放入crontab中每天晚上定时执行的,好像没什么好解释的呢。唯一需要注意的就是使用TIM JNDI 接口时 执行完单个脚本后需要加sleep时间,因为使用JNDI接口写TIM 以后 ,在TIM中的请求需要时间完成, 否则的话,如果数据量很大,很容易出现数据不一致。很不想出现某人第二天打电话说,我的帐号上不了啦。那就杯具了哈~
#!/bin/bash
#------------- This sync_HR Script , at 6:00 running ------------
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/opt/sap/jco
export CLASSPATH=$CLASSPATH:/opt/sap/jco/sapjco.jar
MYTIME=`date +%Y%m%d_%H%m%S`
LOG_FILE=/ididata/sync/logs/$MYTIME.log
TDI_PATH=/opt/IBM/TDI/V6.1.1
XML_PATH=/ididata/sync/xml
TDI_LOG=/ididata/sync/logs
#------------- Disable_person -------------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/disable_person.xml -r disable_person
sleep 5
echo "==========================================" >> $LOG_FILE
echo "Disable_person" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Defer Time---------------------------------
sleep 1800
#-------------- Clear_db2_hrdept --------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/clear_db2_hrdept.xml -r clear_db2_hrdept
sleep 5
echo "==========================================" >> $LOG_FILE
echo "Clear_db2_hrdept" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Sync_employee_data --------------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/sync_employee_data.xml -r sync_employee_data
sleep 5
echo "==========================================" >> $LOG_FILE
echo "Sync_employee_data" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Sync_department_data ------------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/sync_department_data.xml -r sync_department_data
sleep 5
echo "==========================================" >> $LOG_FILE
echo "Sync_department_data" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Sync_department_relation --------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/sync_department_relation.xml -r sync_department_relation
sleep 5
echo "==========================================" >> $LOG_FILE
echo "Sync_department_relation" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Disable_dept ---------------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/disable_dept.xml -r disable_dept
sleep 5
echo "==========================================" >> $LOG_FILE
echo "Disable_dept" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Sync_company_to_tim --------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/sync_company_to_tim.xml -r sync_company_to_tim
sleep 5
echo "==========================================" >> $LOG_FILE
echo "sync_company_to_tim" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Delete_empty_company --------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/delete_empty_company.xml -r delete_empty_company
sleep 5
echo "==========================================" >> $LOG_FILE
echo "Delete_empty_department" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- load_group --------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/group.xml -r 1_load_group
sleep 5
echo "==========================================" >> $LOG_FILE
echo "1_load_group" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- delete_group --------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/group.xml -r 2_delete_group
sleep 5
echo "==========================================" >> $LOG_FILE
echo "2_delete_group" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
#------------- Update_contact_info ------------------------------
echo " " > /ididata/solution/logs/ibmdi.log
$TDI_PATH/ibmdisrv -c $XML_PATH/update_contact_info.xml -r update_contact_info
echo "==========================================" >> $LOG_FILE
echo "Update_contact_info" >> $LOG_FILE
printf "\n\n\n" >> $LOG_FILE
cat /ididata/solution/logs/ibmdi.log >> $LOG_FILE
echo "==========================================" >> $LOG_FILE
sleep 5
printf "\n\n\n\n\n\n\n" >> $LOG_FILE
################## after sleep ######################