自动重连MariaDB服务的Shell脚本

要实现这个功能,你可以使用一个循环来不断尝试连接MariaDB服务,直到成功为止。以下是修改后的Shell脚本代码,它将每隔5秒尝试一次,直到MariaDB服务可用:
#!/bin/bash

IP="your-ip"
PORT="3306"
USER="your-username"
PASSWORD="your-password"
DATABASE="your-database-name"
TABLE="your-table-name"

# 定义最大尝试次数,避免无限循环
MAX_ATTEMPTS=12  # 例如,尝试6次,每次5秒

attempt_counter=0
while [ $attempt_counter -lt $MAX_ATTEMPTS ]; do
  echo "Attempting to connect to the MariaDB container (Attempt $(($attempt_counter + 1)) of $MAX_ATTEMPTS)..."

  # 尝试连接到MariaDB容器并执行ping
  if docker exec mariadb-server mysqladmin -u $USER -p$PASSWORD ping --silent; then
    echo "MariaDB service is running and responding to ping."
    echo "Attempting to update data in the MariaDB container..."
    # 尝试更新数据
    UPDATE_STATUS=$(docker exec mariadb-server mysql -h $IP -P $PORT -u $USER -p$PASSWORD $DATABASE -e "USE $DATABASE; UPDATE $TABLE SET column_name='new_value' WHERE condition;" 2>&1)
    if [ $? -eq 0 ]; then
      echo "Data updated successfully."
      exit 0
    else
      echo "Failed to update data: $UPDATE_STATUS"
      exit 1
    fi
  else
    echo "MariaDB service is not running or not responding to ping. Retrying in 5 seconds..."
    sleep 5
    ((attempt_counter++))
  fi
done

echo "MariaDB service is still not available after $MAX_ATTEMPTS attempts. Exiting."
exit 1
这段脚本首先定义了最大尝试次数,然后使用一个while循环来不断尝试连接MariaDB服务。如果连接失败,它会等待5秒后再次尝试,直到达到最大尝试次数。如果服务可用,它会尝试更新数据,如果更新成功则退出脚本,如果更新失败也会退出脚本并打印错误信息。如果服务在最大尝试次数之后仍然不可用,脚本会打印一条消息并退出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值