人大金仓服务器定时备份

适用于部署在docker容器中的人大金仓数据库

1.进入docker容器的人大金仓安装目录

查看docker容器,执行命令

java 复制代码
docker ps

进入docker容器中

java 复制代码
docker exec -it 210 /bin/bash

不知道kingbase安装目录的,执行命令搜索路径

java 复制代码
which kingbase

2.进入安装目录,创建备份文件所在位置

java 复制代码
cd /home/kingbase/install/kingbase/bin/

我这里是将备份文件放到bin文件夹下的sqlBack中,你们看情况调整

执行创建文件夹目录和脚本文件

java 复制代码
mkdir sqlBack
touch sqlBack.sh

复制脚本到sh文件中,自己调整对应的密码和数据库

powershell 复制代码
#!/bin/bash
export PGPASSWORD="123456"  # ← 关键:export拼写正确 + 等号无空格,更换密码
BACKUP_DIR="/home/kingbase/install/kingbase/bin/sqlBack" #更换备份路径
KEEP_DAYS=10 #更换保留天数
DB_LIST=("contract_zs") #更换备份数据库

mkdir -p "${BACKUP_DIR}"
DATE=$(date +"%Y%m%d_%H%M%S")
SUCCESS=0

for DB in "${DB_LIST[@]}"; do
  BACKUP_FILE="${BACKUP_DIR}/${DB}_${DATE}.dmp"
  echo "【$(date)】开始备份数据库 ${DB}..."
  
  /home/kingbase/install/kingbase/bin/sys_dump \
    -h localhost \
    -p 54321 \
    -U kingbase \
    -v \
    -f "${BACKUP_FILE}" \
    -F c \
    "${DB}"
  
  if [ $? -eq 0 ]; then
    echo "✅ ${DB} 备份成功:${BACKUP_FILE}"
    ((SUCCESS++))
  else
    echo "❌ ${DB} 备份失败!跳过..."
  fi
done

echo "🧹 清理超过 ${KEEP_DAYS} 天的备份..."
for DB in "${DB_LIST[@]}"; do
  find "${BACKUP_DIR}" -name "${DB}_*.dmp" -mtime +${KEEP_DAYS} -delete
done
echo "✅ 共成功备份 ${SUCCESS}/${#DB_LIST[@]} 个数据库,保留最近 ${KEEP_DAYS} 天备份"
exit $(( ${#DB_LIST[@]} - SUCCESS ))

拷贝进脚本文件中,手动执行是否可以正常备份文件

如果需要提供密码

先查看/home/kingbase/.encpwd文件,看文件中的信息是什么

powershell 复制代码
cat /home/kingbase/.encpwd

如果显示没有这个文件

则直接创建

powershell 复制代码
echo "*:54321:*:kingbase:$(echo -n '123456' | base64)" >> /home/kingbase/.encpwd

创建完在查看后显示上述信息,此时执行命令还需要输入密码的话,执行

powershell 复制代码
chown kingbase:kingbase /home/kingbase/.encpwd

此时再次执行脚本,无需输入密码


4.到这里说明脚本没有问题,此时需到宿主机执行定时命令

退出docker容器,执行exit

5.执行命令会打开定时文件,在文件中书写定时任务,退出保存,等待任务执行看是否完成备份

powershell 复制代码
 crontab -e

6.等待定时任务执行,看备份文件是否生成

正常成功sqlBack文件夹下会生成新文件

如果执行失败了,例如权限不够

执行命令

powershell 复制代码
# 1. 修复脚本权限 + 所有者(关键!)
docker exec -u root 210592c5084a chown kingbase:kingbase /home/kingbase/install/kingbase/bin/sqlBack.sh
docker exec -u root 210592c5084a chmod 755 /home/kingbase/install/kingbase/bin/sqlBack.sh

# 2. 修复 .encpwd 权限(消除 WARNING)
docker exec -u root 210592c5084a chmod 600 /home/kingbase/.encpwd
docker exec -u root 210592c5084a chown kingbase:kingbase /home/kingbase/.encpwd

执行脚本测试

powershell 复制代码
docker exec 210592c5084a /home/kingbase/install/kingbase/bin/sqlBack.sh

此时等待定时任务执行,看/var/log/kingbase_back.log日志显示

相关推荐
思麟呀8 分钟前
应用层自定义协议与序列化
linux·运维·服务器·网络·c++
Lost_in_the_woods17 分钟前
Java程序员的Linux之路——命令篇
linux·运维·服务器
IpdataCloud18 分钟前
在线IP查询API与本地离线库,速度与安全如何选型?
运维·服务器·网络
志栋智能19 分钟前
超自动化巡检,如何成为业务稳定的“压舱石”?
大数据·运维·网络·人工智能·自动化
困惑阿三23 分钟前
全栈服务器运维终极备忘录
运维·服务器·nginx·pm2
optimistic_chen31 分钟前
【Vue3入门】自定义指令与插槽详解
linux·运维·服务器·vue.js·前端框架·指令
牛奶咖啡1340 分钟前
基于Cobbler的系统自动化安装部署——Cobbler的安装部署实践
linux·运维·服务器·cobbler·cobbler的安装配置·cobbler环境检查问题解决·cobbler中导入系统镜像
mounter62543 分钟前
深度解析 RDMA 技术的里程碑:基于 DMA-BUF 的 P2P 直接访问(GPU Direct RDMA 新姿势)
linux·运维·服务器·网络·p2p·kernel
南山十一少1 小时前
docker的安装及使用
运维·docker·容器
Willliam_william1 小时前
CentOS 7系统中进行时间/时区设置
linux·运维·centos