返回顶部
首页 > 资讯 > 数据库 >MacOS使用Docker创建MySQL主从数据库的方法
  • 142
分享到

MacOS使用Docker创建MySQL主从数据库的方法

2024-04-02 19:04:59 142人浏览 安东尼
摘要

一、拉取Mysql镜像 通过终端获取最新的mysql镜像 Docker pull mysql/mysql-server 二、创建MySQL数据库容器配置文件对应目录 我们在当前

一、拉取Mysql镜像

通过终端获取最新的mysql镜像

Docker pull mysql/mysql-server

二、创建MySQL数据库容器配置文件对应目录

我们在当前用户下创建一组目录,用来存放MySQL容器配置文件,(linux下可以省略此步骤)参考下图:

注意:MySQL8版本以后,需要在映射文件中加入 mysql-files,否则MySQL数据库容器会创建失败。

因为在MacOS下不支持vi/vim 直接修改my.cnf文件,也不支持apt-get安装vim,所以需要在本地新建两个my.cnf映射文件。(Linux下可以通过vim直接修改配置文件)

master主库对应的my.cnf配置文件为:


[mysqld]
server_id = 1
log-bin= mysql-bin
read-only=0
replicate-ignore-db=mysql
replicate-ignore-db=sys
replicate-ignore-db=infORMation_schema
replicate-ignore-db=performance_schema

slave从库对应的my.cnf配置文件为:


[mysqld]
server_id = 2
log-bin= mysql-bin
read-only=1
replicate-ignore-db=mysql
replicate-ignore-db=sys
replicate-ignore-db=information_schema
replicate-ignore-db=performance_schema

三、创建两个MySQL数据库容器

创建master主数据库容器

docker run --name mysql-master -d -p 3307:3306 -e MYSQL_ROOT_PASSWord=123456 -v /Users/yumaster/test/mysql_master_slave/master/data:/var/lib/mysql -v /Users/yumaster/test/mysql_master_slave/master/conf/my.cnf:/etc/mysql/my.cnf -v /Users/yumaster/test/mysql_master_slave/master/mysql-files:/var/lib/mysql-files mysql/mysql-server

创建slave从数据库容器

docker run --name mysql-slave -d -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -v /Users/yumaster/test/mysql_master_slave/slave/data:/var/lib/mysql -v /Users/yumaster/test/mysql_master_slave/slave/conf/my.cnf:/etc/mysql/my.cnf -v /Users/yumaster/test/mysql_master_slave/slave/mysql-files:/var/lib/mysql-files mysql/mysql-server

如下图,说明两个MySQL容器创建成功

此时我们打开Docker仪表板可以看到,两个容器已经运行起来了。而且端口就是我们之前创建的对应端口

我们通过Navicat连接会报哦1130错误,是因为所连接的用户账户没有远程连接的权限。需要更改mysql数据库里的user表里的host项

把localhost改成%

具体步骤:


mysql> use mysql
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> select host from user where user='root';
+-----------+
| host      |
+-----------+
| localhost |
+-----------+
1 row in set (0.01 sec)

mysql> update user set host='%' where user = 'root';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1  Changed: 1  Warnings: 0

mysql> select host from user where user='root';
+------+
| host |
+------+
| %    |
+------+
1 row in set (0.00 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.01 sec)

四、主从数据库配置

master主数据库配置:


//进入master主数据容器
docker exec -it mysql-master mysql -uroot -p123456
//创建一个用户来同步数据,每个slave使用标准的MySQL用户名和密码连接master。进行复制操作的用户会授予REPLICATION SLAVE 权限。mysql8 之前的版本中加密规则是mysql_native_password,而在mysql8之后,加密规则是caching_sha2_password
CREATE USER 'slave'@'%' IDENTIFIED BY '123456';(这样有可能在slave创建与master连接时报错)
或
CREATE USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
//对用户进行授权
GRANT REPLICATION SLAVE ON *.* to 'slave'@'%';
//查看状态,记住File、Position的值,在Slave中将用到
show master status;
//查询master容器的IP,会在slave设置主库连接时用到
docker inspect mysql-master | grep IPA;

mster的状态,File mysql-bin.000003 Position 661

slave从数据库配置:


//进入slave从数据容器
docker exec -it mysql-slave mysql -uroot -p123456
//设置主库链接 change master to
change master to master_host='172.17.0.2',master_user='slave',master_password='123456',master_log_file='mysql-bin.000003',master_log_pos=661,master_port=3306;
//启动从库同步
start slave;
//查看状态
show slave status\G;
//如果 show slave status\G命令结果中出现:
//Slave_IO_Running: Yes
//Slave_SQL_Running: Yes
//以上两项都为Yes,那说明没问题了。
//否则,从新配置从数据
stop slave;
reset slave all;

启动从库同步成功

五、主从验证

我们在master上创建一个数据库,然后创建一张表,再插入一条数据,相应的slave也会增加;


create database master_slave_demo;
use master_slave_demo;
create table userinfo(username varchar(50),age int);
insert into userinfo values('Toulon',25);
select * from userinfo;

在执行命令之前,主从数据库数量相同;

master执行命令之后slave增加对应数据

可以发现主库新增的数据已经同步过来了,MySQL的主从复制就设置完成了。(测试环境,MacOS M1 ARM64机器,Docker,MySQL 8.0.27)

到此这篇关于MacOS使用Docker创建MySQL主从数据库的文章就介绍到这了,更多相关Docker创建MySQL主从数据库内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: MacOS使用Docker创建MySQL主从数据库的方法

本文链接: https://lsjlt.com/news/161015.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MacOS使用Docker创建MySQL主从数据库的方法
    一、拉取MySQL镜像 通过终端获取最新的MySQL镜像 docker pull mysql/mysql-server 二、创建MySQL数据库容器配置文件对应目录 我们在当前...
    99+
    2024-04-02
  • MacOS如何使用Docker创建MySQL主从数据库
    这篇文章主要介绍MacOS如何使用Docker创建MySQL主从数据库,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、拉取MySQL镜像通过终端获取最新的MySQL镜像docker pull mysql/mysq...
    99+
    2023-06-22
  • 使用Docker搭建MySQL主从数据库的方法步骤
    目录1. 准备主服务器2. 准备从服务器3. 启动主从同步4. 实现主从同步5. 停止和重置很多人对主从数据库有一个误区,把多个mysql搭建在同一个服务器上,性能提升是不是很有限?这个理念是错误的,数据库的性能瓶颈主要...
    99+
    2023-01-11
    Docker搭建MySQL主从 Docker MySQL主从
  • mysql主从的创建方法
    这篇文章主要介绍“mysql主从的创建方法”,在日常操作中,相信很多人在mysql主从的创建方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql主从的创建方法”的疑惑...
    99+
    2024-04-02
  • mysql创建数据库的方法
    不知道大家之前对类似mysql创建数据库的方法的文章有无了解,今天我在这里给大家再简单的讲讲。感兴趣的话就一起来看看正文部分吧,相信看完mysql创建数据库的方法你一定会有所收获的。使用MySQL来创建数据...
    99+
    2024-04-02
  • 使用docker-compose搭建mysql主从
    目录 一、docker-compose和主从的简介 1、docker-compose 2、mysql主从 3、为什么要使用docke-compose? 二、部署mysql主从集群 1、mysql-master主库 2、mysql-slave...
    99+
    2023-09-26
    docker mysql java 数据库 微服务
  • Mysql主从数据库搭建(一主两从)
    目录 1、服务器规划 2、主从同步流程 3、主从搭建 3.1、master节点上配置文件修改 3.2、master节点创建同步用户和权限 3.3、slave1和slave2节点配置文件修改 3.4、slave1和slave2节点执行同步任...
    99+
    2023-08-31
    数据库 mysql 服务器
  • mysql数据库创建数据表的方法
    小编给大家分享一下mysql数据库创建数据表的方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!mysql创建数据表的方法:使用sql通用语法【CREATE TABLE table_nam...
    99+
    2024-04-02
  • Mysql中怎么创建数据库并配置主从
    这篇文章将为大家详细讲解有关Mysql中怎么创建数据库并配置主从,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、主服务器上创建一个用于复制的账户。 my...
    99+
    2024-04-02
  • Mysql数据库中怎么创建从库
    今天就跟大家聊聊有关Mysql数据库中怎么创建从库,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。首先参考http://blog.itpub.net/...
    99+
    2024-04-02
  • MySQL数据库主从同步的实现方法
    这篇文章主要讲解了MySQL数据库主从同步的实现方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。安装环境说明系统环境:[root@~]# cat /etc/redhat-re...
    99+
    2024-04-02
  • mysql创建数据库的方法有哪些
    在MySQL中,可以使用以下几种方法来创建数据库: 使用CREATE DATABASE语句: CREATE DATABASE d...
    99+
    2024-04-22
    mysql
  • 数据库表的创建方法
    这篇文章主要介绍数据库表的创建方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在数据库中,可以使用“CREATE TABLE”语句来创建表,语法格式为“CREATE TABLE 表...
    99+
    2024-04-02
  • mysql中创建数据库的方法是什么
    这篇文章给大家分享的是有关mysql中创建数据库的方法是什么的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。 数据库可以看作是一个专门存储数据对象的容器,这里的数据对象包...
    99+
    2024-04-02
  • 在MySQL数据库中创建新表的方法
    这篇文章将为大家详细讲解有关在MySQL数据库中创建新表的方法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。CREATE TABLE语法:CREATE TABL...
    99+
    2024-04-02
  • mysql主主和主从的搭建方法
    这篇文章主要介绍“mysql主主和主从的搭建方法”,在日常操作中,相信很多人在mysql主主和主从的搭建方法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql主主和主从...
    99+
    2024-04-02
  • MongoDB连接数据库并创建数据等使用方法
    1.mongodb官网 MongoDB: the application data platform | MongoDB 2.进入MongoDB官网下载MongoDB以及MongoD...
    99+
    2024-04-02
  • mysql 使用 PHP脚本创建数据库
    在一些开源的系统,都可以动态创建数据库名及数据库数据,mysql 使用 PHP脚本创建数据库,简单说说生成的原理。 1,使用的函数 mysqli_connect() ...
    99+
    2024-04-02
  • MySQL:创建数据库,数据表,主键和外键
    目录 前言: 安装MySQL: 打开MySQL: 创建数据库: 查看已建数据库: 查看数据库引擎: 创建数据表:  主键约束: 单字段主键: 多字段联合主键: 外键约束: 前言: MySQL数据库安装了很久,一直也没静下心来学习,因为起...
    99+
    2023-10-18
    mysql 数据库
  • SQL Server创建数据库的方法
    本篇内容介绍了“SQL Server创建数据库的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!&nbs...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作