博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【 PostgreSQL】后台周期执行函数实例(shell+crontab)
阅读量:4346 次
发布时间:2019-06-07

本文共 1239 字,大约阅读时间需要 4 分钟。

工作中常见函数后台周期执行的情况,Oracle有job实现,gp数据库可以通过shell+crontab实现。流程如下:

  1. gpadmin用户下创建函数sh脚本。
  2. 将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

 

大功告成!

 

上一篇:

转载于:https://www.cnblogs.com/summer108/p/9563009.html

你可能感兴趣的文章
@ConfigurationProperties注解取消location属性
查看>>
查看XBox360的系统版本信息
查看>>
TCP状态转换图解析
查看>>
.net web 开发遇到的一些问题总结
查看>>
Spring整合Mybatis原理简单分析
查看>>
阻塞&&非阻塞
查看>>
centos7,yum安装工具报错
查看>>
[BZOJ 1003] 物流运输
查看>>
Android Studio 代码无提示,无颜色区分
查看>>
移动端返回刷新
查看>>
SAML
查看>>
What is event bubbling and capturing?
查看>>
File and Folder Permissions
查看>>
DBContext
查看>>
firewall 允许app访问网络
查看>>
window.addEventListener介绍说明
查看>>
JSON字符串转JavaBean,net.sf.ezmorph.bean.MorphDynaBean cannot be cast to ……
查看>>
Java小知识----POI事件模式读取Excel 2007
查看>>
Linux常见英文报错中文翻译
查看>>
17. Letter Combinations of a Phone Number
查看>>