目录python
MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL受权许可。mysql
开发这个分支的缘由之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,所以社区采用分支的方式来避开这个风险。linux
MariaDB的目的是彻底兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。sql
1.在线下载阿里云的 yum 仓库,以及epel仓库数据库
CentOS-Base.repo epel.repo
2.安装mysql的方式django
yum install mysql-server mysql -y
3.安装mysql的方式也有2种,阿里云官方提供的mariadb软件包,版本可能过低,可是下载网速很快,方便学习使用vim
4.在企业里面,多半不会使用阿里云的mariadb版本,由于版本过低,安全性过低,公司会配置myariadb官方的yum仓库centos
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;
1.navicat 2.cmd mysql -uroot -p -h 192.168.15.53 3.pycharm 4.pymysql python 5.orm django
受权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数据库的主从复制方案,是其自带的功能,而且主从复制并非复制磁盘上的数据库文件,而是经过binlog日志复制到须要同步的从服务器上。
MySQL数据库支持单向、双向、链式级联,等不一样业务场景的复制。在复制的过程当中,一台服务器充当主服务器(Master),接收来自用户的内容更新,而一个或多个其余的服务器充当从服务器(slave),接收来自Master上binlog文件的日志内容,解析出SQL,从新更新到Slave,使得主从服务器数据达到一致。
主从复制的逻辑有如下几种
主从机制实现原理:
(1) master将改变记录到二进制日志(binary log)中(这些记录叫作二进制日志事件,binary log events); (2) slave将master的binary log events拷贝到它的中继日志(relay log); (3) slave重作中继日志中的事件,将改变反映它本身的数据。
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/
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 status\G 当你检查这2条参数,yes的时候,主从ok Slave_IO_Running: Yes Slave_SQL_Running: Yes
此时解锁主库!!
此时解锁主库!! unlock tables
此时解锁主库!!
验证主从同步是否正常
检查主从复制是否成功的关键在于
MariaDB [(none)]> show slave status\G *************************** 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