Ubuntu中crontab中遇到的sh脚本一些问题


问题一:

问题描述:
在写一个脚本循环时候,出现“let:not found”,这是因为在ubuntu默认是指向bin/dash解释器的,dash是阉割版的bash,其功能远没有bash强大和丰富.并且dash不支持let和i++等功能.
解决办法:
打开一个终端输入:
sudo dpkg-reconfigure dash 选择 “否”, 表示用bash代替dash

问题二:

手动运行sh脚本可以,但是做定时任务总是无法执行。原因是crontab没有加载运行环境,导致sh脚本无法执行,所以在中间加入./etc/profile;,放到crontab -e的文本中,获取环境变量。

以下是crontab -e代码

SHELL = /bin/sh
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin


* * * * *  ./etc/profile; /bin/sh /home/hjj/cron.sh  

问题三:

Ubuntu默认是不打开crontab的日志文件的。
控制台输入

vim /etc/rsyslog.d/50-default.conf

Ubuntu中crontab中遇到的sh脚本一些问题

打开文件,在文件中找到cron.*,把前面的#去掉,保存退出,输入

sudo service rsyslog restart

重启系统日志,然后稍微等下应该就能在/var/log目录下看到cron.log,vi cron.log就可以查看cron运行日志了。

问题四:

/var/log/corn.log日志显示如下图:
Ubuntu中crontab中遇到的sh脚本一些问题
原因: cron把屏幕输出都发送到email,当前环境并未安装email server,于是系统报错。

sudo apt-get install -y postfix

# 选择并回车
Internet Site

# postfix继续安装,完毕后自动启动

安装成功后 (内容已经发送到/var/mail/root中)

原创文章,作者:306829225,如若转载,请注明出处:https://blog.ytso.com/267837.html

(0)
上一篇 2022年6月19日
下一篇 2022年6月19日

相关推荐

发表回复

登录后才能评论