zoukankan      html  css  js  c++  java
  • Linux

    Linux - centos7 下 MySQL(mariadb) 和 主从复制

    MySQL(mariadb)

    MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可。

    开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险。

    MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。

    安装MySQL(mariadb)

    1.在线下载阿里云的 yum 仓库,以及epel仓库

    	CentOS-Base.repo  epel.repo
    

    2.安装mysql的方式

    	yum install mysql-server  mysql -y  
    

    3.安装mysql的方式也有2种,阿里云官方提供的mariadb软件包,版本可能太低,但是下载网速很快,方便学习使用

    4.在企业里面,多半不会使用阿里云的mariadb版本,因为版本太低,安全性太低,公司会配置myariadb官方的yum仓库

    1.手动创建mariadb的仓库文件
    	touch Mariadb.repo
    2.写入配置信息
    	[mariadb]
    	name = MariaDB
    	baseurl = http://yum.mariadb.org/10.1/centos7-amd64
    	gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
    	gpgcheck=1
    3.尝试安装最新版本mariadb
    	yum install mariadb-server mariadb
    

    5.使用mysql,启动

    systemctl start mariadb 
    

    6.初始化数据库

    mysql_secure_installation
    

    配置数据库的中文支持

    1.修改mysql的配置文件,支持中文编码
    
    cat /etc/my.cnf  和我一致就行 
    	[mysqld]
    	character-set-server=utf8
    	collation-server=utf8_general_ci
    	log-error=/var/log/mysqld.log
    	datadir=/var/lib/mysql
    	socket=/var/lib/mysql/mysql.sock
    	# Disabling symbolic-links is recommended to prevent assorted security risks
    	symbolic-links=0
    	# Settings user and group are ignored when systemd is used.
    	# If you need to run mysqld under a different user or group,
    	# customize your systemd unit file for mariadb according to the
    	# instructions in http://fedoraproject.org/wiki/Systemd
    
    	[client]
    	default-character-set=utf8
    
    	[mysql]
    	default-character-set=utf8
    
    2.在服务器上,修改了配置文件,都要重启数据库服务
    systemctl restart mariadb 
    
    3.在utf8编码下,配置mariadb
    	show create table stu;
    	create table stu(id int,name char(10));
    	insert into stu(id,name) values(1,"小王");
    	show create database s16;
    

    在远程用 mysql客户端去连接服务端,方式有哪些

    1.navicat
    2.cmd  
    	mysql  -uroot -p  -h 192.168.15.53
    3.pycharm 
    4.pymysql  python
    5.orm  django
    

    配置mysql支持远程连接的sql语句

    授权mariadb远程连接
    #授予root用户对所有的库表所有的权限,在所有的机器上操作,皆可登录
    # 此时是退出mysql数据库在外面执行的
    grant all privileges on *.* to root@'%' identified by 'centos';(密码)
    grant all privileges on *.* to root@'%' identified by 'root';
    
    刷新授权表:
    flush privileges;
    

    数据库备份与恢复

    mysqldump命令用于备份数据库数据

    mysqldump -u root -p --all-databases > /tmp/db.dump
    数据导入,方式有2种
    1.mysql -uroot -p  <  /tmp/db.dump 
    2.进入mysql命令行,输入source /tmp/db.dump 
    systemctl stop firewalld
    systemctl disable firewalld
    

    进入mariadb数据库,删除一个db

    [root@master ~]# mysql -uroot -p
    

    MariaDB [(none)]> drop database s11;
    进行数据恢复,吧刚才重定向备份的数据库文件导入到mysql中

    [root@master ~]# mysql -uroot -p < /tmp/db.dump
    

    MYSQL主从复制

    MySQL数据库的主从复制方案,是其自带的功能,并且主从复制并不是复制磁盘上的数据库文件,而是通过binlog日志复制到需要同步的从服务器上。

    MySQL数据库支持单向、双向、链式级联,等不同业务场景的复制。在复制的过程中,一台服务器充当主服务器(Master),接收来自用户的内容更新,而一个或多个其他的服务器充当从服务器(slave),接收来自Master上binlog文件的日志内容,解析出SQL,重新更新到Slave,使得主从服务器数据达到一致。

    主从复制的逻辑有以下几种

    • 一主一从,单向主从同步模式,只能在Master端写入数据
    • 一主多从
    • 主主复制逻辑架构,此架构可以在Master1或Master2进行数据写入,或者两端同事写入(特殊设置,互为主从)

    主从机制实现原理:

    (1) master将改变记录到二进制日志(binary log)中(这些记录叫做二进制日志事件,binary log events); 
    (2) slave将master的binary log events拷贝到它的中继日志(relay log); 
    (3) slave重做中继日志中的事件,将改变反映它自己的数据。
    

    master主库配置

    1.环境准备,准备2台机器,一个master 一个slave

    	192.168.15.53  主库 
    
    	192.168.15.94  从库
    

    2.配置主库的环境

    1.修改主库的配置文件,开启binlog功能
    	vim /etc/my.cnf
    	[mysqld]
    	server-id=1
    	log-bin=s16-mysql-bin
    
    2.重启数据库
    systemctl restart mariadb
    

    3.创建用于数据同步的账号

    create user 'banzhang'@'%' identified by 'bz666';
    

    4.授予这个账号,一个slave的身份标识

    grant replication slave on *.* to 'banzhang'@'%';
    

    5.锁表

    flush table with read lock;
    

    6.数据库信息导出

    mysqldump -uroot -p   --all-databases  >  /opt/db.dump  
    
    scp /opt/db.dump root@192.168.15.122:/opt/
    

    mariadb从库的操作

    1.阿里云的源,和官方源,同一安装软件包名如下

    yum install mariadb-server mariadb -y 
    

    2.配置从库的配置文件,开启server-id

    vim /etc/my.cnf 
    
    写入如下操作
    [mysqld]
    server-id=3
    read-only=true
    
    character-set-server=utf8
    collation-server=utf8_general_ci
    log-error=/var/log/mysqld.log
    

    3.重启数据库

    systemctl restart mariadb 
    

    4.在从库,通过一条命令,开启主从同步

    进入数据库
    mysql > change master to master_host='192.168.15.91',
    master_user='banzhang',
    master_password='bz666',
    master_log_file='s16-mysql-bin.000002',  这个和下面的参数要和主库的状态一致   即show master status; 查看这两个参数的数值
    master_log_pos=331;
    

    5.开启slave同步

    start slave; 
    

    6.检查主从同步状态

    show slave statusG 
    当你检查这2条参数,yes的时候,主从ok
    
    Slave_IO_Running: Yes
    Slave_SQL_Running: Yes
    

    此时解锁主库!!

    此时解锁主库!! unlock tables

    此时解锁主库!!

    验证主从同步是否正常

    检查主从复制是否成功的关键在于

    MariaDB [(none)]> show slave statusG
    *************************** 1. row ***************************
                   Slave_IO_State: Waiting for master to send event
                      Master_Host: 192.168.119.10
                      Master_User: chaoge
                      Master_Port: 3306
                    Connect_Retry: 60
                  Master_Log_File: mysql-bin.000001
              Read_Master_Log_Pos: 1039
                   Relay_Log_File: slave-relay-bin.000002
                    Relay_Log_Pos: 537
            Relay_Master_Log_File: mysql-bin.000001
                 Slave_IO_Running: Yes
                Slave_SQL_Running: Yes
    

    tip:

    注意此处还未配置从库的只读模式,只需在slave服务器上配置/etc/my.cnf,加上以下配置,并且在slave上创建普通用户,使用普通用户主从同步即可达到只读的效果

    如果用root用户,无法达到readonly,这是一个坑

    [mysqld]
    character-set-server=utf8
    collation-server=utf8_general_ci
    log-error=/var/log/mysqld.log
    server-id=3
    read-only=true
    [client]
    default-character-set=utf8
    [mysql]
    default-character-set=utf8
  • 相关阅读:
    图形验证码---pillow
    vue富文本编辑器vue-quill-editor
    django邮件发送
    Django REST Framework JWT
    jwt验证
    使用django的用户表进行登录管理
    [转]CSRF漏洞详细说明
    Django框架10
    Django框架09
    Django框架08
  • 原文地址:https://www.cnblogs.com/konghui/p/10533669.html
Copyright © 2011-2022 走看看