Docker中配置MySql环境

目录

一、简单安装

1. 首先从Docker Hub中拉取镜像

2. 启动尝试创建MySQL容器,并设置挂载卷。

3. 查看mysql8这个容器是否启动成功

4. 如果已经成功启动,进入容器中简单测试

4.1 进入容器

4.2 登录mysql中 

4.3 进行简单添加查找测试

二、主从复制安装

2.1 主服务创建配置

1. 主从服务容器创建,并且配置

2. 创建配置文件并设置参数

3. 重启容器使得配置生效

4. 进入容器内,进行主服务中进行设置

4.1 进入容器

4.2 创建数据同步用户,并给同步用户授权

4.3 查看所有用户的权限

4.4 查看MySQL主服务器的当前状态,包括二进制日志文件和位置

2.2 从服务创建配置

1. 从服务容器创建,并且配置

2. 创建配置文件并设置参数

3. 重启容器使得配置生效

4. 进入容器内,进行从服务中进行设置

4.1 进入容器

4.2 配置从服务器,指定主服务器

4.3 启动 MySQL 主从复制

4.4 查看 MySQL 主从复制状态

2.3 安装中的遇到的问题

2.4 配置完成,进行简单测试

1. 在主服务器中创建并添加数据

2. 在从服务器中查询数据,是否同步

3. 测试结果


一、简单安装

1. 首先从Docker Hub中拉取镜像

这里我要安装的是mysql8版本。

docker pull mysql:8.0.27

2. 启动尝试创建MySQL容器,并设置挂载卷。

docker run -p 3306:3306 \--name mysql8 \--privileged=true \-v /app/mysql8/log:/var/log/mysql \-v /app/mysql8/data:/var/lib/mysql \-v /app/mysql8/conf:/etc/mysql/conf.d \-v /app/mysql8/files:/var/lib/mysql-files \-e MYSQL_ROOT_PASSWORD=123456 \-d mysql:8.0.27
  • --name mysql8: 为容器指定一个名称,这里是 mysql8
  • --privileged=true: 赋予容器更多的权限。在一般情况下,尽量避免使用 --privileged,因为它会赋予容器更多的权限,可能会带来一些安全风险。
  • -v /app/mysql8/log:/var/log/mysql: 将主机上的 /app/mysql8/log 目录映射到容器内的 /var/log/mysql,用于存储MySQL的日志文件。
  • -v /app/mysql8/data:/var/lib/mysql: 将主机上的 /app/mysql8/data 目录映射到容器内的 /var/lib/mysql,用于持久化存储MySQL的数据。
  • -v /app/mysql8/conf:/etc/mysql/conf.d: 将主机上的 /app/mysql8/conf 目录映射到容器内的 /etc/mysql/conf.d,用于提供自定义的MySQL配置文件。
  • -v /app/mysql8/files:/var/lib/mysql-files: 将主机上的 /app/mysql8/files 目录映射到容器内的 /var/lib/mysql-files,用于存储MySQL的文件。
  • -e MYSQL_ROOT_PASSWORD=123456: 设置MySQL root用户的密码为 123456
  • -d: 后台运行容器。

3. 查看mysql8这个容器是否启动成功

docker ps

4. 如果已经成功启动,进入容器中简单测试

4.1 进入容器

docker exec -it mysql8 /bin/bash

4.2 登录mysql中 

mysql -uroot -p123456

4.3 进行简单添加查找测试

CREATE DATABASE mydatabase;USE mydatabase;CREATE TABLE users (id INT PRIMARY KEY AUTO_INCREMENT,username VARCHAR(50) NOT NULL,email VARCHAR(100) NOT NULL
);INSERT INTO users (username, email) VALUES
('john_doe', 'john@example.com'),
('jane_smith', 'jane@example.com'),
('bob_jones', 'bob@example.com');SELECT * FROM users; 

二、主从复制安装

2.1 主服务创建配置

1. 主从服务容器创建,并且配置

ps:这里也默认使用mysql8版本进行安装。

docker run -p 3307:3306 \--name mysql-master \--privileged=true \-v /app/mysql-master/log:/var/log/mysql \-v /app/mysql-master/data:/var/lib/mysql \-v /app/mysql-master/conf:/etc/mysql/conf.d \-v /app/mysql-master/files:/var/lib/mysql-files \-e MYSQL_ROOT_PASSWORD=123456 \-d mysql:8.0.27
  • docker run: 启动一个新的Docker容器。
  • -p 3307:3306: 将主机的3307端口映射到容器的3306端口,这样可以通过主机的3307端口访问MySQL服务。
  • --name mysql-master: 为容器指定一个名称,这里是 mysql-master
  • --privileged=true: 赋予容器更高的权限。注意,一般情况下最好避免使用 --privileged,因为它可能会引入一些潜在的安全风险。
  • -v /app/mysql-master/log:/var/log/mysql: 将主机上的 /app/mysql-master/log 目录映射到容器内的 /var/log/mysql,用于存储MySQL的日志文件。
  • -v /app/mysql-master/data:/var/lib/mysql: 将主机上的 /app/mysql-master/data 目录映射到容器内的 /var/lib/mysql,用于持久化存储MySQL的数据。
  • -v /app/mysql-master/conf:/etc/mysql/conf.d: 将主机上的 /app/mysql-master/conf 目录映射到容器内的 /etc/mysql/conf.d,用于提供自定义的MySQL配置文件。
  • -v /app/mysql-master/files:/var/lib/mysql-files: 将主机上的 /app/mysql-master/files 目录映射到容器内的 /var/lib/mysql-files,用于存储MySQL的文件。
  • -e MYSQL_ROOT_PASSWORD=123456: 设置MySQL root用户的密码为 123456
  • -d: 以后台模式运行容器。
  • mysql:8.0.27: 使用的MySQL镜像的标签,这里是MySQL 8.0.27版本

2. 创建配置文件并设置参数

vim /app/mysql-master/conf/my.cnf
[mysqld]
## 设置server_id, 同一个局域网中需要唯一
server_id=1001
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql
## 开启二进制日志功能
log-bin=mall-mysql-bin
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间。默认值为0,表示不自动清理
expire_logs_days=7
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062

ps:在编写配置的时候,参数后不要留有空格,避免不必要的错误!!!

3. 重启容器使得配置生效

docker restart mysql-master

4. 进入容器内,进行主服务中进行设置

4.1 进入容器
docker exec -it mysql-master /bin/bash
mysql -uroot -p123456
4.2 创建数据同步用户,并给同步用户授权
create user 'slave'@'%' identified by '123456';
grant replication slave, replication client on *.* to 'slave'@'%';
flush privileges;
4.3 查看所有用户的权限
SELECT user, host, authentication_string, Grant_priv, Super_priv, Create_priv, Insert_priv, Update_priv, Delete_priv, Select_priv FROM mysql.user;

 得到这样得结果

4.4 查看MySQL主服务器的当前状态,包括二进制日志文件和位置
show master status;

参数说明:

File(文件)

表示当前正在写入的二进制日志文件的名称

Position(位置)

表示在二进制日志文件中的当前写入位置

Binlog_Do_DB

一个逗号分隔的数据库列表,表示正在复制的二进制日志事件应用于哪些数据库

Binlog_Ignore_DB

一个逗号分隔的数据库列表,表示正在复制的二进制日志事件不应用于哪些数据库

Executed_Gtid_Set

表示已经执行的 GTID(全局事务标识符)集合。在MySQL的 GTID 复制中

 

2.2 从服务创建配置

1. 从服务容器创建,并且配置

docker run -p 3308:3306 \--name mysql-slave \--privileged=true \-v /app/mysql-slave/log:/var/log/mysql \-v /app/mysql-slave/data:/var/lib/mysql \-v /app/mysql-slave/conf:/etc/mysql/conf.d \-v /app/mysql-master/files:/var/lib/mysql-files \-e MYSQL_ROOT_PASSWORD=123456 \-d mysql:8.0.27

2. 创建配置文件并设置参数

vim /app/mysql-slave/conf/my.cnf
[mysqld]
## 设置server_id, 同一个局域网内需要唯一
server_id=1002
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql
## 开启二进制日志功能,以备slave作为其它数据库实例的Master时使用
log-bin=mall-mysql-slave1-bin
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间。默认值为0,表示不自动清理
expire_logs_days=7
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断
## 如:1062错误是指一些主键重复,1032是因为主从数据库数据不一致
slave_skip_errors=1062
## relay_log配置中继日志
relay_log=mall-mysql-relay-bin
## log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1
## slave设置只读(具有super权限的用户除外)
read_only=1

ps:在编写配置的时候,参数后不要留有空格,避免不必要的错误!!!

3. 重启容器使得配置生效

docker restart mysql-slave

4. 进入容器内,进行从服务中进行设置

4.1 进入容器
docker exec -it mysql-slave /bin/bash
mysql -uroot -p123456
4.2 配置从服务器,指定主服务器

我这里使用的是 CentOS7,查看服务器地址

ifconfig

CHANGE MASTER TOMASTER_HOST = '192.168.153.133',       -- 主服务器的 IP 地址MASTER_USER = 'slave',                  -- 用于连接主服务器的用户名MASTER_PASSWORD = '123456',             -- 用于连接主服务器的密码MASTER_PORT = 3307,                     -- 主服务器的端口号MASTER_LOG_FILE = 'binlog.000011',      -- 主服务器的二进制日志文件MASTER_LOG_POS = 1193,                  -- 主服务器的二进制日志位置MASTER_CONNECT_RETRY = 30,              -- 如果连接失败,重试的时间间隔(秒)GET_MASTER_PUBLIC_KEY = 1;              -- 启用 SSL 模式,1 表示启用
4.3 启动 MySQL 主从复制
start slave;
 4.4 查看 MySQL 主从复制状态
# \G 可以将横向的结果集表格转换成纵向展示。
# slave status的字段比较多,纵向展示比友好
show slave status \G;

主要查看 Slave_IO_Running 和 Slave_SQL_Running是否为 Yes 状态。

ps:如果在安装中遇到问题可以查看下面这篇文章  ↓↓↓ ↓↓↓ 

2.3 安装中的遇到的问题

如果在安装过程中遇到问题,可以查看这篇文章,这是我遇到的一些问题和解决方案。

Docker中安装MySql的遇到的问题icon-default.png?t=N7T8http://t.csdnimg.cn/ujsL1

2.4 配置完成,进行简单测试

1. 在主服务器中创建并添加数据

CREATE DATABASE IF NOT EXISTS mydatabase;USE mydatabase;CREATE TABLE IF NOT EXISTS users (id INT PRIMARY KEY AUTO_INCREMENT,username VARCHAR(50) NOT NULL,email VARCHAR(100) NOT NULL
);INSERT INTO users (username, email) VALUES('alice_white', 'alice@example.com'),('charlie_brown', 'charlie@example.com'),('emma_jones', 'emma@example.com');select * from users;

2. 在从服务器中查询数据,是否同步

show databases;use mydatabase;select * from users;

3. 测试结果

主从服务器数据同步 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/662970.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MySQL-----初识

一 SQL的基本概述 基本概述 ▶SQL全称: Structured Query Language,是结构化查询语言,用于访问和处理数据库的标准的计算机语言。SQL语言1974年由Boyce和Chamberlin提出,并首先在IBM公司研制的关系数据库系统SystemR上实现。 ▶美国国家标…

MySQL亿级数据的查询优化-历史表该如何建

前端时间在知乎上看到一个问题,今天有空整理并测试了一下: 这个问题很具体,所以还是可以去尝试优化一下,我们基于InnoDB并使用自增主键来讲。 比较简单的做法是将历史数据存放到另一个表中,与最近的数据分开。那是不是…

如何使用Linux Archcraft结合内网穿透实现SSH远程连接

📑前言 本文主要是使用Linux Archcraft结合内网穿透实现SSH远程连接的文章,如果有什么需要改进的地方还请大佬指出⛺️ 🎬作者简介:大家好,我是青衿🥇 ☁️博客首页:CSDN主页放风讲故事 &#…

go gin 响应数据

go gin 响应数据 package mainimport ("fmt""github.com/gin-gonic/gin" )type UserInfo struct {UserName string json:"user_name"Age int json:"age"Password string json:"-" }func JsonTest(ctx *gin.Context…

黑马Java——常见API

一、游戏打包exe 游戏打包exe要考虑的因素: 游戏打包exe核心步骤: 详见《打包exe文档》 二、Math (一) Math类的常用方法 1、代码实现 2、小结

JVM 笔记

JVM HotSpot Java二进制字节码的运行环境 好处: 一次编写,到处运行自动内存管理,具有垃圾回收功能数组下标越界检查多态(虚方法表) JVM组成 类加载子系统(Java代码转换为字节码)运行时数据…

【JavaEE进阶】 图书管理系统开发日记——贰

文章目录 🌲前言🎄设计数据库🍃引⼊MyBatis和MySQL驱动依赖🌳Model创建🎍约定前后端交互接口🍀服务器代码🚩控制层🚩业务层🚩数据层 🌴效果展示⭕总结 &#…

01- k8s基础网络知识 之 underlay与overlay网络

前言: 我们在学习k8s网络之前,必须要了解k8s网络相关的一些基础知识,比如什么是underlay网络、overlay网络等,只有把基础知识掌握之后,后续学习k8s网络的时候,一些知识点就不会再云里雾里了。 1 underlay与…

协作办公开源神器:ONLYOFFICE

目录 前言ONLYOFFICE为什么选择ONLYOFFICE强大的文档编辑功能多种协作方式多人在线协同支持跨端多平台连接器安全性极高本地部署 ONLYOFFICE 8.0版本震撼来袭可填写的 PDF 表单显示协作用户头像更新插件界面设计更快更强大 总结 前言 近几年来,随着互联网技术的不断…

如何解决 docker registry x509 证书不信任问题?

最近想尝试一下极狐GitLab(可以理解为 GitLab 在中国的发行版)内置的容器镜像仓库,这样就不用自己安装 Harbor 之类的了。于是找了个服务器安装了一个极狐GitLab 的私有化部署版本,安装过程可以参考过往的技术文章使用Omnibus 安装…

在Windows搭建gRPC C++开发环境

本文介绍在Windows下使用Visual Studio 2017编译gRPC 1.48.0并配置开发环境,以及开发、配置一个简单的c服务端以及.net客户端。 0、前置条件 1、下载gRPC源码 使用git命令行在预备存放grpc源码的目录下执行, 此处我们下载的是 grpc 1.48.0 git clone -b v1.48.0 …

Pycharm python用matplotlib 3D绘图显示空白解决办法

问题原因: matplotlib版本升级之后显示代码变了,修改为新的 # ax Axes3D(fig) # 原代码 ax fig.add_axes(Axes3D(fig)) # 新代码import numpy as np import matplotlib.pyplot as plt from matplotlib import cm from mpl_toolkits.mplot3d import Ax…

测试环境搭建整套大数据系统(一:基础配置,修改hostname,hosts,免密,时间同步)

一:使用服务器配置。 二:修改服务器名称hostname,hosts。 在 Linux 系统中,hostname 和 /etc/hosts 文件分别用于管理主机名和主机名解析。 在三台服务器上,分别执行以下命令。 vim /etc/hostnamexdso-hadoop-test-0…

༺༽༾ཊ—Unity之-04-原型模式—ཏ༿༼༻

首先创建一个项目, 在这个初始界面我们需要做一些准备工作, 建基础通用文件夹, 创建一个Plane 重置后 缩放100倍 加一个颜色, 任务1:使用 建造者模式 创建三种 金刚猿猴 零部件 拼接组合 首先资源商店下载 金刚猿猴 模…

刨析数据结构(二)

🌈个人主页:小田爱学编程 🔥 系列专栏:数据结构————"带你无脑刨析" 🏆🏆关注博主,随时获取更多关于数据结构的优质内容!🏆🏆 😀欢迎…

strlen函数详解

🎈个人主页:甜美的江 🎉欢迎 👍点赞✍评论⭐收藏 🤗收录专栏:c语言 🤝希望本文对您有所裨益,如有不足之处,欢迎在评论区提出指正,让我们共同学习、交流进步&a…

动态微信小程序码和开发者工具解析小程序码

一、动态生成微信小程序码 1、方式一 微信官方网站,对已发布的小程序,提供了一个快捷的入口,输入微信小程序的page页面即可。 page页面可以通过右侧开启入口获取 也可以通过开发者工具左下角的页面地址和参数地址那里获取到 二、生成的小…

【软件设计师笔记】计算机系统基础知识考点

【考证须知】IT行业高含金量的证书(传送门) 💖 【软件设计师笔记】程序语言设计考点(传送门) 💖 【软件设计师笔记】操作系统考点(传送门) 💖 🐓 计算机系统组成 计算机系统是由硬件和软件组成的,它们协同工作来运…

WAF 无法防护的八种风险

一、目录遍历漏洞 测试用例:Apache 目录遍历漏洞 测试环境搭建: apt intsall apache2 && cd /var/www/html/ && rm index.html无法拦截原因: 请求中无明显恶意特征,无法判断为攻击行为 实战数据: 截…

MongoDB聚合操作

文章目录 聚合操作单一作用聚合聚合管道什么是 MongoDB 聚合框架管道(Pipeline)和阶段(Stage)常用的管道聚合阶段聚合表达式数据准备$project$match$count$group accumulator操作符$unwind$limit$skip$sort$lookup案例聚合操作案例…