图片上传时当图片过大时如何生成缩略图保存在服务器上

图片上传时当图片过大时如何生成缩略图保存在服务器上,第1张

1月24日

14:25

没有问题,可以使用Photoshop,

或是Windows自带的画图也可以。

在Photoshop中打开图片,再新建一个空白文件,用左侧工具栏的

移动工具

,把所有的图片都拖进这个

空白文档

中,变换大小尺寸,移动排好合适位置,之后另存

JPEG格式

,注意文件的总大小,不要超过规定上传的文件大小(

百度知道

不要超过200K)。

画图,打开画图建新文件——编辑——粘贴来源,在目录中找到你的图片,双击打开,改变尺寸大小,移动位置,再重复——编辑——粘贴来源,这样一个一个把你的图像粘贴进来,排好位置和大小后,就可以保存了。

祝你好运

揪错

nextcloud 默认并不会为存储的图片提前生成缩略图,只有当我们在网页或者客户端,访问到相应的图片时,才会在服务器上进行生成。

这种按需生成的策略,一定程度上节省了服务器空间,但是带来的问题就是,如果当前目录下图片较多,比如有个几百张照片之类的,而且 cpu 的性能不行,比如我的老旧笔记本,你就会发现图片的缩略图加载的特别慢,比如像下面这样:

这时候的慢,并不是因为网络原因,打开服务器上的 netdata 页面,可以看到,cpu 已经爆表了。

虽然说只要加载一次之后,缩略图就会缓存在服务器上,下次就不需要重新生成了,但是如果照片特别多,总是会有很多从上传之后第一次访问的目录。

如果偶尔需要在 nextcloud 上翻找翻找旧照片,回忆一下的话,这种时候,缩率图加载太慢的话,肯定影响回忆的心情。

经过一番检索,发现 nextcloud 有一个预先生成缩率图的插件: Preview Generator

应用商店里的简介并没有描述如何使用,可以去 github 里查看具体的文档: https://github.com/rullzer/previewgenerator 。

安装方法其实也很简单,按照文档来:

第一步在应用市场中安装插件。

第二步启用插件。

第三步的意思是,这个插件安装完成之后,手动触发一下给所有图片生成缩率图。

这里需要注意一下,因为我是在 k3s 集群里用 docker 部署的 nextcloud ,如果需要执行 occ 命令的话,选择进入容器内部听着好像是个不错的选择,但是这个命令是需要以 www-data 这个用户身份执行的,而 www-data 又被设置成了禁止登陆的用户,所以如果直接在容器内部执行 su -l www-data php occ preview:generate-all 命令的话,会报错。

解决方式就是直接 ssh 登陆上宿主机,然后执行 docker exec --user www-data Container_ID php occ preview:generate-all 就行了,正在扫描的目录,会被打印到标准输出中。

同时缩率图会被存在 /var/www/html/data/appdata_occ3eu1bw2q6#/preview 目录下。

通过 watch -n 1 du -m -d 1 命令,我们可以看到, preview 目录的大小一直在增长,说明缩略图在持续的生成中。

同时我们可以看到,cpu 占用稳定在 50% 左右,相对于默认的按需生成时,直接 cpu 满载来说,这个插件只是利用闲时 cpu 计算能力,还是比较合适的,就算服务器上有其他服务,也不用太担心受到影响。

当有新的图片上传的时候,这个插件并不会自动触发,说白了就是这个插件仅仅提供了一个命令给我们,需要我们自己去调用,那么可以将这个命令加入到定时任务中,每隔一段时间就自动运行一次。

之前加定时任务的时候,一直失败不触发,还没有看看是为啥。

理论上讲就是加上一条 /usr/local/bin/php occ preview:pre-generate 即可。


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/801669.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-08-28
下一篇2023-08-28

发表评论

登录后才能评论

评论列表(0条)

    保存