xml地图|网站地图|网站标签 [设为首页] [加入收藏]
python中mysql主从同步配置的方法,开发进阶篇系列
分类:数据库

1)安装mysql

ubuntu中安装一台mysql了,docker安装另外一台mysql

获取mysql的镜像,主从同步尽量保证多台mysql的版本相同,我的ubuntu中存在的mysql是5.7.22版本,所以获取5.7.22版本的镜像为例:

docker image pull mysql:5.7.22
或
docker load -i mysql_docker_5722.tar

 

运行mysql docker镜像,需要在宿主机中建立文件目录用于mysql容器保存数据和读取配置文件。

在家目录中(/home/python)中创建目录,将mysql的配置文件放到此目录中

cd ~
mkdir mysql_slave
cd mysql_slave
mkdir data
cp /etc/mysql/mysql.conf.d ./

 

将docker运行的mysql作为slave来运行,开启前需要修改配置文件。

编辑 ~/mysql_slave/mysql.conf.d/mysqld.cnf 文件,修改

port  =  8306
general_log  = 0
server-id  = 2

 

让此台mysql运行在8306端口上,且mysql编号为2

创建docker容器

docker run --name mysql-slave -e MYSQL_ROOT_PASSWORD=mysql -d --network=host -v /home/python/mysql_slave/data:/var/lib/mysql -v /home/python/mysql_slave/mysql.conf.d:/etc/mysql/mysql.conf.d  mysql:5.7.22

 

  • MYSQL_ROOT_PASSWORD 是创建mysql root用户的密码

测试,在ubuntu中使用mysql命令尝试连接docker容器中的mysql

mysql -uroot -pmysql -h 127.0.0.1 --port=8306

 

---恢复内容开始---

  在安装完数据库后,使用汉字插入到表中,会报错,需要修改字符集类型,如下图所示:

2)备份主服务器原有数据到从服务器

如果在设置主从同步前,主服务器上已有大量数据,可以使用mysqldump进行数据备份并还原到从服务器以实现数据的复制。

在主服务器Ubuntu上进行备份,执行命令:

mysqldump -uroot -pmysql --all-databases --lock-all-tables > ~/master_db.sql

图片 1

  • -u :用户名

  • -p :示密码

  • --all-databases :导出所有数据库

  • --lock-all-tables :执行操作时锁住所有表,防止操作时有数据修改

  • ~/master_db.sql :导出的备份数据(sql文件)位置,可自己指定

在docker容器中导入数据

mysql -uroot -pmysql -h127.0.0.1 --port=8306 < ~/master_db.sql

 

1、MySQL概述

-- 插入汉字时报错
INSERT INTO User2 VALUES('张三')

3)配置主服务器master(Ubuntu中的MySQL)

编辑设置mysqld的配置文件,设置log_bin和server-id

sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

图片 2

 

重启mysql服务

sudo service mysql restart

 

登入主服务器Ubuntu中的mysql,创建用于从服务器同步数据使用的帐号

mysql –uroot –pmysql

GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' identified by 'slave';

FLUSH PRIVILEGES;

 

图片 3

 

获取主服务器的二进制日志信息 

SHOW MASTER STATUS;

 

File为使用的日志文件名字,Position为使用的文件位置,这两个参数须记下,配置从服务器时会用到。

 

  1.什么是数据库?

    图片 4

4)配置从服务器slave (docker中的mysql)

进入docker中的mysql

mysql -uroot -pmysql -h 127.0.0.1 --port=8306

执行

change master to master_host='127.0.0.1', master_user='slave', master_password='slave',master_log_file='mysql-bin.000006', master_log_pos=590;
  • master_host:主服务器Ubuntu的ip地址
  • master_log_file: 前面查询到的主服务器日志文件名
  • master_log_pos: 前面查询到的主服务器日志文件位置

启动slave服务器,并查看同步状态

start slave;
show slave status G

 

图片 5

 

 

 

  存储数据的仓库

-- 查看字符集
SHOW VARIABLES LIKE ‘character%’;

  2.都有哪些公司在用数据库?

   如下图所示: character_set_database=iatin1 需要改成utf8或gbk

  金融机构、游戏公司、购物网站、论坛网站...

 图片 6
  打开my.cnf文件,修改参数,再重启
  图片 7
 重启后,再查看SHOW VARIABLES LIKE 'character%'。如下所示:character_set_filesystem不用改,默认使用二进制。
  图片 8

  3.提供数据库服务的软件?

  新建一个数据库test2, 字符集默认显示[default]不用改, 在库里新建一个表user1,如下图所示
  图片 9

    1.软件分类

-- 插入汉字成功
INSERT INTO  user1 VALUES('张三')

      MySQL、Oracle、SQL_Server、DB2、MongoDB、MariaDB

    图片 10

    2.生产环境中,如何选择使用哪个数据库软件?

  对于之前已有的test库,则需要把该库之前的默认字符改过来,如下图所示:
    图片 11

      开源:MYSql,Mariadb,MongoDB

      不开源:Oracle,DB2,SQL_Server

    3.公司的类型:

      1.商业数据库:政府部门,金融机构

      2.开源数据库:游戏网站、购物网站、论坛网站.....

  4、MySQL的特点

  1.关系型数据库

    1.关系型数据库特点

      1.数据是以行和列(表格)的形式去存储

      2.表中的每一行叫一条记录,每一列叫一个字段

      3.表和表之间的罗技关联叫关系

    2.示例

      1.关系型数据库存储

        表1  学生信息表

        姓名  年龄  班级

        星矢  25     三班

        水冰月 29    六班

        表2  班级信息表

        班级  班主任  

        三班  大空翼

        六班  松人

      2.非关系型数据库中存储

        {"姓名":"水冰月","年龄":"25"}

    2、跨平台

      可以在Unix,Linux,Windows上运行数据库服务;

    3、支持多种编程语言

      python,java,php,c/c++....

  5、数据库软件。数据库、数据仓库的概念

  1.数据库软件

    一个软件,看得见,可操作,实现数据库的逻辑功能

  2、数据库

    是一种逻辑概念,用来存放数据的仓库,侧重存储

  3、数据仓库

    从数据量上来说,比数据库庞大的多,主要用于数据分析和数据挖掘

2、MySQL安装

  1.Ubuntu安装

    安装服务端

      sudo apt-get install mysql-server

本文由澳门新葡亰手机版发布于数据库,转载请注明出处:python中mysql主从同步配置的方法,开发进阶篇系列

上一篇:关于SSMS显示select出来的数据行的疑问,SERVER中隐 下一篇:批量拆分SQL语句为事务并批处理,5120的解决办法
猜你喜欢
热门排行
精彩图文