技术标签: linux 如何加定时任务
一、业务需求:
将一个普通的java项目打包(此处是jar包),上传到linux服务器上面,要求通过定时器,每分钟去检测一次该服务是否一直再跑,如果进程不在,就重新启动该服务,如果进程还在,就不做处理。。。。
二、具体步骤以及需要注意的地方(本人查找过多人的博客,加
上亲身实践,得出以下相对靠谱点的解决问题的方式,如有不足
之处,希望大神可以指出):
1、写一个简单的可执行shell脚本;(主要是实现 :检测pid 、程序的start 、 stop 、restart、status 。。。。如有需要,可留言)
2、以下就是linux系统添加定时任务:
a.通过 crontab -l 指令 先查看一下已有哪些定时任务(任意路径下都可以);
b.然后可以通过 crontab -e指令 来添加定时任务;
比如每分钟执行一次脚本:
*/1 * * * * /usr/apache-tomcat-8.5.20/webapps/java_start.sh start > /usr/apache-tomcat-8.5.20/webapps/date.txt 2>&1 &
简单说明:
*/1 * * * * :表示每分钟执行一次 一共五位,从左到右依次是:分、时、日、月、年(很多定时器,时间设置规则都类似,具体可以参考后面注释)
/usr/apache-tomcat-8.5.20/webapps/java_start.sh start :需要执行的指令(此处就是执行java_start.sh这个脚本)
/usr/apache-tomcat-8.5.20/webapps/date.txt : 将输出写入到指定的date.txt文件之中
> :将每分钟执行的最新结果写入指定文件(不存在就创建,存在就是先清空再写入)
& :表示在后台启动
2>&1 :此处是将执行脚本过程中所有错误的信息也会合并,并且写到date.txt文件之中(其中&1更准确的说应该是文件描述符 1,而数字1一般代表的就是STDOUT_FILENO,实际上这个操作就是一个dup2(2)调用.它将标准输出,然后复制标准输出到文件描述符2(STDERR_FILENO),就是文件描述符1和2指向同一个文件表项,也可以说错误的输出被合并了.)
若果是 > /dev/null :表示就是把所有标准输出和标准出错都扔到垃圾桶里面。
c.将脚本和jar包放到指定目录;
d.操作中出现的问题:
1. date.txt 文件中记录:XXXXXXXXXXXXXXXXXXX 权限不够
解决方案:脚本放到指定路径之后,需要 付给它权限:chmod +7 XXXXXXX.sh
2. linux系统下,在脚本的目录下面 执行./XXXXXXX.sh start 可以启动项目 ,但是通过定时任务来启动服务时,date.txt文件中报 找不到jar包(Error: Unable to access jarfile xxxxx.jar)
解决方案:先看一下脚本中的项目jar包名称和实际的项目jar包名称是否一致(应该是一致的,不然一开始不会通过脚本启动服务成功),其实问题是因为在linux定时任务cron中,它需要再次指定jdk路径,(网上百度都在说是环境问题,其实不排除这种可能,但是我要部署的服务器上面还在跑其他的java项目),所以我这边的问题是路径问题,需要在脚本开头,添加一下/etc/profile里面的如下内容:
export JAVA_HOME=/usr/java/jdk1.8.0_151
export JRE_HOME=/usr/java/jdk1.8.0_151/jre
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib
export PATH=$PATH:$JAVA_HOME/bin
每个人的具体路径不同,可以通过 vim /etc/profile 找到自己的环境
3. 之前运行好好的脚本,编辑完之后,报错,还原成原来的样子(就是曾今运行成功过的)还是报错,错误信息如下:预期的符号`${\r`附近有语法错误
解决方案:是因为在Windows系统下面编辑,之后放到linux系统上面运行,格式有问题,,,你可以看一下notepad右下角的显示,鼠标点一下右键,转换为Unix格式,重新保存一份,再放到linux服务器上运行就没有问题啦························
3、补充说明:
A.任务调度设置文件的写法:
可用crontab -e命令来编辑,编辑的是/var/spool/cron下对应用户的cron文件,也可以直接修改/etc/crontab文件
具体格式如下:
Minute Hour Day Month Dayofweek command
分钟 小时 天 月 天每星期 命令
每个字段代表的含义如下:
Minute 每个小时的第几分钟执行该任务
Hour 每天的第几个小时执行该任务
Day 每月的第几天执行该任务
Month 每年的第几个月执行该任务
DayOfWeek 每周的第几天执行该任务
Command 指定要执行的程序
在这些字段里,除了“Command”是每次都必须指定的字段以外,其它字段皆为可选字段,可视需要决定。对于不指定的字段,要用“*”来填补其位置。
举例如下:
5 * * * * ll 指定每小时的第5分钟执行一次ll命令
30 5 * * * ll 指定每天的 5:30 执行ll命令
30 7 8 * * ll 指定每月8号的7:30分执行ll命令
30 5 8 6 * ll 指定每年的6月8日5:30执行ll命令
30 6 * * 0 ll 指定每星期日的6:30执行ll命令[注:0表示星期天,1表示星期1,
以此类推,也可以用英文来表示,sun表示星期天,mon表示星期一等。]
30 3 10,20 * * ll 每月10号及20号的3:30执行ll命令[注:“,”用来连接多个不连续的时段]
25 8-11 * * * ll 每天8-11点的第25分钟执行ll命令[注:“-”用来连接连续的时段]
*/15 * * * * ll 每15分钟执行一次ll命令 [即每个小时的第0 15 30 45 60分钟执行ls命令 ]
B.在linux和unix类型的系统中,shell脚本里面有重定向符号 ‘>’和‘>>’
> ,这个表示向文件重新添加内容,该文件首先被清空。
而 >> ,这个表示想文件追加内容,原来的内容不会被清理掉。
C.
新增调度任务
1.新增调度任务可用两种方法:
1)、在命令行输入: crontab -e 然后添加相应的任务,wq存盘退出。
2)、直接编辑/etc/crontab 文件,即vi /etc/crontab,添加相应的任务。
2.查看调度任务
crontab -l //列出当前的所有调度任务
crontab -l -u jp //列出用户jp的所有调度任务
3.删除任务调度工作
crontab -r //删除所有任务调度工作
文章浏览阅读1.1k次。原题如下:编写程序,要求用户录入一串整数(把这串整数存储在数组中),然后通过调用selection_sort函数来排列这些整数。在给定n个元素的数组后,election_sort函数必须做下列工作:搜索数组找出最大的元素,然后把它移到数组的最后面;递归的调用函数本身对前面的n-1个数组元素进行排序。下面是我自己写的程序:(运行结果不对,求大神指导!!!)#include #define N 8in..._c语音递归n从高到低排序
文章浏览阅读6.1k次,点赞5次,收藏12次。面临问题:很多时候数据量大了,特别是有几亿条数据的时候,可能你会发现,跑个搜索怎么一下 5~10s。第一次搜索的时候,是 5~10s,后面反而就快了,可能就几百毫秒。说实话,ES 性能优化是不可能随手调一个参数,就可以万能的应对所有的性能慢的场景。也许有的场景是你换个参数,或者调整一下语法,就可以搞定,但是绝对不是所有场景都可以这样。性能优化:Filesystem Cache你往 ES..._亿级数据模糊查询用什么数据库
文章浏览阅读6.8k次。本文继续记录多股回测时遇到的异常情况。坑描述backtrader在读取日线数据时,会自动给date数据添加“时:分:秒.毫秒(23:59:59.999990)”信息。而通常用户在指定回测周期的开始和结束日期时,只会精确到日,时分秒信息会被backtrader默认以0补全。由于上述两个事实的存在,假如用户指定回测周期的结束日期有日线数据(由于非交易日、停盘等原因,可能没有日线数据),那么在backtrader中,回测周期的结束时间就会被设定为该日的00:00:00,而backtrader读_indexerror: array assignment index out of range
文章浏览阅读1.9k次。本文转载自:https://www.cnblogs.com/mafuqiang/p/7161592.html乘积量化1。简介 乘积量化(PQ)算法是和VLAD算法是由法国INRIA实验室一同提出来的,为的是加快图像的检索速度,所以它是一种检索算法,在矢量量化(Vector Quantization,VQ)的基础上发展而来,虽然PQ不算是新算法,但是这种思想还是挺有用处的,本文没有添加公式。 它..._乘积量化检索
文章浏览阅读6.2k次,点赞8次,收藏39次。1. 基本概念1.1 熵熵原本是一个热力学概念,是用来描述热力学系统混乱(无序)程度的度量。在信息论建立之后,关于上的概念和理论得到了发展。作为衡量时间序列中新信息发生率的非线性动力学参数,熵在众多的科学领域得到了应用。八十年代最常用的熵的算法是K-S熵及由它发展来的E-R熵,但这两种熵的计算即使对于维数很低的混沌系统也需要上万点的数据,而且它们对于噪声很敏感,时间序列叠加了随机噪声后这两种熵的计算可能不收敛。1.2 近似熵近似熵(APEN, Aproximate Entropy),是由Pincus_样本熵电池代码
文章浏览阅读932次。BeanFactoryBeanFactory是IOC最基本的容器,负责生产和管理bean,它在为其他具体的IOC容器提供了最基本的规范,例如XmlBeanFactory、ApplicationContext等具体的挺起都实现了BeanFactory,再在其基础上附加了其他功能BeanFactory源码package org.springframework.beans.factory; ..._beanfactory与factorybean和applicationcontext的区别
文章浏览阅读280次。全文3000字,预计阅读时长:8分钟适用于从事ARM软硬件设计、开发、调试的工程师、教师以及学生对于大部分开发者来讲,ARM架构知识一直存放于盲盒之中,知之甚少;而ARM架构知识是ARM结构化知识中非常关键的一部分,它的缺失,会导致我们对于问题的系统化思考难以进行。所以增设了《ARM架构知多少-A系列》专栏来和大家一起学习ARM架构,完善知识结构,拓展系统思考边界。_hypervisor arm
文章浏览阅读1.1k次。硬件环境:ZYNQ7000软件环境:petalinux2018.2 xilinx_vivado_sdk2018.2学习例程:1、DMA初始化1)定义变量//定义ioctrl的命令#define AXI_ADC_IOCTL_BASE 'W'#define AXI_ADC_SET_SAMPLE_NUM _IO(AXI_ADC_IOCTL_BASE, 0)#define AXI_ADC_SET_DMA_LEN_..._adc数据长度为什么是1920
文章浏览阅读5.4k次,点赞3次,收藏9次。前言分布式系统的执行环境往往是异常复杂的,很多情况涉及到多节点间的消息通信。相比较于单节点系统而言,分布式系统在问题追踪,排查方面显然也复杂很多。那么这个时候,在分布式系统中,增加哪些类型的日志数据,来帮助我们发现和定位问题呢?答案就是我们今天将要阐述的审计日志(Audit log)。审计日志的概念很多人可能在想这样一个问题:同样是日志,审计日志和普通的日志,区别在于哪里呢?审计日志,..._审计日志定义
文章浏览阅读7k次,点赞19次,收藏54次。csdn上有很多关于conda的文章,但是一直没有一个宏观一些的文章,我将从宏观角度出发,对文章进行一个整合,解读,将新同学从conda环境入门到配置,应用全流程进行解读。当然,这篇文章因为是宏观一些,可能很多同学不能一次性看懂,没关系,这个可以反复看,在不同阶段都可以提供帮助。......_conda 环境
文章浏览阅读593次。一、Map概述1、Map是将键映射到值( key-value )的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。2、Map与Collection的区别(1)Map 是以键值对的方式存储元素,键唯一,值可以重复。(2)Collection存储的是单列元素,子接口Set元素唯一,子接口List可以重复。(3)Map的数据结构针对键有效,跟值无关..._treehash的遍历方法
文章浏览阅读704次。目录一、调度约束过程解析1.1、调度方式1.2、示例1 nodeName1.3、示例2 nodeSelector二、故障排除2.1、故障现象2.2、排查思路一、调度约束过程解析1、首先,用户可以通过kubectl命令或者dashborad、API调用的方式(用作开发)来创建资源,和管理资源(Kubernetes通过watch的机制进行每个组件的协作,每个组件之间的设计实现了解耦)2、用户提交创建资源的请求给API Server,API Server将创建资源的元信息(属性信息)写入到etcd中,et_pod崩溃一般怎么排查