crontab 运行环境遇到的一个问题

栏目: IT技术 · 发布时间: 6年前

内容简介:睡觉之前,记录昨天遇到的一个问题,不然时间一长我就忘记了,如果我从工作开始就写博客,那么很多美好的事情都不会忘记了,自己的技术水平肯定也会提升一大截。昨天上班后,同事说有一些问题,由于相关程序是队列运行的,先查看了一下php cli错误日志,发现很多脚本提示 Call to undefined function,当时觉得挺奇怪的,因为其他web机器没有该问题。然后手动运行了一个脚本,没有任何问题,基本上断定是cron运行导致的,就先模拟写了个小程序:

睡觉之前,记录昨天遇到的一个问题,不然时间一长我就忘记了,如果我从工作开始就写博客,那么很多美好的事情都不会忘记了,自己的技术水平肯定也会提升一大截。

昨天上班后,同事说有一些问题,由于相关程序是队列运行的,先查看了一下php cli错误日志,发现很多脚本提示 Call to undefined function,当时觉得挺奇怪的,因为其他web机器没有该问题。

然后手动运行了一个脚本,没有任何问题,基本上断定是cron运行导致的,就先模拟写了个小程序:

include "init.php";
echo "start";
echo self_function();//定义在init.php中
echo "end";

然后设置cron:

*/1 * * * * www php /usr/local/www/index.php >> /usr/local/www/debug.log

还是同样的问题,因为是找不到函数,将 include 改为 require 也还是同样的报错,而不是说找不到文件,这就很诡异了;然后把 cli 命令行模式的 Opcache 关闭了,同样报错;

因为以前cron运行 Python 遇到过编码的问题,所以一个闪念,修改了cron:

*/1 * * * * www cd /usr/local/www; php index.php

运行没有问题,虽然问题解决了,但这样cron部署就没有通用性了,所以感觉还是不好。

不断试验,将 init.php 改为 init2.php,然后cron运行就没问题,是不是文件缓存?不管是删除init.php重建;或者stat修改属性;或者将init.php引用目录改为/usr/local/init.php,还是不行,只要名字为 init.php 就是不行。

查看 /var/log/cron 也没有问题。甚至重启 systemctl restart crond.service 也还是不行。

后来同事发了一个php cli 错误报错,虽然看过错误日志但没有注意,猛的发现提示 /home/www/init.php 中没有 HTTP_HOST,怎么提示在 /home/www 目录下?

立刻去/home/www/一看,还真有init.php,删除后,cron正确运行。

基本上验证了 cron 会以 $HOME /home/www 环境变量运行,相当于 index.php 引用 /home/www/init.php,而不是相对路径引用 /usr/local/www/init.php。

后面代码引用文件还是绝对路径较好,那这个 /home/www/init.php 怎么来的呢?这反应了线上环境不能轻易登陆,明年去申请一台配置较低的ecs,作为开发环境和QA环境。

最后还是说一句,其实意识到环境变量的问题,但还是排查了很久,一方面是基本功问题,一方面也是判断力的问题。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

重新定义团队:谷歌如何工作

重新定义团队:谷歌如何工作

拉兹洛·博克 / 宋伟 / 中信出版集团 / 2015-12-1 / CNY 56.00

谷歌首席人才官拉斯洛•博克权威力作,谷歌公开认可的谷歌高层作品,首度揭秘谷歌颠覆工业时代模式的人才和团队管理的核心法则,《纽约时报》畅销榜第一名,Business Insider 2015最佳商业书籍,谷歌的创造力就在于此! 编辑推荐! 1、 谷歌人才官首次公开谷歌人才和团队管理的核心秘籍 在谷歌执掌人事多年的拉斯洛•博克是人才和团队管理的顶级专家。他加入谷歌后,谷歌的员工数从六......一起来看看 《重新定义团队:谷歌如何工作》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

html转js在线工具
html转js在线工具

html转js在线工具