我在云中的 Arch 上运行 LAEMP 反向代理服务器。
我将nextcloud/data
文件夹安装到附加存储驱动器上/mnt/hdd/nextcloud/data
,并链接到/srv/www/nextcloud/data
。
如果我不这样做,而是保持nextcloud/data
在同一个磁盘上/
,那么我根本不会遇到这个问题。
在 时reboot
,系统启动;PHP 页面出错,但 和 均未httpd
显示nginx
任何错误systemctl status
。错误位于 中php-fpm
。
输出systemctl status php-fpm
:
× php-fpm.service - The PHP FastCGI Process Manager
Loaded: loaded (/usr/lib/systemd/system/php-fpm.service; enabled; preset: disabled)
Drop-In: /etc/systemd/system/php-fpm.service.d
└─override.conf
Active: failed (Result: exit-code) since Tue 2023-05-30 16:47:30 PDT; 14s ago
Process: 316 ExecStart=/usr/bin/php-fpm --nodaemonize --fpm-config /etc/php/php-fpm.conf (code=exited, status=226/NAMESPACE)
Main PID: 316 (code=exited, status=226/NAMESPACE)
CPU: 8ms
May 30 16:47:29 MY_HOST systemd[1]: Starting The PHP FastCGI Process Manager...
May 30 16:47:29 MY_HOST (php-fpm)[316]: php-fpm.service: Failed to set up mount namespacing: /run/systemd/unit-root/mnt/hdd/nextcloud/data: No such file or directory
May 30 16:47:29 MY_HOST (php-fpm)[316]: php-fpm.service: Failed at step NAMESPACE spawning /usr/bin/php-fpm: No such file or directory
May 30 16:47:30 MY_HOST systemd[1]: php-fpm.service: Main process exited, code=exited, status=226/NAMESPACE
May 30 16:47:30 MY_HOST systemd[1]: php-fpm.service: Failed with result 'exit-code'.
May 30 16:47:30 MY_HOST systemd[1]: Failed to start The PHP FastCGI Process Manager.
systemd
Nextcloud 从drop-in中获取此信息/etc/systemd/system/php-fpm.service.d/override.conf
:
[Service]
...
ReadWritePaths=/srv/www/nextcloud/data
当我运行时systemctl restart php-fpm
,错误会永远消失,直到下次重新启动。
我推测服务php-fpm
无法找到nextcloud
文件夹,因为启动hdd/
时未安装php-fpm
,并希望查看其 Web 文件夹。我认为我应该以某种方式调整运行级别php-fpm
和/或(最好)何时/etc/fstab
将连接的存储驱动器加载到/mnt/hdd
。
/etc/fstab
/mnt/hdd
使用以下语句安装驱动器:
/dev/vdc1 /mnt/hdd ext4 defaults,noatime,nofail 0 0
我在网上搜索到的任何东西都没能告诉我如何解决这个问题。搜索结果中所有的东西都显示与php-fpm
或无关的内容/etc/fstab
。即便如此,我最多也只能得到一些脚本小子的答案。
我想知道vdc1
在运行时尽早挂载的正确方法,或者至少等到php-fpm
目录可用后再发脾气。
答案1
您可以通过将以下配置选项添加到现有文件中来将 systemd 单元配置为仅在挂载后启动,或者如果不想修改它,则添加另一个配置选项:
[Unit]
After=local-fs.target
另一个选择是将以下选项添加到 fstab 中的挂载定义中:
x-systemd.required-by=php-fpm.service
答案2
尽管另一个答案里面的声明暂时有帮助/etc/fstab
,修改.service
文件最终成为我更可靠的解决方案......
我们需要一些声明在服务配置中,但在 下[Unit]
,不是[Service]
,有点像:
[Unit]
Requires=local-fs.target
After=local-fs.target
但是,问题是把它们放在哪里以及Requires=
和的值应该是多少After=
。
我们需要一项服务插入覆盖配置。
服务为php-fpm
,其原始配置文件位于/lib/systemd/system/php-fpm.service
。但是,修改该文件并非永久性的,因为它会被升级替换。相反,需要创建一个覆盖文件,其名称任意,扩展名为.conf
。/etc/systemd/system/php-fpm.service.d/
虽然/etc/systemd/system/
应该已经存在,其中包含许多内容,php-fpm.service.d/
但可能需要创建子文件夹。
基于/etc/fstab:
UUID=long-uuid-serial-c0de1 /mnt/ssd ext4 defaults,noatime,nofail,x-systemd.required-by=php-fpm.service 0 0
UUID=long-uuid-serial-c0de2 /mnt/hdd ext4 defaults,noatime,nofail,x-systemd.required-by=php-fpm.service 0 0
这命令:
systemctl list-units --type=mount
返回多行,包括这些:
mnt-hdd.mount loaded active mounted /mnt/hdd
mnt-ssd.mount loaded active mounted /mnt/ssd
我们从/etc/fstab
和中/mnt/hdd
认识到/mnt/ssd
。
因此,我们需要这个文件:
/etc/systemd/system/php-fpm.service.d/mount.conf:
[Unit]
Requires=mnt-hdd.mount
After=mnt-hdd.mount
Requires=mnt-ssd.mount
After=mnt-ssd.mount