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

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

直接上脚本

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

bash 复制代码
[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 是一个单元的集合,它定义了一组单元的依赖关系。

然后执行下面命令

bash 复制代码
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

bash 复制代码
nc -zv -w 2 192.168.2.102 3306

然后提示没有这个命令

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

bash 复制代码
yum install nc -y

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

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

bash 复制代码
#!/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

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

bash 复制代码
chmod 754 /usr/local/seata/bin/seata_start.sh

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

bash 复制代码
[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每次就能在服务器重启的时候正常启动了

相关推荐
GreatSQL20 小时前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
zzzzzz3102 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode2 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220703 天前
如何搭建本地yum源(上)
运维
A小辣椒4 天前
TShark:Wireshark CLI 功能
linux
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二4 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
A小辣椒4 天前
TShark:基础知识
linux
AlfredZhao4 天前
OCI 明明分配了 200G 系统盘,为什么 df 只看到 30G?
linux·oci
小猿姐4 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops