crontab自动运行python程序进行cx_Oracle链接Oracle数据库

公招需要链接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是不起作用的。以下是各个文件的一个作用域:

  1. /etc/profile: 此文件为系统的每个用户设置环境信息,当用户第一次登录时,该文件被执行. 并从/etc/profile.d目录的配置文件中搜集shell的设置。
  2. /etc/bashrc: 为每一个运行bash shell的用户执行此文件.当bash shell被打开时,该文件被读取。
  3. ~/.bash_profile: 每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次!默认情况下,他设置一些环境变量,执行用户的.bashrc文件。
  4. ~/.bashrc: 该文件包含专用于你的bash shell的bash信息,当登录时以及每次打开新的shell时,该该文件被读取。
  5. ~/.bash_logout: 当每次退出系统(退出bash shell)时,执行该文件. 另外,/etc/profile中设定的变量(全局)的可以作用于任何用户,而~/.bashrc等中设定的变量(局部)只能继承 /etc/profile中的变量,他们是"父子"关系。
  6. ~/.bash_profile 是交互式、login 方式进入 bash 运行的~/.bashrc 是交互式 non-login 方式进入 bash 运行的通常二者设置大致相同,所以通常前者会调用后者。

解决办法,在crontab中调用时修改为下面的语句:

30 7 * * *  . /etc/profile; /usr/local/bin/python2.7 /data/storeDataToOracleDB.py

注意etc之前的句号不能省略,问题解决。

本文作者:肖云

本文链接:http://www.d7dd.com/2019/8/cx-Oracle-crontab

版权声明:本博客所有文章除特别声明外,均采用CC BY-NC-SA 3.0许可协议。转载请注明出处!

Python双环境下安装配置爬虫环境
0 条评论
已登录,注销 取消