运维经验分享(六)-- 深究crontab不能正确执行Shell脚本的问题(二)

简介:

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

  1. 运维经验分享(一)-- Linux Shell之ChatterServer服务控制脚本

  2. 运维经验分享(二)-- Linux Shell之ChatterServer服务控制脚本二次优化

  3. 运维经验分享(三)-- 解决Ubuntu下crontab不能正确执行Shell脚本的问题(一)

  4. 运维经验分享(四)--关于 java进程管理的服务控制脚本编程思路分析

  5. 运维经验分享(五)-- 改进的java进程管理的服务控制脚本

  6. 运维经验分享(六)-- 深究crontab不能正确执行Shell脚本的问题(二)

  7. 运维经验分享(七)-- Linux Shell之ChatterServer服务控制脚本第三次优化

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

先前在《运维经验分享(三)-- 解决Ubuntu下crontab不能正确执行脚本的问题》文章中提到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. 运维经验分享(一)-- Linux Shell之ChatterServer服务控制脚本

  2. 运维经验分享(二)-- Linux Shell之ChatterServer服务控制脚本二次优化

  3. 运维经验分享(三)-- 解决Ubuntu下crontab不能正确执行Shell脚本的问题(一)

  4. 运维经验分享(四)--关于 java进程管理的服务控制脚本编程思路分析

  5. 运维经验分享(五)-- 改进的java进程管理的服务控制脚本

  6. 运维经验分享(六)-- 深究crontab不能正确执行Shell脚本的问题(二)

  7. 运维经验分享(七)-- Linux Shell之ChatterServer服务控制脚本第三次优化




本文转自 urey_pp 51CTO博客,原文链接:http://blog.51cto.com/dgd2010/1677211,如需转载请自行联系原作者

相关文章
|
14天前
|
关系型数据库 Shell 网络安全
定期备份数据库:基于 Shell 脚本的自动化方案
本篇文章分享一个简单的 Shell 脚本,用于定期备份 MySQL 数据库,并自动将备份传输到远程服务器,帮助防止数据丢失。
|
1月前
|
Shell Linux
【linux】Shell脚本中basename和dirname的详细用法教程
本文详细介绍了Linux Shell脚本中 `basename`和 `dirname`命令的用法,包括去除路径信息、去除后缀、批量处理文件名和路径等。同时,通过文件备份和日志文件分离的实践应用,展示了这两个命令在实际脚本中的应用场景。希望本文能帮助您更好地理解和应用 `basename`和 `dirname`命令,提高Shell脚本编写的效率和灵活性。
109 32
|
5月前
|
Shell
一个用于添加/删除定时任务的shell脚本
一个用于添加/删除定时任务的shell脚本
166 1
|
25天前
|
JavaScript Shell C#
多种脚本批量下载 Docker 镜像:Shell、PowerShell、Node.js 和 C#
本项目提供多种脚本(Shell、PowerShell、Node.js 和 C#)用于批量下载 Docker 镜像。配置文件 `docker-images.txt` 列出需要下载的镜像及其标签。各脚本首先检查 Docker 是否安装,接着读取配置文件并逐行处理,跳过空行和注释行,提取镜像名称和标签,调用 `docker pull` 命令下载镜像,并输出下载结果。使用时需创建配置文件并运行相应脚本。C# 版本需安装 .NET 8 runtime。
114 2
|
3月前
|
运维 Kubernetes Devops
自动化运维:从脚本到工具的演进之旅
在数字化浪潮中,自动化运维成为提升效率、保障系统稳定的关键。本文将探索自动化运维的发展脉络,从基础的Shell脚本编写到复杂的自动化工具应用,揭示这一技术变革如何重塑IT运维领域。我们将通过实际案例,展示自动化运维在简化工作流程、提高响应速度和降低人为错误中的重要作用。无论你是初学者还是资深专家,这篇文章都将为你提供宝贵的洞见和实用的技巧。
|
4月前
|
运维 Devops
自动化运维:从脚本到DevOps的进化之旅
在数字化时代,自动化运维不仅是提高生产效率的关键,更是企业竞争力的象征。本文将带领读者穿越自动化运维的发展历程,从最初的脚本编写到现代DevOps文化的形成,揭示这一演变如何重塑IT行业的工作模式。通过具体案例,我们将展示自动化工具和实践如何简化复杂任务,优化流程,并促进团队协作。你将发现,自动化运维不仅关乎技术的进步,更体现了人、流程和技术三者之间协同增效的深层逻辑。
|
4月前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
132 2
6种方法打造出色的Shell脚本
|
4月前
|
机器学习/深度学习 人工智能 运维
自动化运维之路:从脚本到工具的演进
在IT运维领域,效率和准确性是衡量工作成效的关键指标。随着技术的发展,自动化运维逐渐成为提升这两个指标的重要手段。本文将带领读者了解自动化运维的演变历程,从最初的简单脚本编写到现今复杂的自动化工具应用,展示如何通过技术提升运维效率。文章不仅介绍理论和实践案例,还提供了代码示例,帮助读者理解自动化运维的实际应用场景。
|
4月前
|
运维 监控 网络安全
自动化运维的崛起:如何利用Python脚本简化日常任务
【10月更文挑战第43天】在数字化时代的浪潮中,运维工作已从繁琐的手工操作转变为高效的自动化流程。本文将引导您了解如何运用Python编写脚本,以实现日常运维任务的自动化,从而提升工作效率和准确性。我们将通过一个实际案例,展示如何使用Python来自动部署应用、监控服务器状态并生成报告。文章不仅适合运维新手入门,也能为有经验的运维工程师提供新的视角和灵感。
|
4月前
|
XML JSON 监控
Shell脚本要点和难点以及具体应用和优缺点介绍
Shell脚本在系统管理和自动化任务中扮演着重要角色。尽管存在调试困难、可读性差等问题,但其简洁高效、易于学习和强大的功能使其在许多场景中不可或缺。通过掌握Shell脚本的基本语法、常用命令和函数,并了解其优缺点,开发者可以编写出高效的脚本来完成各种任务,提高工作效率。希望本文能为您在Shell脚本编写和应用中提供有价值的参考和指导。
189 1