环境为:Linux + Nginx + PHP
我在测试服务器的 git 库写了个钩子,用来将最新的代码发布到测试环境的 www 目录。这个 www 目录是个软链接。
比如现在有软链接:/var/www/a 链接到 /var/code/a0
当有人提交代码时,会新建 /var/code/a1 目录,并删除 /var/code/a0 目录,然后将 /var/www/a 链接到 /var/code/a1
问题:当有成员提交代码后,在浏览器访问项目地址时,会在一段时间内持续报 403 错误。一会又好了。
猜想:是不是 fpm 在读取一个文件后会记录其 innode 并缓存一段时间,导致发布代码后,fpm 还在尝试通过之前缓存的 innode 来加载文件,所以导致 403 呢? 如果是,有什么好办法解决吗?
1
silenceeeee OP 来一位大兄弟帮帮忙啊
|
2
EvilCult 2019-08-07 14:54:26 +08:00
所有软连接的问题,我都先暴力的换成 mount 试一下,然后再找其他原因
|
3
dot2017 2019-08-07 15:27:08 +08:00
连接锁吧
|
4
VD 2019-08-07 16:36:31 +08:00
aN 提交代码的时候能控制么,能的话,直接软连接上层目录。
否则好像要 nginx -s reload 下 |
5
silenceeeee OP @VD 与 nginx 似乎没关系,每次提交代码后 fpm 重启一下倒是可以解决问题, 但是这种做法不是很好。
|
6
VD 2019-08-08 11:44:54 +08:00 1
@silenceeeee
https://hackernoon.com/truly-atomic-deployments-with-nginx-and-php-fpm-aed8a8ac1cd9 看下这位同学的解决方法,似乎都不需要 nginx -s reload,改变软连接指向,就及时生效。 需要将 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 改为 fastcgi_param SCRIPT_FILENAME $realpath_root$fastcgi_script_name; 然后 fastcgi_params 文件里注释掉 SCRIPT_FILENAME 你可以试试 |
7
silenceeeee OP @VD 兄弟,谢谢啊,问题解决了。你是搜的什么关键词呢,我搜了好久没搜到此类文章。
|
8
VD 2019-08-08 16:10:10 +08:00
@silenceeeee nginx php-fpm symlinks
谷歌第一条就是...... |