gpt4 book ai didi

Python CRON 找不到 MySQL 驱动程序

转载 作者:行者123 更新时间:2023-11-29 06:32:44 25 4
gpt4 key购买 nike

我不懂 PYTHON,但我必须在 linux (CentOS6) 服务器上以 cronjob 的形式运行脚本,但我遇到了一些问题。

如果我从浏览器 ( http://xx.xx/xx.py ) 或 bash 运行该脚本,它运行良好。在这两种情况下,它都会加载模块并更新 MySql 数据库。

问题出在 CRON 运行时:

/usr/local/bin/python2.7/home/itsme/cron/demo.py >>/home/itsme/cron/logs/cron_log.log

在我的错误日志中:

Failed to connect to MySql DB using connect string- DRIVER={MySQL};SERVER=localhost;DATABASE=dbname;UID=admin;PWD=*******# .Reconnect Attempt# 1

<class 'pyodbc.Error'> ('IM002', '[IM002] [unixODBC][Driver Manager]Data source name not found, and no default driver specified (0) (SQLDriverConnect)')

这意味着找不到 MySql 驱动程序。所以我尝试:#odbcinst -j

unixODBC 2.2.14
DRIVERS............: /etc/odbcinst.ini
SYSTEM DATA SOURCES: /etc/odbc.ini
FILE DATA SOURCES..: /etc/ODBCDataSources
USER DATA SOURCES..: /root/.odbc.ini
SQLULEN Size.......: 8
SQLLEN Size........: 8
SQLSETPOSIROW Size.: 8

VI/etc/odbcinst.ini

# Example driver definitions

# Driver from the postgresql-odbc package
# Setup from the unixODBC package
[PostgreSQL]
Description = ODBC for PostgreSQL
Driver = /usr/lib/psqlodbc.so
Setup = /usr/lib/libodbcpsqlS.so
Driver64 = /usr/lib64/psqlodbc.so
Setup64 = /usr/lib64/libodbcpsqlS.so
FileUsage = 1


# Driver from the mysql-connector-odbc package
# Setup from the unixODBC package
[MySQL]
Description = ODBC for MySQL
Driver = /usr/lib/libmyodbc5.so
Setup = /usr/lib/libodbcmyS.so
Driver64 = /usr/lib64/libmyodbc5.so
Setup64 = /usr/lib64/libodbcmyS.so
FileUsage = 1

如果我从脚本中打印sys.path:

       ['/home/itsme/cron/', '/usr/local/lib/python2.7/site-packages/setuptools-7.0-py2.7.egg',
'/usr/local/lib/python2.7/site-packages/pip-1.5.6-py2.7.egg',
'/usr/local/lib/python27.zip', '/usr/local/lib/python2.7',
'/usr/local/lib/python2.7/plat-linux2', '/usr/local/lib/python2.7/lib-tk',
'/usr/local/lib/python2.7/lib-old', '/usr/local/lib/python2.7/lib-dynload',
'/usr/local/lib/python2.7/site-packages', '/home/itsme/cron/src', '/usr/lib']

为什么CRON找不到MySQL驱动?

感谢您的帮助。

最佳答案

我认为您的 cron 环境中缺少一些导致此问题的环境变量。

在您的终端中,在此脚本运行的地方,运行以下命令

printenv > env.normal.text

现在,运行一个虚拟的 cron 作业,输出如下所示的环境变量

* * * * * * printenv > env.cron.text

现在只需比较两者的相关缺失变量。在你的 cron 中设置它。

关于Python CRON 找不到 MySQL 驱动程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26914217/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com