工作中常见函数后台周期执行的情况,Oracle有job实现,gp数据库可以通过shell+crontab实现。流程如下:
- gpadmin用户下创建函数sh脚本。
- 将sh挂在crontab任务上
################################详细描述###################################
一、在路径 /home/summer 下创建文件 task_month.sh ,内容如下:
#!/bin/bash
##导入gp数据库脚本
source /usr/local/greenplum-db/greenplum_path.sh
##填写IP,端口,数据库名称,用户,密码。
export PGHOST="132.***.**.2"
export PGPORT="5432"
export PGDATABASE="lntms"
export PGUSER="gpadmin"
export PGPASSWORD="gpadmin"
##时间处理,作为入参
v_month=`date -d"-1 month" '+%Y%m'`
v_month_two=`date -d"-2 month" '+%Y%m'`
##打印执行开始时间,参数等信息
echo -e " \n"`date -d today '+%Y-%m-%d %T'`
echo "v_month:"${v_month}
echo "v_month_two:"${v_month_two}
echo "参数:"${1}
##将入参赋值给变量
v_type=${1}
##根据入参做判断加工
if [ ${v_type} -eq 1 ] ; then
echo "report begin..."
psql -tc "select rpt.p_rpt_test1('${v_month_two}');"
##中间睡3秒吧
sleep 3
psql -tc "select rpt.p_rpt_test1('${v_month}');"
echo "report end ... SUCCESS ..."
elif [ ${v_type} -eq 2 ] ; then
echo "pro begin..."
psql -tc "select rpt.p_rpt_test2('${v_month}','${v_month_two}','hb');"
echo "pro end ... SUCCESS ..."
else
echo "参数未知"
fi
二、将sh放到crontab上执行吧!
##将执行后的结果保存到日志文件中
/home/summer/task_month.sh 1 >> /home/summer/task_month.log
大功告成!
上一篇: