冷备份MySQL数据库并且使用Docker直接运行的操作过程
备份数据库
- 查看数据库的数据文件的位置
systemctl status mysqld查看启动进程以及防水
/etc/my.conf查看datadir指向Mysql数据库的存储数据路径. - 关闭数据库
systemctl stop mysqld - 备份数据库数据文件
mkdir /mysqlindocker && time scp -r /var/lib/mysql /mysqlindocker
scp /etc/my.cnf /mysqlindocker/
mkdir /mysqlindocker/log
mkdir /mysqlindocker/mysql-files
chown mysql:mysql /mysqlindocker/ -R && chmod 777 /mysqlindocker -R
chmod 644 /mysqlindocker/my.cnf
拉取mysql的镜像
- 从docker hub 拉取
docker pull mysql:8.0.25 - 可以从可以上网的机器上面备份好之后再执行导出和导出
docker save mysql:8.0.25 -o /mysql_docker_8025.tar - 复制到当前机器上面后执行导入操作
docker load -i /mysql_docker_8025.tar
使用命令拉起来mysql数据库
- 直接写命令
docker run --name mysql3307 -p 3307:3306 -v /mysqlindocker/mysql:/var/lib/mysql -v /mysqlindocker/mysql-files:/var/lib/mysql-files -v /mysqlindocker/my.cnf:/etc/my.cnf -v /mysqlindocker/log:/var/log -e MYSQL_ROOT_PASSWORD=Test20131127 -e TZ=Asia/Shanghai -d mysql:8.0.25
配置参数说明
- my.conf 的参数说明
[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
max_allowed_packet = 1G
innodb_log_file_size = 30M
innodb_log_buffer_size = 256M
innodb_buffer_pool_size=2G
innodb_file_per_table = 1
max_connections=2000
lower-case-table-names=1
innodb_strict_mode = 0
character_set_server=utf8
default-time-zone='+8:00'
transaction-isolation = READ-COMMITTED
default_authentication_plugin=mysql_native_password
binlog_expire_logs_seconds = 7200
[mysql]
default-character-set=utf8
prompt="\\u@\\h : \\d \\r:\\m:\\s>"
配置参数说明
- datadir 指代数据目录
- innodb 指代log文件以及内存占用大小,可以进行调整以适应不同的并发情况.
- max_connections 标明数据库能够提供的访问并发数量.
- lower-case-table-names 标明建库时数据库表名的大小写模式.
- innodb-strict-mode 标明可以避免部分异常SQL的异常提示, 造成环境安装和使用中断.
- utf8 使用了utf8mb3的字符集, 因为erp应用会使用较多的字段数,使用其他字符集可能导致单表的总字符长度数不够的问题.
- time-zone 标明时区
- read-committed 标明可重复读的模式.
- 标明mysql的密码格式.
- binlog_expire_logs_seconds 标明binlog的过期时间, 测试环境可以设置的比较小, 不然会占用较多的磁盘.
- 标明客户端的字符集.
- 标明mysql 登录时的提示信息,避免自己输入错误了.
Docker 命令说明
docker run 正常运行容器的命令
--name mysql3307 只对容器的名字,便于进行容器的启停查看log等.
-p 3307:3306 将端口expose 出来,需要注意的是 前面的是主机的端口, 后面的是容器内的端口
-v /mysqlindocker/mysql:/var/lib/mysql 这个定义的是 数据文件
-v /mysqlindocker/mysql-files:/var/lib/mysql-files 需要增加一个空文件 尽心初始化使用
-v /mysqlindocker/my.cnf:/etc/my.cnf 指定自己的配置文件到容器内部, 需要注意的是这个文件 需要 644的执行权限才可以
-v /mysqlindocker/log:/var/log 增加系统log目录
-e MYSQL_ROOT_PASSWORD=Test20131127 必须指定一个root密码,但是如果 -v 了存储目录 会使用内部的密码来代替这个密码
-e TZ=Asia/Shanghai 指定时区, 修改为东八区
-d mysql:8.0.25 指定镜像以及版本
冷备份MySQL数据库并且使用Docker直接运行的操作过程的更多相关文章
- Weka链接Mysql数据库
Weka简介 Weka的全名是怀卡托智能分析环境(Waikato Environment for Knowledge Analysis),是一款免费的,非商业化(与之对应的是SPSS公司商业数据挖掘产 ...
- Windows平台下搭建MySQL数据库
1.下载安装MySQL数据库: (1)->我的标签->软件下载->计算机相关专业所用软件---百度云链接下载->mysql-installer-community-5.7.18 ...
- MYSQL——数据库存储引擎!
本人安装mysql版本为:mysql Ver 14.14 Distrib 5.7.18, for Win64 (x86_64),查看mysql的版本号方式:cmd-->mysql --vers ...
- Linux下C++访问MySQL数据库
由于想要开始了解并学习用LAMP进行web开发,所以昨晚我在Fedora上安装了MySQL,学习了MySQL的几个常用命令.想着在学习进行web开发(PHP访问数据库)之前,先用我熟悉的C++连接数据 ...
- Docker 运行 MYSQL 数据库的总结
公司里面要求做一个小demo 学习java相关的东西 然后使用了mysql数据库 很早之前做过mysql的容器化运行. 现在想想已经忘记的差不多了 所以这里总结一下 docker化运行mysql数据 ...
- 使用docker容器运行MySQL数据库并持久化数据文件
1.下载mysql镜像 # docker pull mysql 2.启动mysql容器 # docker run -itd -v /data:/var/lib/mysql -p 33060:3306 ...
- Docker安装Mysql数据库容器(zz)
zz自:http://blog.csdn.net/chengxuyuanyonghu/article/details/54380032 1.下载mysql的镜像: sudo docker pull m ...
- 沉迷 Docker,无法自拔(在 Docker 中运行 MySQL)
记得之前做网站开发的时候,因为服务端用的 MySQL 数据库,为了方便调试以及隔离生产与开发环境,自己就在本地也安装了一个 MySQL 数据库.但是用着用着慢慢的也发现了一些不舒服的地方,比如常驻后台 ...
- Docker学习实践 - Docker安装MySql数据库
Docker安装MySQL数据库 1.Ubuntu安装MySQL安装 (1)安装编译源码需要的包 sudo apt-get install make cmake gcc g++ bison libnc ...
- Docker安装MySQL数据库
本文翻译自:MySQL Docker Containers:Understanding the basics 1.下载MySQL镜像 docker pull mysql:5.6 如此便可以下载最新的M ...
随机推荐
- 不同数据库模式下DATE类型的行为解析
摘要:本文章主要介绍了GaussDB(DWS)数据类型中的DATE类型在不同数据库模式下且在不同应用场景下的行为表现及对比. 本文分享自华为云社区<GaussDB(DWS)数据类型之DATE类型 ...
- 开心档之MySQL 导出数据
MySQL 导出数据 MySQL中你可以使用SELECT...INTO OUTFILE语句来简单的导出数据到文本文件上. 使用 SELECT ... INTO OUTFILE 语句导出数据 以下实例中 ...
- SBOM落地的关键一步——漏洞可利用性交流(VEX)
SolarWinds 网络安全事件的影响,加上 Log4j 漏洞对众多知名企业产生难以估量的后果,使软件供应链安全成为安全领域的热门话题,并且SBOM现在成为网络安全漏洞计划的一个重要组成部分. SB ...
- 打通数据治理全链路,火山引擎DataLeap数据治理平台公有云版本正式发布
更多技术交流.求职机会,欢迎关注字节跳动数据平台微信公众号,回复[1]进入官方交流群 近日,火山引擎DataLeap正式对外发布数据治理平台公有云版.DataLeap是火山引擎大数据研发治理套件, ...
- DamiBus v0.51 发布
DamiBus,专为本地多模块之间通讯解耦而设计(尤其是未知模块.隔离模块.领域模块).零依赖,特适合 DDD. 特点 结合 Bus 与 RPC 的概念,可作事件分发,可作接口调用,可作响应订阅. 支 ...
- 升讯威在线客服系统:与QQ、微信的区别和优势
本系列文章详细介绍使用 .net core 和 WPF 开发 升讯威在线客服与营销系统 的过程.本产品已经成熟稳定并投入商用. 请访问:https://kf.shengxunwei.com 文章目录列 ...
- 阿里云视频云人脸生成领域最新研究成果入选CVPR2022
CVPR(IEEE Conference on Computer Vision and Pattern Recognition)作为计算机视觉和模式识别领域的顶级会议,在全球具有极高的权威性.目前在中 ...
- 【动态规划】动态规划基础 (OI wiki)
文章来自 OI wiki ,转载仅作学习使用 动态规划应用于子问题重叠的情况: 要去刻画最优解的结构特征: 尝试递归地定义最优解的值(就是我们常说的考虑从 \(i - 1\) 转移到 \(i\)): ...
- Codeforces Round #700 (Div. 2) A ~ D1个人题解
Codeforces Round #700 (Div. 2) 比赛链接: Click Here 1480A. Yet Another String Game 因为Alice是要追求小,Bob追求大值, ...
- HHKB 键盘布局记录以及一些闲言碎语
HHKB (happy hacking keyboard) 是世界顶级键盘品牌,自 1996 年推出以来畅销至今.与其他键盘不同,HHKB 机身小巧,省略了 F1 - F12 功能键.光标键和 Pag ...