公招需要链接Oracle数据库,导出数据到Mysql中,每天都需要进行相同的操作,所以决定写了一段Python脚本,利用ubuntu自动的crontab定时运行。一切调整结束,并且在命令行中也能正常进行,可是自动执行时就无法工作,日志也没有记录,找了半天,终于发现问题所在。
在脚本最上方,程序如下:
#encoding:utf-8
import os
import time
import sys
import MySQLdb
import mysqlHelper
import cx_Oracle
import oracleHelper
注意,这里
import cx_Oracle
cx_Oracle需要依赖oracle的ORACLE_HOME环境。我发现ORACLE_HOME定义在/etc/profile下,在这里修改的内容是对所有用户起作用的,但是对crontab是不起作用的。以下是各个文件的一个作用域:
- /etc/profile: 此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行. 并从/etc/profile.d目录的配置文件中搜集shell的设置。
- /etc/bashrc: 为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取。
- ~/.bash_profile: 每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次!默认情况下,他设置一些环境变量,执行用户的.bashrc文件。
- ~/.bashrc: 该文件包含专用于你的bash shell的bash信息,当登录时以及每次打开新的shell时,该该文件被读取。
- ~/.bash_logout: 当每次退出系统(退出bash shell)时,执行该文件. 另外,/etc/profile中设定的变量(全局)的可以作用于任何用户,而~/.bashrc等中设定的变量(局部)只能继承 /etc/profile中的变量,他们是"父子"关系。
- ~/.bash_profile 是交互式、login 方式进入 bash 运行的~/.bashrc 是交互式 non-login 方式进入 bash 运行的通常二者设置大致相同,所以通常前者会调用后者。
解决办法,在crontab中调用时修改为下面的语句:
30 7 * * * . /etc/profile; /usr/local/bin/python2.7 /data/storeDataToOracleDB.py
注意etc之前的句号不能省略,问题解决。