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