首页 技术 正文
技术 2022年11月12日
0 收藏 661 点赞 3,385 浏览 2148 个字

1.    MySQL主从配置

我们的方案设计基于Mysql的主从数据复制功能,以下是基于mysql5.5以上版本最新的主从配置。

开启mysql主从数据复制,主要在mysql的my.ini文件中设置:

windows系统一般在c:\ProgrameData\MySQL中:

Linux系统一般在 /etc/my.cnf中:

mycat读写分离性能测试

1、主数据库服务器配置:

server-id=1

log-bin=mysql-bin

binlog-do-db=Industry       //只同步Industry数据库

binlog-ignore-db=mysql    //避免同步mysql用户配置,以免不必要的麻烦

binlog-ignore-db=performance_schema
binlog-ignore-db=information_schema

2创建一个允许从服务器来访问的用户(主服务器)

grant replication slave on *.* to ‘root’@’192.168.0.58’
identified by ‘root’;

说明:

  • root:Slave使用的账号
  • IDENTIFIED BY ‘root’ :Slave使用的密码
  • 192.168.1.58:Slave数据库IP

master端,通过show master
status\G 显示信息。如图:

mycat读写分离性能测试

注意上图中的File,和Position。Slave 中会用到这些信息。

3、从数据库服务器配置:

server-id=11              //服务Id,注意要和master的server-id不一样

log-bin=mysql-bin

relay-log-index=slave-relay-bin.index

relay-log=slave-relay-bin

sync_master_info=1
sync_relay_log=1
sync_relay_log_info=1

4、关联上Master信息:

change master to

master_host=’192.168.0.68′,master_user=’root’,master_port=3306,master_password=’root’,master_log_file=’mysql-bin.000001′,master_log_pos=120;

命令说明:

  • master_host:master 数据库服务器ip
  • master_user: master  数据库通过GRANT授权的账号
  • master_port:master  数据库使用的端口号
  • master_password:master  数据库通过GRANT授权的密码
  • master_log_file:master数据库中通过show master status显示的File名称
  • master_log_pos:master数据库中通过show master status显示的Position数据

重启Slave 的MySql服务

在命令行中输入start slave.

在命令行中输入show slave status,显示如下:

mycat读写分离性能测试

注意:只有Slave_IO_Running与Slave_SQL_Running都为Yes才配置成功。

至此,配置全部完成。这样,Master服务器上Industry里的数据就能同步到slave的Industry数据库中。

 

2.    主从配置的MySQL创建表方式

由于Mysql已经配置好了主从复制,在创建表时,我们要注意,在Master库中创建表后,Mysql会自动在Slave库中创建一张表。这里我们需要做的是,将从库中自动创建的表删除,然后手动创建一张我们符合我们需求的表。具体操作步骤如下:

  1. 在主库中创建表A,引擎选择Innodb;
  2. 删除从库中自动创建的表A;
  3. 在从库中创建表A,引擎选择MyISAM;

建表带sql引擎语句样例:

CREATE
TABLE table1 (
id INT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id),
name TEXT
) TYPE= InnoDB

CREATE
TABLE table1 (
id INT NOT NULL AUTO_INCREMENT,
PRIMARY KEY (id),
name TEXT
) TYPE=MyISAM

 

3.    启用Mycat的读写分离机制

最后启用Mycat的读写分离机制即可。

4.    两种模式的执行时间比照图

再多的废话也不如实际的测试来的有效,接下来,让我们实际测试利用这种方案能给我们带来多大的执行效率。

首先,在开启mycat的读写分离机制后,如下图:

mycat读写分离性能测试

此时写入库的引擎为Innodb,读库的引擎为MyISAM,这时使用count语句,执行时间如下图:

mycat读写分离性能测试

使用like条件语句执行时间如下图:

mycat读写分离性能测试

使用等于条件语句执行时间如下图:

mycat读写分离性能测试

接下来,我们取消读写分离机制,见下图:

mycat读写分离性能测试

此时只有写入库,并且引擎为Innodb,这时使用count语句,执行时间如下图:

mycat读写分离性能测试

使用like条件语句执行时间如下图:

mycat读写分离性能测试

使用等于条件语句执行时间如下图:

mycat读写分离性能测试

总体的执行时间对比表,见下图:

Sql语句

启用读写分离机制(读库使用MyISAM)

取消读写分离机制(读使用的是Innodb)

count

0.468秒

6.786秒

like

6.022秒

25.818秒

=

0.094秒

0.515秒

相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:9,495
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,909
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,741
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,496
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:8,134
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:5,298