最近项目有一个python的项目需要发布环境,想着应该和java的部署流程差不多:
- 从git上拉取指定分支的代码
- 上传到指定服务器
- 运行指定远程服务器上的重启脚本
整个过程想想都觉得没啥大问题.
但是…
转角就是一个模块异常 :
一般看到这个问题,从网上看到有两种方案:
- 代码中自己指定路径
- 从环境变量中自己指定.
/etc/profile
加上PYTHONPATH
因为之前部署过一个python也是这么解决的想着问题也不大。
但是吧。。。搞了将近一天都没解决!!!!
他喵的。。。
心态差点崩盘,到底是哪里出了鬼?
python相关的文章全部啃完了,都没发现个所以然,心态接近崩盘。
但是慢慢复盘发现一个很有意思的现象:
- 我从服务器上手动执行脚本,能启动成功!!!!!!!!
- jenkins执行远程服务器上的启动脚本,异常就出现了。
应该是远程执行的过程中出现了猫腻。
他喵的
按照这个线索找答案,网上找到这样一个相似问题 :
之前在使用Jenkins执行远程shell脚本时,出现提示java: command not found;
多方查找原因后发现是因为远程执行shell脚本时,不会自动加载环境变量,导致出现此错误,
解决方案就是在脚本前加上这段代码即可source /etc/profile;
想一想也有可能,因为我的PYTHONPATH就是在环境变量中指定的,而且我手动能执行成功,但是远程调用脚本执行就不行!
然后尝试了一下,他喵的 OK了。
有时候排查问题的方向真的很重要,他喵的。
坑太多了,脑子真的不够用。