解决php中通过exec调用python脚本报ModuleNotFoundError错误
背景
出于某些原因,我们有时会在PHP中通过exec来调用Python代码,有可能是某些功能只能用Python实现(或用Python实现比较方便),有可能是出于性能考虑(Python可以执行耗时任务)。
但我们有时会发现,在控制台用命令行的方式运行python脚本一切正常,在 php 中用 exec
调用就报 ModuleNotFoundError: No module named 'xxx'
错误。
本文是在 Ubuntu 20.04 上以 ubuntu
用户身份进行的测试。
错误原因
用户不同
这种错误一般都是因为执行脚本的用户不同导致的,php用exec
调用python脚本时,使用的用户一般是 www-data
,而我们在控制台一般都是 root
或 ubuntu
用户。
这个可以通过 whoami
命令来验证。
php代码如下:
$pythonScript = "whoami";
Log::info("exec script:" . $pythonScript);
exec($pythonScript, $output, $returnValue);
Log::info("exec output:" . json_encode($output));
Log::info("exec returnValue:" . $returnValue);
输出如下:
[2023-07-13 10:34:27] local.INFO: exec script:whoami
[2023-07-13 10:34:27] local.INFO: exec output:["www-data"]
[2023-07-13 10:34:27] local.INFO: exec returnValue:0
为什么用户不同就会导致 ModuleNotFoundError: No module named 'xxx'
这个错误呢,根本原因还是权限问题。
权限问题
我们在控制台写python脚本时,一般会通过 pip[3] install [xxx]
的形式安装依赖的包,这时包一般会安装在用户目录。
下面做个测试,我们安装 python-dotenv
这个包,然后查看包的安装位置:
可以看到这个包安装在了 /home/ubuntu/.local/lib/python3.8/site-packages
这个目录。
下面我们试一下用 www-data
用户的身份是否有权限调用。
Python测试代码:
from dotenv import load_dotenv
load_dotenv()
分别用当前用户和www-data
调用:
可以看到用www-data
调用时果然报ModuleNotFoundError: No module named 'dotenv'
错误。
我们查看一下我们安装的python-dotenv
对www-data
用户是否可用:
sudo -u www-data pip3 show python-dotenv
可以看到确实是没有的。
即然原因确定了,接下来就好办了。
解决方案
方案一:修改web服务器用户
即然是控制台用户可以运行脚本,我们把Web服务器用户改为控制台用户就可以了,以 apache 为例具体步骤如下:
1.打开apache配置文件:sudo vim /etc/apache2/apache2.conf
2.更改以下两行,将运行的用户和组设置为自己所需的:
User ${APACHE_RUN_USER}
Group ${APACHE_RUN_GROUP}
#更改为
User ubuntu
Group ubuntu
3.重启apache:sudo service apache2 restart
注:这种方案能解决问题,但并不好,因为权限给的太大了,有很大的安全风险,不建议用。
方案二:给 www-data 用户安装python依赖库
在安装之前我们确认一下www-data用户是否没有安装python-dotenv包:
sudo -u www-data pip3 show python-dotenv
下面我们给 www-data 用户安装python-dotenv包:
#安装
sudo -u www-data pip3 install python-dotenv
#显示安装路径
sudo -u www-data pip3 show python-dotenv
我们可以看到,安装到了 /var/www/.local/lib/python3.8/site-packages
目录下。
我们来验证一下:
sudo -u www-data python3 pyscripts/test.py
可以看到不报错了。
大家还有别的方案吗?欢迎留言讨论。
解决php中通过exec调用python脚本报ModuleNotFoundError错误的更多相关文章
- 在go中通过cmd调用python命令行参数量级过大问题解决
问题描述如下: 在go中使用cmd调用python命令行 cmd := exec.Command("python", "dimine/Kriging/matrix.py& ...
- 运行python脚本报错:selenium.common.exceptions.SessionNotCreatedException: Message: session not created
运行python脚本报错:selenium.common.exceptions.SessionNotCreatedException: Message: session not created 原因: ...
- QT中 使用c++调用python
最近在做一个项目,开发环境用的是QT c++.项目中使用amazon云服务,调研发现有一个Amazon云的python接口.就有了标题中的问题,需要用C++来调用python脚本. 下面是一个c++调 ...
- Windows下运行python脚本报错“ImportError: No Module named ...”的解决方法
之前遇到一个问题,在Pycharm或IPython之类的IDE上运行脚本正常,但是直接运行或cmd命令行运行的时候报了模块未能找到的错误--ImportError: No Module named . ...
- Python脚本报错AttributeError: ‘module’ object has no attribute’xxx’解决方法
最近在编写Python脚本过程中遇到一个问题比较奇怪:Python脚本完全正常没问题,但执行总报错"AttributeError: 'module' object has no attrib ...
- 运行python脚本报错SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: truncated \UXXXXXXXX escape
运行python脚本报错 SyntaxError: (unicode error) 'unicodeescape' codec can't decode bytes in position 2-3: ...
- j解决sparkr中使用某些r的原生函数 发生错误Error: class(objId) == "jobj" is not TRUE的问题
Create table function in Spark in R not working João_Andre (3) 询问的问题 | 2016年12月10日 06:03BLUEMIXRSPA ...
- Python脚本报错AttributeError: 'module' object has no attribute 'maketrans'
出现此错误的原因:是此文件smtp02.py 所在的目录下有string.pyc 的文件存在,与python库里的string.pyc冲突造成无法确认编译所取的类库.
- 头疼的Python 脚本报错
Python 脚本报错 检查是否用了制表符.变量声明前面不能用制表符,只能用空格,版本为2.7.14
- 在Java中调用Python
写在前面 在微服务架构大行其道的今天,对于将程序进行嵌套调用的做法其实并不可取,甚至显得有些愚蠢.当然,之所以要面对这个问题,或许是因为一些历史原因,或者仅仅是为了简单.恰好我在项目中就遇到了这个问题 ...
随机推荐
- 【Spring注解驱动】(一)IOC容器
前言 课程跟的是尚硅谷雷丰阳老师的<Spring注解驱动教程>,主要用于SSM框架向SpringBoot过渡,暑假有点懒散,争取这周看完. 1 容器 Spring的底层核心功能是IOC控制 ...
- Linux命令行与shell脚本编程(1)--读书笔记
这里记录下个人读书笔记,持续更新中(作者小白,大佬轻喷... chap7 理解Linux文件权限 7.1 Linux安全性 Linux系统的每个用户账户都有唯一的用户ID,即UID,用户权限根据UID ...
- Centos7.x 安装 nmon性能监控工具
一.简介 nmon 工具可以帮助在一个屏幕上显示所有重要的性能优化信息,并动态地对其进行更新.这个高效的工具可以工作于任何哑屏幕.telnet 会话.甚至拨号线路.另外,它并不会消耗大量的 CPU 周 ...
- Vue拖拽排序
转载至https://www.crazyming.com/note/757/ 使用拖拽功能来实现排序. 需要先学习w3cschool 关于拖拽的教程:http://www.w3school.com.c ...
- 2022-05-02:给定一个数组arr,一个正数num,一个正数k, 可以把arr中的某些数字拿出来组成一组,要求该组中的最大值减去最小值<=num, 且该组数字的个数一定要正好等于k, 每个数字只
2022-05-02:给定一个数组arr,一个正数num,一个正数k, 可以把arr中的某些数字拿出来组成一组,要求该组中的最大值减去最小值<=num, 且该组数字的个数一定要正好等于k, 每个 ...
- 2021-05-20:给定一个数组arr, 返回如果排序之后,相邻两数的最大差值。要求:时间复杂度O(N) 。
2021-05-20:给定一个数组arr, 返回如果排序之后,相邻两数的最大差值.要求:时间复杂度O(N) . 福大大 答案2021-05-20: 假设答案法.N个数,根据最大值和最小值的范围等分成N ...
- 2021-10-27:课程表。你这个学期必须选修 numCourses 门课程,记为 0 到 numCourses - 1 。在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisi
2021-10-27:课程表.你这个学期必须选修 numCourses 门课程,记为 0 到 numCourses - 1 .在选修某些课程之前需要一些先修课程. 先修课程按数组 prerequisi ...
- sqlmap的一些简单使用命令
路径 C:\Users\Administrator\AppData\Local\Programs\Python\Python39\sqlmap post型注入 *每次使用都要重新抓包,不可以使用旧的数 ...
- LLM探索:GPT概念与几个常用参数 Top-k, Top-p, Temperature
前言 上一篇文章介绍了几个开源LLM的环境搭建和本地部署,在使用ChatGPT接口或者自己本地部署的LLM大模型的时候,经常会遇到这几个参数,本文简单介绍一下~ temperature top_p t ...
- 近期SQL优化实战分享
分享一下本周SQL优化的两个场景. 如果能对读者有一定的启发,共同探讨,不胜荣幸. 版本信息:mysql,5.7.19 引擎: innodb 场景1 我们有一张常口表,里面的数据由各种数据源合并而来, ...