博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
运维经验分享(六)-- 深究crontab不能正确执行Shell脚本的问题(二)
阅读量:5930 次
发布时间:2019-06-19

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

运维经验分享作为一个专题,目前共7篇文章

  1. 《》

  2. 《》

  3. 《》

  4. 《》

  5. 《》

  6. 《》

  7. 《》

====================================分割线======================================

先前在《》文章中提到Ubuntu下crontab因为默认Shell的原因可能导致crontab不能正确执行。本文章总结和列举一些更需要尤为注意的crontab书写规则。

注:以下规则适用于CentOS和Ubuntu等,是crontab通有的问题,需要特别注意。

  1. 环境变量问题。系统自带的环境变量将不能使用,或者能使用的非常少,因此写的脚本中有些明显使用系统环境变量的行就在crontab计划任务中执行失败,典型的就是java程序,因为java程序对JAVA_HOME和JRE_HOME这两个环境变量有很大的依赖。除了java程序,更典型的就是PATH变量,如果PATH变量不加声明的话,则Shell中需要命令将无法使用,因此在执行crontab计划任务时,最好是先声明PATH变量以及相关的变量,除了用export也可以用declare更可用KEY=VALUE的方式去声明,例子请参考文章结束的例子。

  2. 相对路径与绝对路径问题。crontab不支持相对路径,例如简单的“.”、“..”、“./”、“../”等,如果Shell脚本中有像“.”、“..”、cd、$(pwd)等这样的使用就需要特别注意,最好的解决办法就是在crontab中直接调用另一个Shell脚本,这个Shell脚本中首先指定好所要执行的Shell(如/bin/bash),设定好当前环境变量,再写想实际执行的Shell脚本,这样想在Shell脚本中怎样执行就能在crontab的计划任务中如何执行,不必再担心出现命令行中能执行成功,而在crontab中执行不成功的奇怪现象

  3. (补充上一篇文章的知识)crontab默认Shell问题。默认的crontab计划任务的shell是/bin/sh如果你想用bash去执行,则需要将Shell脚本的首行写好,使它能成功的调用bash以及属于bash专用的命令或语法。

示例:

crontab计划任务:

正确的写法:

1
*
/1 
* * * * 
/data/chatterserver-test/cron_chatter
.sh

或(更容易读到cron执行结果的日志,其实在/data/chatterserver-test/cron_chatter.sh中的最后一行加了日志的)

1
*
/1 
* * * * 
/data/chatterserver-test/cron_chatter
.sh >
/tmp/cron_chatter-test/
$(
date 
+\%Y\%m\%d\%H\%M\%S) 2>&1

错误的写法:

1
*
/1 
* * * * 
cd 
/data/chatterserver-test 
&& 
/bin/bash 
/data/chatterserver-test/chatter
.sh restart >
/tmp/cron_chatter-test/
$(
date 
+\%Y\%m\%d\%H\%M\%S) 2>&1

crontab调用脚本(/data/chatterserver-test/cron_chatter.sh):

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#!/bin/bash
declare 
-x CLASSPATH=
".:/usr/lib/jvm/jdk1.8.0_40/lib/dt.jar:/usr/lib/jvm/jdk1.8.0_40/lib/tools.jar:/usr/lib/jvm/jdk1.8.0_40/lib:/usr/lib/jvm/jdk1.8.0_40/jre/lib"
declare 
-x DISPLAY=
"localhost:11.0"
declare 
-x HOME=
"/home/vivo"
declare 
-x JAVA_HOME=
"/usr/lib/jvm/jdk1.8.0_40"
declare 
-x JRE_HOME=
"/usr/lib/jvm/jdk1.8.0_40/jre"
declare 
-x LANG=
"zh_CN.UTF-8"
declare 
-x LANGUAGE=
"zh_CN:zh:en_US:en"
declare 
-x LC_ALL=
"zh_CN.UTF-8"
declare 
-x LESSCLOSE=
"/usr/bin/lesspipe %s %s"
declare 
-x LESSOPEN=
"| /usr/bin/lesspipe %s"
declare 
-x LOGNAME=
"vivo"
declare 
-x LS_COLORS=
"rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.lz=01;31:*.xz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.webm=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.axv=01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=00;36:*.au=00;36:*.flac=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.axa=00;36:*.oga=00;36:*.spx=00;36:*.xspf=00;36:"
declare 
-x MAIL=
"/var/mail/vivo"
declare 
-x MAVEN_HOME=
"/usr/local/maven/apache-maven-3.2.5"
declare 
-x OLDPWD=
"/home/vivo"
declare 
-x PATH=
"/usr/lib/jvm/jdk1.8.0_40/bin:/usr/local/maven/apache-maven-3.2.5/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games"
declare 
-x PWD=
"/data/chatterserver-test"
declare 
-x SHELL=
"/bin/bash"
declare 
-x SHLVL=
"1"
# declare -x SSH_CLIENT="58.56.178.146 56404 12322"
# declare -x SSH_CONNECTION="58.56.178.146 56404 58.67.204.13 12322"
# declare -x SSH_TTY="/dev/pts/5"
declare 
-x TERM=
"xterm"
declare 
-x USER=
"vivo"
declare 
-x XDG_RUNTIME_DIR=
"/run/user/1000"
declare 
-x XDG_SESSION_ID=
"380"
cd 
/data/chatter-test/bin 
&& 
/bin/bash 
/data/chatter-test/bin/chatter
.sh restart >
/tmp/cron_chatter-test/
$(
date 
+\%Y\%m\%d\%H\%M\%S) 2>&1

--end--

====================================分割线======================================

运维经验分享作为一个专题,目前共7篇文章

  1. 《》

  2. 《》

  3. 《》

  4. 《》

  5. 《》

  6. 《》

  7. 《》

本文转自 urey_pp 51CTO博客,原文链接:http://blog.51cto.com/dgd2010/1677211,如需转载请自行联系原作者
你可能感兴趣的文章
Android内存测试方法梳理和实现原理简析
查看>>
一分钟实现Android遮罩引导视图
查看>>
使用 fastlane 实现自动化打包
查看>>
(五)神经网络入门之构建多层网络
查看>>
分析WordPress中esc_sql函数引起的注入危害
查看>>
第二届网易前端技术大会-启航
查看>>
基于Vert.x和RxJava 2构建通用的爬虫框架
查看>>
bootstrap基本布局
查看>>
老牌语言依然强势,GO、Kotlin 等新语言为何不能破局?
查看>>
RxJava2系列之相较RxJava1的更新之处(二)
查看>>
JavaEE进阶知识学习-----SpringCloud(九)Zuul路由网关
查看>>
浏览器是多进程
查看>>
安全令牌JWT
查看>>
Redux框架之applyMiddleware()讲解
查看>>
“寒冬”下的金三银四跳槽季来了,帮你客观分析一下局面
查看>>
基于RxJava2+Retrofit2实现简单易用的网络请求框架
查看>>
iOS自定义对象的读写怎么保证线程安全问题
查看>>
PHPExcel(更新中)
查看>>
Android不透明度对应的16进制值
查看>>
AppDelegate解耦
查看>>