lnmp 软链接 403 问题求助

2019-08-07 12:16:40 +08:00
 silenceeeee

环境为: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 呢? 如果是,有什么好办法解决吗?

1189 次点击
所在节点    问与答
8 条回复
silenceeeee
2019-08-07 12:34:32 +08:00
来一位大兄弟帮帮忙啊
EvilCult
2019-08-07 14:54:26 +08:00
所有软连接的问题,我都先暴力的换成 mount 试一下,然后再找其他原因
dot2017
2019-08-07 15:27:08 +08:00
连接锁吧
VD
2019-08-07 16:36:31 +08:00
aN 提交代码的时候能控制么,能的话,直接软连接上层目录。

否则好像要 nginx -s reload 下
silenceeeee
2019-08-07 21:47:50 +08:00
@VD 与 nginx 似乎没关系,每次提交代码后 fpm 重启一下倒是可以解决问题, 但是这种做法不是很好。
VD
2019-08-08 11:44:54 +08:00
@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

你可以试试
silenceeeee
2019-08-08 15:50:15 +08:00
@VD 兄弟,谢谢啊,问题解决了。你是搜的什么关键词呢,我搜了好久没搜到此类文章。
VD
2019-08-08 16:10:10 +08:00
@silenceeeee nginx php-fpm symlinks
谷歌第一条就是......

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/589785

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX