热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[linux]crontab命令执行问题

在服务器上设置了一个R脚本的crontab任务,死活不执行。在网上搜了很久,终于解决了。这里主要说一下crontab异常时,该如何排查。假设cron命令为:****Rscriptyour_

在服务器上设置了一个R脚本的crontab任务,死活不执行。在网上搜了很久,终于解决了。

这里主要说一下crontab异常时,该如何排查。

假设cron命令为:* * * * Rscript /your_path/hello_world.r >> /your_path/hello_world.log

1.首先检查cron命令是否完全正确。

虽然很简单,但是我还是在这吃了不少苦。

具体症状主要表现为cron不执行,并且crontab执行日志下找不到执行记录。

contab的执行日志在/var/log/cron.log中(Ubunutu),vi之后使用nG跳到最后一行,可以看到最新的执行记录。

如果没有看到cron命令,则很可能是命令或者命令路径不正确。仔细检查一下。

注:No MTA installed, discarding output 这个信息,讲道理与执行脚本与否无关。可以不必理会。

(crontab执行脚本时是不会直接错误的信息输出,而是会以邮件的形式发送到你的邮箱里,这时候就需要邮件服务器了,如果你没有安装邮件服务器,它就会报这个错)

2.crontab环境配置问题

如果手动在shell中可以执行,但是在crontab中无法执行时,就应该考虑这个问题了。

这个时候在cron日志中可以看到cron命令的执行记录,但是脚本就是死活不执行。hello_world.log下什么信息都没有。

搜到很多内容,说是环境配置的问题(确实也应该是环境配置的问题)。简单的说就是crontab执行时的环境和我们自己在shell中执行时的环境是不一致的。

更详细的内容可以参考这里:http://blog.csdn.net/zc02051126/article/details/20480289

虽然链接里说了很多解决方案,但是我并不知道他在说什么,呵呵。

我直接指定了命令的绝对路径,将cron命令改为:* * * * /usr/local/bin/Rscript /your_path/hello_world.r >> /your_path/hello_world.log

再次编辑crontab,终于在hello_world.log中找到了输出信息。

 

* 绝对路径根据自己安装程序位置的不同而不同。常见的有/usr/bin,/usr/local/bin等。如果不确定,就自己去路径下ls看是否存在相应程序。

* 网上很多说在脚本中首行加上环境路径(如#!/usr/bin/env Rscripit)。但是我没成功,不知道为什么。 

3.脚本路径的问题

  问题为手动运行脚本正常, 但是通过crontab自动运行则不成功。查看crontab的log发现在指定时间运行了任务,只是看不到结果。

  刚开始以为是权限或者环境的问题,但细想又想不通。

  事实上当crontab的log显示cron任务执行,但没有结果输出的时候,应该开始怀疑本身脚本的问题了。

  以我的例子来说,debug之后发现是脚本含文件路径,并且使用的相对路径。因为crontab环境和手动运行脚本时的环境不同,导致文件路径无效,进而脚本无效,于是crontab没有结果。将脚本中的相对路径改成绝对路径之后,crontab的结果就正常了。

 

Crontab命令指南,可以参考:http://www.cnblogs.com/peida/archive/2013/01/08/2850483.html  虽然我依然没看懂,呵呵。


推荐阅读
  • Tomcat安装与配置教程及常见问题解决方法
    本文介绍了Tomcat的安装与配置教程,包括jdk版本的选择、域名解析、war文件的部署和访问、常见问题的解决方法等。其中涉及到的问题包括403问题、数据库连接问题、1130错误、2003错误、Java Runtime版本不兼容问题以及502错误等。最后还提到了项目的前后端连接代码的配置。通过本文的指导,读者可以顺利完成Tomcat的安装与配置,并解决常见的问题。 ... [详细]
  • 用.sh文件来完成任务,但现在有个项目直接用url就行。一般系统不会有crontabShell#安装crontab:yuminstallcronta ... [详细]
  • 前言crontab是Unix和Linux用于设置周期性被执行的指令,是互联网很常用的技术,很多任务都会设置在crontab循环执行,如果不使用crontab,那么任务就是常驻程序,这对你的程序要求比较 ... [详细]
  •   crontab命令用于设置周期性被执行的指令,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • 如何去除Win7快捷方式的箭头
    本文介绍了如何去除Win7快捷方式的箭头的方法,通过生成一个透明的ico图标并将其命名为Empty.ico,将图标复制到windows目录下,并导入注册表,即可去除箭头。这样做可以改善默认快捷方式的外观,提升桌面整洁度。 ... [详细]
  • Windows下配置PHP5.6的方法及注意事项
    本文介绍了在Windows系统下配置PHP5.6的步骤及注意事项,包括下载PHP5.6、解压并配置IIS、添加模块映射、测试等。同时提供了一些常见问题的解决方法,如下载缺失的msvcr110.dll文件等。通过本文的指导,读者可以轻松地在Windows系统下配置PHP5.6,并解决一些常见的配置问题。 ... [详细]
  • 本文介绍了在Linux下安装Perl的步骤,并提供了一个简单的Perl程序示例。同时,还展示了运行该程序的结果。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 本文介绍了在Windows环境下如何配置php+apache环境,包括下载php7和apache2.4、安装vc2015运行时环境、启动php7和apache2.4等步骤。希望对需要搭建php7环境的读者有一定的参考价值。摘要长度为169字。 ... [详细]
  • 本文介绍了在mac环境下使用nginx配置nodejs代理服务器的步骤,包括安装nginx、创建目录和文件、配置代理的域名和日志记录等。 ... [详细]
  • mac php错误日志配置方法及错误级别修改
    本文介绍了在mac环境下配置php错误日志的方法,包括修改php.ini文件和httpd.conf文件的操作步骤。同时还介绍了如何修改错误级别,以及相应的错误级别参考链接。 ... [详细]
  • 解决Sharepoint 2013运行状况分析出现的“一个或多个服务器未响应”问题的方法
    本文介绍了解决Sharepoint 2013运行状况分析中出现的“一个或多个服务器未响应”问题的方法。对于有高要求的客户来说,系统检测问题的存在是不可接受的。文章详细描述了解决该问题的步骤,包括删除服务器、处理分布式缓存留下的记录以及使用代码等方法。同时还提供了相关关键词和错误提示信息,以帮助读者更好地理解和解决该问题。 ... [详细]
  • 安装oracle软件1创建用户组、用户和目录bjdb节点下:[rootnode1]#groupadd-g200oinstall[rootnode1]#groupad ... [详细]
  • 【场景】:需要定期运行Hadoop的MapReduce【解决办法】:编写一个运行MapReduce的Shell脚本。然后使用crontab配置定时任务。【Shell脚本】 ... [详细]
author-avatar
皆靖所能
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有