目录准备工作编写shell文件在linux添加定时任务crontab格式介绍准备工作 一台Linux(Centos7为例)服务器。安装Docker服务。安装并启动sqlServer容
给出一个备份的范例
#!/bin/bash
#设置mssql备份目录
folder=/var/opt/mssql/data/databack/
day=`date +%Y%m%d%H%M%S`
#数据库服务器,一般为localhost
host=localhost
#用户名
user=sa
#密码
passWord='********'
# 容器名称
containerId='sqlserver'
# 循环获取数据库名称
for line in $(docker exec $containerId /opt/mssql-tools/bin/sqlcmd \
-S $host -U $user -P $password \
-Q "select [name] from master.dbo.SysDatabases where [dbid] > 4")
do
# 判断是否是数据库名称
if [[ $line =~ ^[a-zA-Z0-9_]+$ && $line != 'name' && $line != 'rows' ]]; then
echo "数据库 $line 开始备份"
docker exec $containerId /opt/mssql-tools/bin/sqlcmd \
-S $host -U $user -P $password \
-Q "BACKUP DATABASE [$line] TO DISK = N'$folder$line/$line$day.bak' WITH NOFORMAT, NOINIT, NAME = N'$line Backup $day', SKIP, NOREWIND, NOUNLOAD, STATS = 10"
fi
done
添加定时任务需要使用到Linux的crontab服务。我们可以通过下列命令来检测并安装这个服务。
# 检查crontab工具是否安装
crontab -l
# 检查crond服务是否启动
service crond status
# 如果未安装服务我们需要进行安装
yum install vixie-cron
yum install crontabs
再确认安装完成后我们使用命令 crontab -e
打开crontab的编辑功能,添加如下示例:
# 定时任务 每日0点备份
# 注意别忘记 sh 命令
0 0 * * * sh /root/databack/sqlServerBackup.sh
添加完成后可以使用命令(systemctl restart crond
),重启下crond服务确保服务能正常运行。
参考生成工具 https://tool.lu/crontab/
格式: * * * * * comand
(*以空格或tab隔开)
举例:
到此这篇关于Linux下定时自动备份Docker中所有SqlServer数据库 的文章就介绍到这了,更多相关Docker SqlServer定时自动备份内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Linux下定时自动备份Docker中所有SqlServer数据库的脚本
本文链接: https://www.lsjlt.com/news/168781.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0