Elasticsearch 自动重启脚本创建实现

 更新时间:2023年08月09日 11:13:37   作者:志哥  
这篇文章主要为大家介绍了Elasticsearch 自动重启脚本创建实现详解分析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

产品需求

应产品要求,让写个es的自动重启的脚本,如果es挂了,要在分分钟之内重启,当时我的内心是崩溃的,像我这种Linux只会cd、 ls 的哪会写什么脚本啊,无奈,只能去谷歌了,边看边改,没想到还真给写出来了,貌似还不难,是不是有什么漏洞我就母鸡了。

es自动重启,首先要知道es是怎么启的,下载,配置,启动,这里就略过了。直接看脚本吧。

创建脚本

首先创建个sh文件,es_monitor.sh,内容很简单,判断es进程是否存在,存在就算了,不存在就重启。

#!/bin/bash
cd `dirname $0`
BIN_DIR=`pwd`
# jdk路径,这里有个坑,下文会讲
export JAVA_HOME=/home/pangu/soft/jdk1.8.0_111
# 获取es进程ID,我的es目录是/home/pangu/app/elastic/elasticsearch-master
ES_ID=`ps -ef |grep elasticsearch |grep -w 'elasticsearch-master'|grep -v 'grep'|awk '{print $2}'`
#启动脚本目录
StartES=/home/pangu/app/elastic/elasticsearch-master/bin/elasticsearch
# 日志输出
ESMonitorLog=$BIN_DIR/es-master-monitor.log
Monitor()
{
  if [[ $ES_ID ]];then # 这里判断ES进程是否存在
    echo "[info]当前ES进程ID为:$ES_ID"
  else
    echo "[error]ES进程不存在!ES开始自动重启..."
    sh $StartES -d
  fi
}
Monitor>>$ESMonitorLog

crontab 定时任务

crond 是 Linux 下用来周期性的执行某种任务或等待处理某些事件的一个守护进程。

当前用户(pangu)下crontab -e,把下面这个放进去,保存,路径是自己脚本的路径,一分钟检测一次。ps: es默认不能用root启动,这里所说用户都是pangu。

*/1 * * * * /bin/sh /home/pangu/app/elastic/es-monitor/es_monitor.sh

遇到的问题

过程中遇到了一个问题,./bin/elasticsearch -d直接启动es是可以的 ,直接运行es_monitor.sh 也是可以的,如果es进程被杀死,是会启动的,但是用crontab怎么都不行,一直报 JAVA_HOME 找不到的问题。

Could not find any executable java binary. Please install java in your PATH or set JAVA_HOME

而 pangu 用户的.bash_profile里面是配的有 Java环境变量的啊,想不通就去求助Linux大神旭哥了,旭哥看到后,表示很无语,骂了一句傻逼,说这都是最基础的东西。原来我配置在 pangu 用户下的.bash_profile Java环境变量在 cron 下是不生效的,去网上查了一下,发现好多人都被这个环境变量的问题坑过,crontab会以用户的身份执行配置的命令,但是不会加载用户的环境变量。这个可以用交互、非交互shell来解释,.bash_profile是交互的,以login的方式进入bash运行的。

什么是交互式模式呢?就是shell等待你的输入,并且立即执行你提交的命令。这种模式被称作交互式是因为shell与用户进行交互。这种模式也是大多数用户非常熟悉的:登录、执行一些命令、签退。当你签退后,shell也终止了。而非交互式模式,是以shell script(非交互)方式执行的,在这种模式下,shell不与你进行交互,而是读取存放在文件中的命令,并且执行它们,当它读到文件的结尾,shell也就终止了。可见我们的crontab是非交互的模式。这样就懂了吧,看来要好好学学Linux了,噗噗噗。

以上就是Elasticsearch 自动重启脚本实现的详细内容,更多关于Elasticsearch 重启脚本的资料请关注脚本之家其它相关文章!

相关文章

  • Java与MySQL导致的时间不一致问题分析

    Java与MySQL导致的时间不一致问题分析

    在使用MySQL的过程中,你可能会遇到时区相关问题,本文主要介绍了Java与MySQL导致的时间不一致问题分析,具有一定的参考价值,感兴趣的可以了解一下
    2024-07-07
  • Java中的集合工具类Collections详解

    Java中的集合工具类Collections详解

    这篇文章主要介绍了Java中的集合工具类Collections详解,java.utils.Collections是集合工具类,用来对集合进行操作,不是Collection集合的根接口,这个要区分开来,需要的朋友可以参考下
    2024-01-01
  • Java 多线程并发LockSupport

    Java 多线程并发LockSupport

    这篇文章主要介绍了Java 多线程并发LockSupport,LockSupport 类是用于创建锁和其他同步类的基本线程阻塞原语,更多相关内容需要得小伙伴可以参考一下下面文章内容
    2022-06-06
  • JAVA 根据设置的概率生成随机数的方法

    JAVA 根据设置的概率生成随机数的方法

    本篇文章主要介绍了JAVA 根据设置的概率生成随机数的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • mybatisplus报错:Invalid bound statement(not found)问题及解决

    mybatisplus报错:Invalid bound statement(not fou

    文章主要介绍了在使用MyBatis-Plus时遇到的`Invalid bound statement (not found)`错误的几种常见原因和解决方法,包括namespace路径不一致、函数名或标签id不一致、构建未成功、扫包配置错误以及配置文件书写错误
    2025-02-02
  • spring boot 使用 @Scheduled 注解和 TaskScheduler 接口实现定时任务

    spring boot 使用 @Scheduled 注解和 TaskScheduler 接口实现定时任务

    这篇文章主要介绍了spring boot 使用 @Scheduled 注解和 TaskScheduler 接口实现定时任务,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • Java基础之如何学好Java

    Java基础之如何学好Java

    这篇文章已经是有数年“网龄”的老文,不过在今天看来仍然经典。如何学习java?本篇文章可以说也是面对编程初学者的一篇指导文章,其中对于如何学习Java的步骤的介绍,很多也适用于开发领域其他技能的学习。
    2014-10-10
  • 实例解决Java异常之OutOfMemoryError的问题

    实例解决Java异常之OutOfMemoryError的问题

    在本篇文章中,我们给大家分享了关于解决Java异常之OutOfMemoryError的问题的方法,有此需要的朋友们学习下。
    2019-02-02
  • SpringCloud Alibaba使用Seata处理分布式事务的技巧

    SpringCloud Alibaba使用Seata处理分布式事务的技巧

    在传统的单体项目中,我们使用@Transactional注解就能实现基本的ACID事务了,随着微服务架构的引入,需要对数据库进行分库分表,每个服务拥有自己的数据库,这样传统的事务就不起作用了,那么我们如何保证多个服务中数据的一致性呢?跟随小编一起通过本文了解下吧
    2021-06-06
  • java中单双斜杠的使用图文详解

    java中单双斜杠的使用图文详解

    JAVA中的斜杠有正斜杠与反斜杠之分,正斜杠,一般就叫做斜杠,下面这篇文章主要给大家介绍了关于java中单双斜杠使用的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
    2022-09-09

最新评论