备份数据库


  • 查看数据库的数据文件的位置

    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直接运行的操作过程的更多相关文章

  1. Weka链接Mysql数据库

    Weka简介 Weka的全名是怀卡托智能分析环境(Waikato Environment for Knowledge Analysis),是一款免费的,非商业化(与之对应的是SPSS公司商业数据挖掘产 ...

  2. Windows平台下搭建MySQL数据库

    1.下载安装MySQL数据库: (1)->我的标签->软件下载->计算机相关专业所用软件---百度云链接下载->mysql-installer-community-5.7.18 ...

  3. MYSQL——数据库存储引擎!

    本人安装mysql版本为:mysql  Ver 14.14 Distrib 5.7.18, for Win64 (x86_64),查看mysql的版本号方式:cmd-->mysql --vers ...

  4. Linux下C++访问MySQL数据库

    由于想要开始了解并学习用LAMP进行web开发,所以昨晚我在Fedora上安装了MySQL,学习了MySQL的几个常用命令.想着在学习进行web开发(PHP访问数据库)之前,先用我熟悉的C++连接数据 ...

  5. Docker 运行 MYSQL 数据库的总结

    公司里面要求做一个小demo 学习java相关的东西 然后使用了mysql数据库 很早之前做过mysql的容器化运行. 现在想想已经忘记的差不多了  所以这里总结一下 docker化运行mysql数据 ...

  6. 使用docker容器运行MySQL数据库并持久化数据文件

    1.下载mysql镜像 # docker pull mysql 2.启动mysql容器 # docker run -itd -v /data:/var/lib/mysql -p 33060:3306 ...

  7. Docker安装Mysql数据库容器(zz)

    zz自:http://blog.csdn.net/chengxuyuanyonghu/article/details/54380032 1.下载mysql的镜像: sudo docker pull m ...

  8. 沉迷 Docker,无法自拔(在 Docker 中运行 MySQL)

    记得之前做网站开发的时候,因为服务端用的 MySQL 数据库,为了方便调试以及隔离生产与开发环境,自己就在本地也安装了一个 MySQL 数据库.但是用着用着慢慢的也发现了一些不舒服的地方,比如常驻后台 ...

  9. Docker学习实践 - Docker安装MySql数据库

    Docker安装MySQL数据库 1.Ubuntu安装MySQL安装 (1)安装编译源码需要的包 sudo apt-get install make cmake gcc g++ bison libnc ...

  10. Docker安装MySQL数据库

    本文翻译自:MySQL Docker Containers:Understanding the basics 1.下载MySQL镜像 docker pull mysql:5.6 如此便可以下载最新的M ...

随机推荐

  1. 大模型高效开发的秘密武器:大模型低参微调套件MindSpore PET

    摘要:本文介绍大模型低参微调套件--MindSpore PET. 本文分享自华为云社区<大模型高效开发的秘密武器--大模型低参微调套件MindSpore PET篇>,作者:yd_28087 ...

  2. Tarjan:这个算法大神

    摘要:图的算法是进行静态分析的基础数据算法,如何提高图的分析效率,就需要对图的算法有进一步的认识. 1. 引言 在静态分析技术中, 我们常用会将代码转成抽象语法树(AST), 然后采用深度遍历(DFS ...

  3. 不同数据库模式下DATE类型的行为解析

    摘要:本文章主要介绍了GaussDB(DWS)数据类型中的DATE类型在不同数据库模式下且在不同应用场景下的行为表现及对比. 本文分享自华为云社区<GaussDB(DWS)数据类型之DATE类型 ...

  4. TypeScript里string和String,真不是仅仅是大小写的区别

    摘要:通常来说,string表示原生类型,而String表示对象. 本文分享自华为云社区<TypeScript里string和String的区别>,作者:gentle_zhou . 背景 ...

  5. App备案与iOS云管理式证书 ,公钥及证书SHA-1指纹的获取方法

    iOS 备案查看信息 iOS平台Bundle ID 公钥 证书SHA-1指纹 IOS平台服务器域名 获取 Bundle ID: 或者 https://developer.apple.com/accou ...

  6. Markdown Emojio 表情图标

     :smile:  :laughing:  :blush:  :smiley: ️ :relaxed:  :smirk:  :heart_eyes:  :kissing_heart:  :kissin ...

  7. python argparse传入布尔参数不生效解决

    前言 在一个需要用到flag作为信号控制代码中一些代码片段是否运行的,比如"--flag True"或者"--flag False". 但是古怪的是无法传入Fa ...

  8. 神经网络优化篇:详解RMSprop

    RMSprop 知道了动量(Momentum)可以加快梯度下降,还有一个叫做RMSprop的算法,全称是root mean square prop算法,它也可以加速梯度下降,来看看它是如何运作的. 回 ...

  9. Codeforces Round #681 (Div. 2, based on VK Cup 2019-2020 - Final) 个人题解(A - D)

    1443A. Kids Seating 题意: 给你一个整数n,现在你需要从编号 \(1\) ~ $4 ⋅ n \(中选出\)n\(个编号使得这些编号之间\)g c d ≠ 1$ ,不能整除. 看了半 ...

  10. jdk1.8: Consumer函数

    场景: 当我们在a方法中,需要把某些参数赋值给一个Integer类型的对象,而该对象只有在b方法才能赋值,那么我们可以在a方法中使用consumer记录我们要执行的操作,再把consumer作为参数传 ...