Nextcloud fpm 版在 Dokcer 下安装踩坑
安装
首先到 https://registry.hub.docker.com/_/nextcloud 获取 Nextcloud 的示例 docker-compose
version: '2'
volumes:
nextcloud:
db:
services:
db:
image: mariadb
restart: always
command: --transaction-isolation=READ-COMMITTED --binlog-format=ROW
volumes:
- db:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=
- MYSQL_PASSWORD=
- MYSQL_DATABASE=nextcloud
- MYSQL_USER=nextcloud
app:
image: nextcloud:fpm
restart: always
links:
- db
volumes:
- nextcloud:/var/www/html
environment:
- MYSQL_PASSWORD=
- MYSQL_DATABASE=nextcloud
- MYSQL_USER=nextcloud
- MYSQL_HOST=db
web:
image: nginx
restart: always
ports:
- 8080:80
links:
- app
volumes:
- ./nginx.conf:/etc/nginx/nginx.conf:ro
volumes_from:
- app
修改其为适合自己使用的版本,如我是这么修改的
version: '2'
volumes:
nextcloud:
db:
services:
db:
image: mariadb
restart: always
command: --transaction-isolation=READ-COMMITTED --binlog-format=ROW --skip-innodb-read-only-compressed
volumes:
- /home/puzhiwei/docker/nextcloud/mysql/lib:/var/lib/mysql
- /home/puzhiwei/docker/nextcloud/mysql/etc:/etc/mysql
environment:
- MYSQL_ROOT_PASSWORD=
- MYSQL_PASSWORD=
- MYSQL_DATABASE=nextcloud
- MYSQL_USER=nextcloud
app:
image: nextcloud:fpm
restart: always
links:
- db
volumes:
- /home/puzhiwei/docker/nextcloud/config:/var/www/html/config
- /home/puzhiwei/docker/nextcloud/data:/var/www/html/data
- /home/puzhiwei/docker/nextcloud/apps:/var/www/html/custom_apps
environment:
- MYSQL_PASSWORD=
- MYSQL_DATABASE=
- MYSQL_USER=nextcloud
- MYSQL_HOST=db
web:
image: nginx
restart: always
ports:
- 81:80
links:
- app
volumes:
- /home/puzhiwei/docker/nextcloud/nginx/nginx.conf:/etc/nginx/nginx.conf:ro
volumes_from:
- app
mariadb 配置
我主要添加了 Docker 容器到本地文件的映射,为 mariadb 添加了 --skip-innodb-read-only-compressed
启动命令,如果没有这段启动命令,会出现
nextcloud install Error while trying to initialise the database: An exception occurred while executing a query: SQLSTATE[HY000]: General error: 4047 InnoDB refuses to write tables with ROW_FORMAT=COMPRESSED or KEY_BLOCK_SIZE.
的异常。
Nginx 配置
此处首先要到 https://github.com/nextcloud/docker/blob/master/.examples/docker-compose/with-nginx-proxy/mariadb/fpm/web/nginx.conf 获取需要的Ningx 配置文件,之后设定相应的文件映射。
启动
直接使用 docker-compose up -d
等待镜像下载运行完成即可。
然后访问 http://ip:81
设置管理员账号,完成安装。
踩坑
如何配置 cron 任务
首先在容器中安装需要的软件
# 安装 cron
apt update
apt install cron
# 安装 vim
apt install vim
# 启动 cron
service cron start
由于是在 Docker 容器中运行的 Nextcloud,进入docker 容器默认是 root 用户,此时执行 php -f /var/www/html/cron.php
会出现
Console has to be executed with the user that owns the file config/config.php
Current user id: 0
Owner id of config.php: 33
的异常,因为 cron.php 需要使用 www-data 用户来执行
而 docker 容器中又缺少相应的权限管理工具。
此时我们需要在进入 Nextcloud 镜像之后执行
root@50ce68418e44:/var/www/html# chsh -s /bin/bash www-data
root@50ce68418e44:/var/www/html# su - www-data
将自己切换到 www-data 用户
更新:现在可以通过
sudo docker exec -it -u 33 bec872 bash
增加-u 33
参数将自己切换到www-data
用户。
然后执行
php -d memory_limit=-1 -f /var/www/html/cron.php --define apc.enable_cli=1
注意此处不加 memory_limit=-1
会出现
Fatal error: Allowed memory size of 2097152 bytes exhausted (tried to allocate 438272 bytes) in /var/www/html/3rdparty/composer/autoload_real.php on line 37
的异常。
运行成功后我们就可以配置定时任务了
运行
# 设置 crontab
crontab -e
然后添加
*/5 * * * * chsh -s /bin/bash www-data && su - www-data -c "php -d memory_limit=-1 -f /var/www/html/cron.php --define apc.enable_cli=1"
即可完成 Nextcloud 的 cron 配置
更多 cron 配置请参照 Nextcloud 文档:https://docs.nextcloud.com/server/23/admin_manual/configuration_server/background_jobs_configuration.html
cron 不生效怎么办
如果按照上面的操作方式配置的定时任务不生效,那么可以直接在主机配置 cron 任务
首先检查 cron 状态
service cron status
如果没有安装 cron 则需要按照上面的方法安装 cron
安装完成后输入
crontab -e
编辑下面的文本
*/5 * * * * docker exec -u 33 bec872 php -d memory_limit=-1 -f /var/www/html/cron.php --define apc.enable_cli=1
注意,此处需要删掉 -it 参数
保存后重启 cron 服务
service cron restart
超过30M的大图片无法预览
造成此问题的原因是系统默认给 PHP 图片处理预览的内存太小,默认为 128 M,而预览大一点的图片 512 M 是一个合适的选择,当然你也可以设置更大的数字。
修改 config.php 文件,添加以下参数即可。
* max memory for generating image previews with imagegd (default behavior)
* Reads the image dimensions from the header and assumes 32 bits per pixel.
* If creating the image would allocate more memory, preview generation will
* be disabled and the default mimetype icon is shown. Set to -1 for no limit.
*
* Defaults to ``128`` megabytes
*/
'preview_max_memory' => 512,
版权
本文首发于 https://www.buguagaoshu.com/archives/nextcloudfpmban-zai-dokcerxia-an-zhuang-cai-keng
转载请注明来源
- 感谢你赐予我前进的力量