当前位置: 首页 > article >正文

Linux环境配置Seata开机自启脚本(在MySQL和Nacos启动后启动)

之前给seata配置了一个开机启动脚本,但是经常出现启动失败,查询日志要么MySQL没有连接上要么nacos连接不上,原因都是因为服务器重启的时候这两个服务都还没有完全启动,所以正常的做法应该是启动前先等前置服务启动好了再启动seata

直接上脚本
将脚本放在/lib/systemd/system目录下,名字就叫seata.service

[Unit]

Description=seata
After=mysql.service nacos.service
Requires=mysql.service nacos.service

[Service]
Type=forking
ExecStart=/usr/local/seata/bin/seata-server.sh
PrivateTmp=true

[Install]
WantedBy=multi-user.target

After 定义启动顺序
Requires 表示指定的服务单元依赖于另一个服务单元,并且在启动或停止时,systemd将确保所依赖的单元也被启动或停止。
Type=forking 是 systemd单元文件中的一个配置项,用于指定服务的启动方式。具体来说,它告诉 systemd 这个服务的主进程是一个 fork 出来的子进程。
WantedBy=default.target 是 systemd 单元文件中的一个配置项,用于指定服务单元关联到哪个 target。在 systemd 中,target 是一个单元的集合,它定义了一组单元的依赖关系。

然后执行下面命令

chmod 754 /lib/systemd/system/seata.service
systemctl daemon-reload
systemctl enable seata.service
systemctl status seata.service

注意,很多时候脚本没有正常启动都可以用systemctl status seata.service查看状态
比如下面这个就是脚本权限不够

在这里插入图片描述

还有一个问题就是有些时候我们MySQL服务和seata服务不在一个服务器上,After只能指定当前服务器上的服务,这个时候我们就需要用到远程服务检测了
首先我们需要检测一下有没有nc这个命令
192.168.2.102 3306是我另一台服务器上面的MySQL

nc -zv -w 2 192.168.2.102 3306

然后提示没有这个命令

在这里插入图片描述

我们安装一下这个命令工具

yum install nc -y

再去执行 nc -zv -w 2 192.168.2.102 3306

在这里插入图片描述

接下来在/usr/local/seata/bin新建一个脚本seata_start.sh

#!/bin/bash

# 远程 MySQL 服务器的相关信息
REMOTE_MYSQL_HOST="192.168.2.102"
REMOTE_MYSQL_PORT="3306"

# 等待远程 MySQL 服务就绪的函数
wait_for_mysql() {
    until nc -zv -w 2 $REMOTE_MYSQL_HOST $REMOTE_MYSQL_PORT; do
        echo "Waiting for MySQL to start..."
        sleep 2
    done
    echo "MySQL is ready!"
}

# 调用等待函数
wait_for_mysql

# 在这里添加需要在开机时执行的其他命令或脚本
# 例如,启动你的应用程序或其他服务
/usr/local/seata/bin/seata-server.sh

赋予一下权限防止执行不了

chmod 754 /usr/local/seata/bin/seata_start.sh

然后再改一下开机启动脚本(/lib/systemd/system/seata.service),将里面的路径换成我们刚才建的那个启动脚本

[Unit]

Description=seata
After=mysql.service nacos.service
Requires=mysql.service nacos.service

[Service]
Type=forking
ExecStart=/usr/local/seata/bin/seata_start.sh
PrivateTmp=true

[Install]
WantedBy=multi-user.target

这样seata每次就能在服务器重启的时候正常启动了


http://www.kler.cn/a/152076.html

相关文章:

  • mysql中删除数据后,新增数据时id会跳跃,主键自增id不连续
  • 代码随想录算法训练营第三十八天| 509 斐波那契数 70 爬楼梯 746 使用最小花费爬楼梯
  • Windows10中在Visual Studio2017中VC++项目安装使用GoogleTest库
  • 什么是数据分析
  • Python的正则表达式使用
  • 触底加载上拉刷新
  • CentOS 7安装Java 8
  • Linux 系统渗透提权-Server2204
  • flink消费kafka限制消费速率
  • 【ARM CoreLink 系列 8.1 -- SMMU 详细介绍-STE Entry 详细介绍 1】
  • 通用plantuml模板头
  • Spring三级缓存处理循环依赖的过程
  • 10.30 作业 C++
  • 【NGINX--10】高可用性部署模式
  • 万户ezOFFICE wpsservlet任意文件上传漏洞复现
  • centos7配置tomcat
  • 阅读文献总结2023
  • CTA-GAN:基于生成对抗性网络的主动脉和颈动脉非集中CT血管造影 CT到增强CT的合成技术
  • MySQL 大表设计
  • Echarts 柱状图添加标记 最大值 最小值 平均值