PHP-FPM 在 /etc/fstab 中挂载 Web 文件夹之前启动,引发错误

PHP-FPM 在 /etc/fstab 中挂载 Web 文件夹之前启动,引发错误

我在云中的 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.

systemdNextcloud 从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

相关内容