【shell实例】定时21:00-21:05,循环调用DSQL脚本,其它时段自动退出
1.功能描述:
每日21:00定时调起test.sh,循环调起DSQL脚本test.dsql,直到21:05程序自动退出,捕获日志到相应log文件中。
2.日志文件:
(1)日期.log文件中含Error Time即为错误;
(2)日期目录中log文件为调用dsql详细日志;
(3)test.log文件中为捕获的屏幕输出日志。
3.程序部署:
(1)ETL服务其中新建目录/tmp/zlt,将附件脚本上传至该目录
mkdir -p /tmp/zlt
(2)赋权
cd /tmp/zlt
chmod +x test.sh
chmod +x test.dsql
(3)定时启动
crontab -e
* * * /tmp/zlt/test.sh>>/tmp/zlt/test.log
4.取消定时启动
crontab -e
删除新增内容即可
5.test.sh代码
#!/bin/sh
dir_home="/tmp/zlt"
curr_date=`date +%Y%m%d`
log_dir=${dir_home}/${curr_date}
result_log=${dir_home}/${curr_date}.log `mkdir -p ${log_dir}` be_s=
en_s=
curr_s=`date +%H%M` echo "[curr_dt]:$curr_date"
echo "[log_dir]:$log_dir"
echo "[rlt_log]:$result_log"
echo "[curr_s]:$curr_s"
echo "[be_s ]:$be_s"
echo "[en_s ]:$en_s" if [ "$curr_s" -lt "$be_s" ] || [ "$curr_s" -gt "$en_s" ];then
echo "curr_s is not between $be_s and $en_s"
exit
fi echo "">${result_log}
count=
while [ "$be_s" -le "$en_s" ]
do
echo "========count:$count=========">>${result_log}
echo "[Start Time]:"`date +%F.%H:%M:%S.%N`>>${result_log}
Dsql -c $ETL_HOME/etc/logon_stg.env -f ${dir_home}/test.dsql >& >${log_dir}/test${count}.log
if [ $? != ];then
echo "[Error Time]:"`date +%F.%H:%M:%S.%N`>>${result_log}
fi
echo "[End Time]:"`date +%F.%H:%M:%S.%N`>>${result_log} count=$[$count+]
be_s=`date +%H%M` done
6.test.dsql代码
sel current_time
.IF ERRORCODE <> THEN .QUIT
.QUIT
【shell实例】定时21:00-21:05,循环调用DSQL脚本,其它时段自动退出的更多相关文章
- (转)shell实例手册
原文地址:http://hi.baidu.com/quanzhou722/item/f4a4f3c9eb37f02d46d5c0d9 实在是太好的资料了,不得不转 shell实例手册 0说明{ 手册制 ...
- shell 实例
转载自:https://github.com/liquanzhou/ops_doc 这里只作为笔记使用,不做他用 shell实例手册 0 说明{ 手册制作: 雪松 更新日期: 2018-09-1 ...
- 【转载】shell实例手册
原文地址:shell实例手册 作者:没头脑的土豆 shell实例手册 0说明{ 手册制作: 雪松 更新日期: -- 欢迎系统运维加入Q群: 请使用"notepad++"打开此文档 ...
- (转) shell实例手册
shell实例手册 1文件{ touch file # 创建空白文件rm -rf 目录名 # 不提示删除非空目录(-r:递归删除 -f强制)dos2uni ...
- shell实例利用crontab自动清除日志
shell实例利用crontab自动清除日志 程序运行会产生很多的日志,对于无用的日志手动删除比价麻烦,写一个自动执行的命令是很有必要的. 删除文件shell命令 find 对应目录 -mtime + ...
- Linux(centos 6.5) 调用java脚本以及定时运行的脚本实例及配置文件具体解释
Linux(centos 6.5) 调用java脚本以及定时运行的脚本实例 一.调用java程序脚本(默认已经搭建好了Java环境) 1.jdk 安装路径 /usr/jdk/jdk1.7/-- 2.j ...
- shell for循环+case的脚本(监控程序状态)
分享一个shell for循环+case的脚本(监控程序状态) 分享一个for循环+case的脚本(监控程序状态并执行相关操作) ,供大家学习参考. 复制代码代码如下: #/bin/bash set ...
- 【转】shell之for、while、until循环
一.简介 Shell编程中循环命令用于特定条件下决定某些语句重复执行的控制方式,有三种常用的循环语句:for.while和until.while循环和for循环属于“当型循环”,而unti ...
- 十二星座 英文名:Aries 金牛座 (4/21 - 5/20)的英文名: Taurus 双子座 (5/21 - 6/21)的英文名: Gemini 巨蟹座 (6/22 - 7/22)的英文名: Cancer 狮子座 (7/23 - 8/22)的英文名: Leo 处女座/室女座 (8/23 - 9/22)的英文名: Virgo 天秤座 (9/2
十二星座的具体顺序是:白羊座(Aries).金牛座(Taurus).双子座(Gemini).巨蟹座(Cancer).狮子座(Leo).处女座(Virgo).天秤座(Libra).天蝎座(Scorpio ...
随机推荐
- redis cluster + sentinel详细过程和错误处理三主三备三哨兵
redis cluster + sentinel详细过程和错误处理三主三备三哨兵1.基本架构192.168.70.215 7001 Master + sentinel 27001192.168.70. ...
- 当心Azure跨区域数据传输产生额外费用
最近同事发现Azure上一台虚拟机的费用环比增加了一部分.后面仔细检查发现费用来自数据传输, 因为这是早期部署的一台Azure虚拟机(Iaas),我们在本地生成备份,然后通过AzCopy到存储账号的B ...
- Linux 用户及权限详解
Linux 用户及权限详解 用户 , 组 ,权限 安全上下文(secure context): 权限: r,w,x 文件: r : 可读,可以使用类似cat 等命令查看文件内容. w : 可写,可以编 ...
- 关于加载font-awesome文字显示不出来
关于font-awesome的网站 中文网:http://www.fontawesome.com.cn/get-started/ 官网:https://fontawesome.com/ 中文网4.7: ...
- ambari2.6.50 openssl 版本问题:SSLError: Failed to connect. Please check openssl library versions. Openssl error upon host registration
I'm trying to register hostnames in Ambari but getting the error below. We tried to run yum update o ...
- 467. [leetcode] Unique Substrings in Wraparound String
467. Unique Substrings in Wraparound String Implement atoi to convert a string to an integer. Hint: ...
- Vue(day6)
一.webpack中常用的文件loader & 插件 由于版本存在变动,以下安装和配置都有可能发生变化,请以官方文档为准. 1.html-webpack-plugin插件 html-webpa ...
- IDEA:Maven项目找不到mapper文件 无法自动映射
如果你发现所有的功能都报找不到映射的错,有可能是因为mapper文件没有被编译 在eclipse中,把资源文件放在src下,是可以被编译的 但是在idea中,直接把资源文件放在src下,如果不进行设置 ...
- shell脚本获取进程ID并杀死的实现及问题解析
经常需要杀死某个进程,操作了几次之后,对一个熟练的码农来说,就要制作自己的工具了.有些工具虽然很小,但是却能节省一大部分的时间. 输入某个进程的ID并杀死的方法.这种事情,一般是先搜索再进行优化,这种 ...
- Linux篇---ftp服务器的搭建
一.前述 企业中linux搭建ftp服务器还是很实用的,所以本文针对centoos7和centoos6搭建服务器教程做个总结. 二.具体 1.显示如下图则表示已安装 vsftp软件.如果未显示则需要安 ...