我发现转换成百万个这样的图像的最好方法是创建一个简单的bash脚本,该脚本开始转换找到的所有图像,例如下面列出的图像:
要编辑此bash脚本,如果您没有nano,请使用nano:“
apt-get install nano”对于Ubuntu / Debian或“
yuminstall nano”对于CentOS / CloudLinux ..对于其他发行版:使用Google),但是您可以自由使用任何所需的编辑器。
Bash脚本
首先,通过启动您喜欢的编辑器(mine的
nano)来创建bash脚本:
nano -w ~/imgconv.sh
然后用以下内容填充它:
#!/bin/bashfind ./ -type f -iname "*.jpeg" -exec mogrify -verbose -format jpeg -layers Dispose -resize 1024>x1024> -quality 75% {} +find ./ -type f -iname "*.jpg" -exec mogrify -verbose -format jpg -layers Dispose -resize 1024>x1024> -quality 75% {} +find ./ -type f -iname "*.png" -exec mogrify -verbose -format png -alpha on -layers Dispose -resize 1024>x1024> {} +然后,您需要做的就是使其可执行文件
chmod +x ~/imgconv.sh并在主图像目录中运行,并在其中调整所有子目录中图像的大小:
cd /var/www/webshop.example.com/public_html/media/~/imgconv.sh
那应该开始转换过程。
说明
该脚本的工作方式是,它使用find来查找扩展名为
.jpeg大写的文件,然后运行命令:
find ./ -type f -iname "*.jpeg" -exec <COMMAND> {} +..然后使用“ -exec {} +”参数执行适当的转换作业:
mogrify -verbose -format jpeg -layers Dispose -resize 1024>x1024> -quality 75% <### the filename goes here, in this case *.jpeg ###>
如果您正在使用比今天更旧的文件,并且想要防止重做今天已经转换过的文件,您甚至可以通过添加如下选项来告诉“ find”命令仅转换比今天更旧的文件
-mtime+1:
#!/bin/bashfind ./ -type f -mtime +1 -iname "*.jpeg" -exec mogrify -verbose -format jpeg -layers Dispose -resize 1024>x1024> -quality 75% {} +find ./ -type f -mtime +1 -iname "*.jpg" -exec mogrify -verbose -format jpg -layers Dispose -resize 1024>x1024> -quality 75% {} +find ./ -type f -mtime +1 -iname "*.png" -exec mogrify -verbose -format png -alpha on -layers Dispose -resize 1024>x1024> {} +性能
使用更多内核执行此过程的一种非常简单的方法是,通过
&在每行之后添加a,将每个作业派生到后台。另一种方法是使用GNU Parallel,尤其是使用-
X参数,因为它将使用您所有的CPU内核,并使工作更快地完成很多次。
但是,无论您要使用哪种并行化技术,都请确保仅在自己的系统上而不是在生产平台所在的共享磁盘系统上执行此操作,因为要获得最大的性能会降低硬件或虚拟机监控程序的性能。
这项工作将需要一段时间,因此请确保事先设置没有超时/空转数据包的屏幕或终端。在我的系统上,它每分钟可以处理大约5000个文件,因此整个工作应该少于50-60小时…听起来像是周末进行的一项很好的工作。
只要确保通过编写单独的命令将所有文件扩展名彼此分开即可;将所有选项叠加在一起并使用所有图像格式的所有选项进行“迁移”将不起作用。
ImageMagick是正确的强大工具。



