Mysql数据库进阶之(分表分库,主从分离)
前言:数据库的优化是一个程序员的分水岭,作为小白我也得去提前学习这方面的数据的
(一) 三范式和逆范式
听起范式这个迟非常专业我来举个简单的栗子:
第一范式就是: 把能够关联的每条数据都拆分成一个表
第二范式就是:把能够关联的每条数据写在一个表格中去
第三范式就是:把一些重复的字段再划分多一个表来存(这样做查询数据时候只能连表来操作)给查询带来压力
逆范式就是:宁愿牺牲一些冗余的数据把所有的字段都往一个表格里面存,这样有利于提高查询速度.
(二)垂直分表和水平分表设计
1.水平分表
create table cakes
(
id int unsigned primary key auto_increment,
cakename varchar(16)
)charset=utf8 partition by range(id)(
#分表名称cake1000,范围是id=1 to id=999
partition cake1000 values less than(1000),
#分表名称cake1000,范围是id=1000 to id=1999
partition cake2000 values less than(2000)
); 说明这里通过id标识来分表,主要表格的id如果超过了规定的值就会进入下一个表格
//这个功能主要是用在表格已经生成了但是后面添加的
alter table 表名 add partition (
partition 分表名称 values less than (范围)
) //删除分表的功能
alter table 表名 drop partition 分表名称;
2.垂直分表
create table goods
(
id int unsigned comment '不能在list分表使用索引',
proname varchar(10) not null,
source varchar(20) comment '原料',
`money` varchar(10) not null,
addtime datetime not null comment '2018-03-25 11:22:33'
)charset=utf8 partition by list( month(addtime) )(
partition spring values in(3,4,5), #春季
partition summer values in(6,7,8), #夏季
partition autumn values in(9,10,11), #秋季
partition winter values in(12,1,2) #冬季
); //注意这里是以月份进行分表的,并且id这个字段不能为主键和唯一键索引
//这个功能主要是用在表格已经生成了但是后面添加的
alter table 表名 add partition (
partition 分表名称 values in (范围)
) create index normal_id on goodsYear(id); //通常都是以普通键索引来做为ID
alter table 表名 drop partition 分表名称;
(三) MySQL 的 Grant 用户授权
即:在 MySQL 中默认存在一个本地用户访问的机制,其他服务器是无法访问的另一台服务器的MySQL 数据库,是会报没有权限的
如果希望当前服务器被其他服务器访问就需要使用 Grant 用户授权技术
//授权语句
GRANT ALL PRIVILEGES ON *.* TO '授权用户名'@'被授权服务器的IP' IDENTIFIED BY '授权密码';
//立即生效
FLUSH PRIVILEGES;
//如果授权成功效果,通过命令查看mysql中的系统用户表:
select host,user from mysql.user where user=授权用户名
//测试是否能在别的服务器访问本服务器的数据库
mysql -u授权的用户名 -p授权的密码 -h访问的主机
(四)binlog 日志
show variables like 'log_bin' : 该函数主要用于查看binlog日志是否已经开启
show master status : 该函数主要查看用于Master数据库正在使用的binlog日志情况
show slave status \G: 该函数主要用于Slave数据库是否已经同步
以上函数如果不用于主从复制和读写分离的配置当中,等同没用
(五)读写分离和主从复制
1.主从首要条件:①关闭 selinux ②关闭 iptables ③ master 已经对 slave 进行 grant 授权
create database php32 charset utf8; 在 master 服务器中开启 binlog 日志和设置要发生主从同步数据库(my.cnf) #mysql的bin-log 日志配置选项,假设 做读写(主从)分离,这个选项在从服务器必须关闭 log-bin=mysql-bin #1.主服务器的id,这个 id 不一定设为 1,只要主从不一样就行 server-id=1 #2.要做同步的数据库名字,可以是多个数据库,之间用分号分割 binlog-do-db=php32 #3.保存重启mysql
service mysqld restart #4.显示状态(里面显示的数据用在从服务器使用)
show master status;
#从服务器
servir-id = 2 (这里只要和主服务器不同就行了)
#登录
mysql -uxxx -pxxx
#认证从服务器
change master to master_host='主服务器的IP地址',
master_port=3306,#端口
master_user='xxx',#主服务器授权的用户名
master_password='xxx',#主服务器授权的用户密码
master_log_file='mysql-bin.000007',#主服务器上的bin-log日志
master_log_pos=106;#主服务器上的 bin-log日志值 #启动主从服务
start slave;
stop slave; -- 停止
reset slave; -- 重置
start slave; -- 启动 #登录slave服务器中,查看show slave status\G,看到如下选项代表主从复制同步成功:
show slave status\G
最后注意:如果开发中写的操作发生slave当中,主从同步马上宣告失败,因此开发中,我们必须清楚 master 和 slave 服务器,slave 我们只是让它负责 select,但是 slave 是可以 insert 数据的,但是清楚风险所在.







Mysql数据库进阶之(分表分库,主从分离)的更多相关文章
- mysql数据库为什么要分表和分区?
一般下载的源码都带了MySQL数据库的,做个真正意义上的网站没数据库肯定不行. 数据库主要存放用户信息(注册用户名密码,分组,等级等),配置信息(管理权限配置,模板配置等),内容链接(html ,图片 ...
- efcore在Saas系统下多租户零脚本分表分库读写分离解决方案
efcore在Saas系统下多租户零脚本分表分库读写分离解决方案 ## 介绍 本文ShardinfCore版本x.6.0.20+ 本期主角: - [`ShardingCore`](https://gi ...
- 由mysql分区想到的分表分库的方案
在分区分库分表前一定要了解分区分库分表的动机. 对实时性要求比较高的场景,使用数据库的分区分表分库. 对实时性要求不高的场景,可以考虑使用索引库(es/solr)或者大数据hadoop平台来解决(如数 ...
- mysql大数据解决方案--分表分库(0)
引言 对于一个大型的互联网应用,海量数据的存储和访问成为了系统设计的瓶颈问题,对于系统的稳定性和扩展性造成了极大的问题.通过数据切分来提高网站性能,横向扩展数据层已经成为架构研发人员首选的方式. •水 ...
- sharding sphere 分表分库 读写分离
sharding jdbc: sharding sphere 的 一部分,可以做到 分表分库,读写分离. 和 mycat 不同的 是 sharding jdbc 是 一个 jdbc 驱动 在 驱动这个 ...
- mysql数据库分区和分表
转载自 https://www.cnblogs.com/miketwais/articles/mysql_partition.html https://blog.csdn.net/vbirdbest/ ...
- 什么是分表和分区 MySql数据库分区和分表方法
1.为什么要分表和分区 日常开发中我们经常会遇到大表的情况,所谓的大表是指存储了百万级乃至千万级条记录的表.这样的表过于庞大,导致数据库在查询和插入的时候耗时太长,性能低下,如果涉及联合查询的情况,性 ...
- 12-2 MySQL数据库备份(分表)
#!/bin/bash source /etc/profile DATE="$(date +%F_%H-%M-%S)" DB_IP="172.16.1.122" ...
- mycat 安装 分表 分库 读写分离
简单的 理解 一下 mycat :如图 mycat 是一个 连接数据库的中介.一个独立安装的 工具,他连接着真实的数据库,并且 把自己伪装成一个数据库. 程序连接 mycat ,mycat 连接 到真 ...
随机推荐
- MYSQL理论
1.数据库相关概念 数据库服务器(本质就是一个台计算机,该计算机之上安装有数据库管理软件的服务端) 数据库管理管理系统RDBMS(本质就是一个C/S架构的套接字软件) 库(文件夹)=====>数 ...
- topcoder SRM642 div1 hard WheelofFortune
题目链接:vjudge 大意:有两个人参加一场游戏,这个游戏在一个编号为\(0\text~n-1\)的轮盘上进行,一开始轮盘上的数字均为0:一共有\(m\)轮,每一轮都有一个操作参数\(s_i\),主 ...
- 【BZOJ3132】【TYVJ1716】上帝造题的七分钟 二维树状数组
题目大意 维护一个\(n\times m\)的矩阵,有两种操作: \(1~x_1~y_1~x_2~y_2~v\):把\((a,b),(c,d)\)为顶点的矩形区域内的所有数字加上\(v\). \(2~ ...
- DNSCrypt
DNSCrypt 来源 https://www.cnblogs.com/qiudabai/articles/9219840.html https://www.opendns.com/about/inn ...
- 对比cp和scp命令 将数据从一台linux服务器复制到另一台linux服务器
cp命令用来将一个或多个源文件或者目录复制到指定的目的文件或目录.它可以将单个源文件复制成一个指定文件名的具体的文件或一个已经存在的目录下.cp命令还支持同时复制多个文件,当一次复制多个文件时,目标文 ...
- 【CodeForces706E】Working routine(二维链表)
BUPT2017 wintertraining(15) #6B 题意 q次操作,每次把两个给定子矩阵交换,求最后的矩阵.(2 ≤ n, m ≤ 1000, 1 ≤ q ≤ 10 000) 题解 用R[ ...
- 【题解】 bzoj2462: [BeiJing2011]矩阵模板
题面戳我 Solution 二维矩阵\(hash\),判断即可 自己YY了一个方法,\(bzoj\)T到飞,(一开始还用的三\(hash\)),交到luogu貌似跑的不慢啊qwq (我是不会告诉你全输 ...
- Android热点回顾第一期
本文由 ImportNew - 陈强 翻译自 androidweekly.如需转载本文,请先参见文章末尾处的转载要求. Importnew注:欢迎Android爱好者参与翻译文中提及的教程,请私信联系 ...
- 【UVA1194】Machine Schedule
题目大意:给定 N 个任务和两台机器,每个任务可以在任意一台机器上执行,每台机器有 N 个启动状态,不同任务需要机器在不同的状态下执行,求执行所有任务需要多少个不同的状态. 题解:由于一个任务一定要被 ...
- java 8: ClassNotFoundException: sun.jdbc.odbc.JdbcOdbcDriver
转眼之间, java 11都快要推出了. 而我一直都在 java 7环境下写代码,真的不想升级,不想改变什么,可世界每天都在变化. 最近因为服务端需要SNI,而 java 7 只支持客户端的SNI,只 ...