我正在尝试将文件从一个文件夹复制到CensOS中同一系统上的另一个文件夹,并在cronjob中设置预定义的时间表。但是系统没有复制文件。
使用的CentOS版本详细信息如下所示。
CentOS release 6.7 (Final)
LSB_VERSION=base-4.0-amd64:base-4.0-noarch:core-4.0-amd64:core-4.0-noarch:graphics-4.0-amd64:graphics-4.0-noarch:printing-4.0-amd64:printing-4.0-noarch
CentOS release 6.7 (Final)
我在"脚本"中创建了一个shell脚本。我的主文件夹下的文件夹。 此文件夹添加在PATH环境变量中。 这是bash_profile的内容。
PATH=$PATH:$HOME/bin
export JAVA_HOME=/usr/java/default
export CATALINA_HOME=/var/lib/apache-tomcat
PATH=$JAVA_HOME/bin:$CATALINA_HOME/bin:~/scripts:$PATH
以下是~/scripts/archivelog.sh
#Script to archive jboss server logs after every 4 hours.
FILE_NAME=server$(date +%y-%m-%d_%H.%M)_log.zip
cd ~/jboss/jboss-eap-6.2/standalone/log/
zip $FILE_NAME server.log
echo "" > server.log
echo "LOG Compressed"
cp $FILE_NAME ~/logs/archives/
我已使用-rwxrwx---
设置了权限chmod 770 ~/scripts/archivelog.sh
该脚本设置为cron作业,每隔2小时运行一次,从周一到周六,从上午8点到晚上11点。
0 8-11/2 * * 1-6 ~/scripts/archivelog.sh
我在2小时后检查了结果,甚至我也通过手动运行来检查脚本,但没有复制文件。 经过调查,我检查了系统是否正在复制文件,但是将文件命名为?。
随着脚本的进一步更改,我看到了,如果我使用
cp $FILE_NAME ~/logs/archives/
然后将文件复制为~/logs/archives/?
如果我使用
cp $FILE_NAME ~/logs/archives
然后将文件复制为~/logs/archives?
如果我使用
cp $FILE_NAME ~/logs/archives/$FILE_NAME
然后将文件复制为~/logs/archives/$FILE_NAME?
请在这方面帮助我,相同的脚本在开发服务器上运行,但不在PRODUCTION Server上运行。
答案 0 :(得分:0)
有关cronjob计划的一件事,正如您所说,您希望在上午8点到晚上11点之间运行它,但当前设置显示它将在上午8点到晚上11点之间运行。您应该将设置更改为8-23,linux cron作业中的时间值为24小时格式。
使用以下设置。而不是~
在cronjob中使用绝对路径。
0 8-23/2 * * 1-6 [PATH]/scripts/archivelog.sh
关于文件复制问题,我怀疑你已经在windows环境中编写了脚本,然后将文件传输到linux,这就是脚本文件中有行结束控件/特殊字符的原因。
您可以使用cat -A
命令查看控制字符。 e.g
cat -A ~/scripts/archivelog.sh
它将显示如下输出:
FILE_NAME=server$(date +%y-%m-%d_%H.%M)_log.zip^M$
cd ~/jboss/jboss-eap-6.2/standalone/log/^M$
zip $FILE_NAME server.log^M$
echo "" > server.log^M$
echo "LOG Compressed"^M$
cp $FILE_NAME ~/logs/archives/^M$
如果您在任何Windows编辑器的Windows中打开该文件,例如Notepad ++并转动显示所有字符,它将显示带有 CRLF 的行结尾。
希望这是你的情况,我在上面已经解释过了。在这种情况下,您需要从shell脚本文件中删除\r
个字符。
您可以使用以下命令从文件中删除这些字符。
sed -i 's/\r$//' ~/scripts/archivelog.sh
如果您将看到文件内容,显示所有字符,请使用以下命令。
cat -A ~/scripts/archivelog.sh
它应该显示如下内容。
FILE_NAME=server$(date +%y-%m-%d_%H.%M)_log.zip$
cd ~/jboss/jboss-eap-6.2/standalone/log/$
zip $FILE_NAME server.log$
echo "" > server.log$
echo "LOG Compressed"$
cp $FILE_NAME ~/logs/archives/$
执行上面提到的sed命令后,希望你的脚本运行良好。 如果它仍然不起作用,请告诉我。