- 921. Minimum Add to Make Parentheses Valid 使括号有效的最少添加
- 915. Partition Array into Disjoint Intervals 分割数组
- 932. Beautiful Array 漂亮数组
- 940. Distinct Subsequences II 不同的子序列 II
一个主机 m1 用于处理所有写请求,它的从机 s1 和另一台主机 m2 还有它的从机 s2 负责所有读请
求。当m1 主机宕机后,m2 主机负责写请求,m1、m2 互为备机。
角色地址
master1 192.168.199.231
slave1 192.168.199.185
master2 192.168.199.120
slave2 192.168.199.174
注意:在一主一从基本上需要删除testdb以及恢复从机
mater1配置
修改/etc/my.cnf文件
#主服务器唯一ID
server-id=1
##启用二进制日志
log-bin=mysql-bin
## 设置不要复制的数据库(可设置多个)
binlog-ignore-db=mysql
##binlog-ignore-db=information_schema
##设置需要复制的数据库
binlog-do-db=testdb
##设置logbin格式
binlog_format=STATEMENT
新加配置
# 在作为从数据库的时候,有写入操作也要更新二进制日志文件
log-slave-updates
#表示自增长字段每次递增的量,指自增字段的起始值,其默认值是1,取值范围是1 .. 65535
auto-increment-increment=2
## 表示自增长字段从哪个数开始,指字段一次递增多少,他的取值范围是1 .. 65535
auto-increment-offset=1
master2配置
/etc/my.cnf
#主服务器唯一ID
server-id=3
#启用二进制日志
log-bin=mysql-bin
# 设置不要复制的数据库(可设置多个)
binlog-ignore-db=mysql
binlog-ignore-db=information_schema
#设置需要复制的数据库
binlog-do-db=testdb
##设置logbin格式
binlog_format=STATEMENT
## 在作为从数据库的时候,有写入操作也要更新二进制日志文件
log-slave-updates
##表示自增长字段每次递增的量,指自增字段的起始值,其默认值是1,取值范围是1 .. 65535
auto-increment-increment=2
## 表示自增长字段从哪个数开始,指字段一次递增多少,他的取值范围是1 .. 65535
auto-increment-offset=2
slave1配置
#从服务器唯一ID
server-id=2
##启用中继日志
relay-log=mysql-relay
slave2配置
#从服务器唯一ID
server-id=4
#启用中继日志
relay-log=mysql-relay
1、配置好哦之后进行mysql服务的重启
2、关闭防火墙
3、在两台主机上建立帐户并授权 slave
#在主机MySQL里执行授权命令
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' IDENTIFIED BY '123123';
查看主机master1状态
mysql> show master status
-> ;
+------------------+----------+--------------+------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000010 | 120 | testdb | mysql | |
+------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)
查询 Master2的状态
mysql> show master status
-> ;
+------------------+----------+--------------+--------------------------+-------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+--------------------------+-------------------+
| mysql-bin.000002 | 120 | testdb | mysql,information_schema | |
+------------------+----------+--------------+--------------------------+-------------------+
1 row in set (0.00 sec)
#分别记录下File和Position的值
#执行完此步骤后不要再操作主服务器MYSQL,防止主服务器状态值变化
在两台主机创建slave
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' IDENTIFIED BY '123123';
④、在从机上配置需要复制的主机
slave1·
mysql> CHANGE MASTER TO MASTER_HOST='192.168.199.231',
-> MASTER_USER='slave',
-> MASTER_PASSWORD='123123',
-> MASTER_LOG_FILE='mysql-bin.000010',MASTER_LOG_POS=120;
Query OK, 0 rows affected, 2 warnings (0.01 sec)
mysql> start slave;
Query OK, 0 rows affected (0.01 sec)
slave2
mysql> CHANGE MASTER TO MASTER_HOST='192.168.199.120',
->MASTER_USER='slave',
->MASTER_PASSWORD='123123',
->MASTER_LOG_FILE='mysql-bin.000002',MASTER_LOG_POS=120;
Query OK, 0 rows affected, 2 warnings (0.03 sec)
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
此时master1和slave1,master2和slave2的主从复制搭建完成
⑤、两个主机互相复制
master1和master2互备主从赋值
master1执行(即连接master2的主机IP地址)
mysql> CHANGE MASTER TO MASTER_HOST='192.168.199.120',
->MASTER_USER='slave',
->MASTER_PASSWORD='123123',
->MASTER_LOG_FILE='mysql-bin.000002',MASTER_LOG_POS=120;
Query OK, 0 rows affected, 2 warnings (0.05 sec)
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
master2执行(即连接master1的主机IP地址)
mysql> CHANGE MASTER TO MASTER_HOST='192.168.199.231',
-> MASTER_USER='slave',
-> MASTER_PASSWORD='123123',
-> MASTER_LOG_FILE='mysql-bin.000010',MASTER_LOG_POS=120;
Query OK, 0 rows affected, 2 warnings (0.07 sec)
mysql> start slave;
Query OK, 0 rows affected (0.00 sec)
⑥、Master1 主机新建库、新建表、insert 记录,Master2 和从机复制
创建数据库
master1
mysql> create database testdb;
Query OK, 1 row affected (0.00 sec)
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| metastore |
| mysql |
| performance_schema |
| test |
| testdb |
+--------------------+
6 rows in set (0.00 sec)
slave2
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| metastore |
| mysql |
| performance_schema |
| test |
| testdb |
+--------------------+
6 rows in set (0.00 sec)
master2
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| metastore |
| mysql |
| performance_schema |
| test |
| testdb |
+--------------------+
6 rows in set (0.01 sec)
slave2
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| metastore |
| mysql |
| performance_schema |
| test |
| testdb |
+--------------------+
6 rows in set (0.00 sec)
创建表以及插入数据
master1
mysql> use testdb;
Database changed
mysql> create table tbl(id int,name varchar(40));
Query OK, 0 rows affected (0.03 sec)
mysql> insert into tbl values (1,'mrchengs');
Query OK, 1 row affected (0.00 sec)
slave1
mysql> use testdb;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
+------+----------+
1 row in set (0.00 sec)
master2
mysql> use testdb;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
+------+----------+
1 row in set (0.00 sec)
slave2
mysql> use testdb;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
+------+----------+
1 row in set (0.00 sec)
1、、修改schema.xml配置文件
配置项说明
#balance="1": 全部的readHost与stand by writeHost参与select语句的负载均衡。
# writeType="0": 所有写操作发送到配置的第一个writeHost, 第一个挂了切到还生存的第二个
# writeType="1",所有写操作都随机的发送到配置的 writeHost,1.5 以后废弃不推荐
# writeHost,重新启动后以切换后的为准,切换记录在配置文件中:dnindex.properties 。
# switchType=
1: 1 默认值,自动切换。
-1 表示不自动切换
2 基于 MySQL 主从同步的状态决定是否切换。
2、、启动mycat
3、、验证读写分离
在master1上执行插入语句
INSERT INTO mytbl VALUES(3,@@hostname);
mysql> select * from tbl;
+------+-----------------------+
| id | name |
+------+-----------------------+
| 1 | mrchengs |
| 3 | localhost.localdomain |
+------+-----------------------+
2 rows in set (0.01 sec)
slave2
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat03 |
+------+----------+
2 rows in set (0.00 sec)
master2
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat04 |
+------+----------+
2 rows in set (0.00 sec)
slave2
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat05 |
+------+----------+
2 rows in set (0.00 sec)
④、登陆mycat
[root@ddkk.com ~]# mysql -umycat -p123456 -P 8066 -h 192.168.199.217
进行验证读写分离
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat04 |
+------+----------+
2 rows in set (0.00 sec)
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat03 |
+------+----------+
2 rows in set (0.00 sec)
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat05 |
+------+----------+
2 rows in set (0.07 sec)
⑤、 高可用下的抗风险能力(高可用)
关闭master1查询在配置文件中配置是否进行切换写主机数据库
[root@ddkk.com ~]# systemctl stop mysql
[root@ddkk.com ~]# systemctl status mysql
● mysql.service - LSB: start and stop MySQL
Loaded: loaded (/etc/rc.d/init.d/mysql; bad; vendor preset: disabled)
Active: inactive (dead) since Thu 2020-02-13 20:15:06 CST; 8s ago
Docs: man:systemd-sysv-generator(8)
Process: 1632 ExecStop=/etc/rc.d/init.d/mysql stop (code=exited, status=0/SUCCESS)
Process: 1070 ExecStart=/etc/rc.d/init.d/mysql start (code=exited, status=0/SUCCESS)
Feb 13 19:18:32 localhost.localdomain systemd[1]: Starting LSB: start and stop MySQL...
Feb 13 19:18:33 localhost.localdomain mysql[1070]: Starting MySQL SUCCESS!
Feb 13 19:18:33 localhost.localdomain systemd[1]: Started LSB: start and stop MySQL.
Feb 13 20:14:50 localhost.localdomain systemd[1]: Stopping LSB: start and stop MySQL...
Feb 13 20:15:06 localhost.localdomain mysql[1632]: Shutting down MySQL.............. SUCCESS!
Feb 13 20:15:06 localhost.localdomain systemd[1]: Stopped LSB: start and stop MySQL.
mycat客户端中执行插入代码
mysql> INSERT INTO tbl VALUES(100,@@hostname);
Query OK, 1 row affected, 1 warning (0.15 sec)
启动master1进行查看数据、
mysql> select * from tbl;
+------+-----------------------+
| id | name |
+------+-----------------------+
| 1 | mrchengs |
| 3 | localhost.localdomain |
| 100 | localhost.localdomain |
+------+-----------------------+
3 rows in set (0.00 sec)
在mycat上进行查询
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat05 |
| 100 | mycat05 |
+------+----------+
3 rows in set (0.00 sec)
mysql> select * from tbl;
+------+-----------------------+
| id | name |
+------+-----------------------+
| 1 | mrchengs |
| 3 | localhost.localdomain |
| 100 | localhost.localdomain |
+------+-----------------------+
3 rows in set (0.00 sec)
mysql> select * from tbl;
+------+----------+
| id | name |
+------+----------+
| 1 | mrchengs |
| 3 | mycat03 |
| 100 | mycat03 |
+------+----------+
3 rows in set (0.00 sec)
此时master1成为读主机
此时master2成为写主机
我用 chown 不行。 Bilals-MBP:~ $ sudo mkdir -p /data/db Password: mkdir: /data/db: Read-only file system
我陷入了一个非常简单的问题。 我正在尝试制作一个Qt GUI应用程序以从GUI控制我的Arduino(而不是从Arduino IDE的串行监视器控制它)。我能够使用QSerialPort write(
我正在尝试使用 Win32 的 CreateFile 函数打开一个 COM 端口。我已经在 MSDN 以及几个论坛上阅读了有关如何执行此操作的文档,但无论我做什么,我仍然收到错误代码 #2(端口不存在
我正在尝试使用系统调用 read() 和 write()。以下程序创建一个文件并将一些数据写入其中。这是代码.. int main() { int fd; open("stud
我对 Xcode 和 sqlite 有点陌生。现在我有一个名为“mydb.db”的数据库文件,它已经有一些表和数据。我把它放在我的 mac 文件夹中,然后将它拖到“支持文件”下的 Xcode 项目中。
背景:如果需要,请跳至问题部分 我正在研究测试设备的前端。前端的目的是为了更容易编写长测试脚本。几乎只是让它们更易读和可写。 设备将使用 Prologix GPIB-USB Controller 进行
本文实例讲述了python文件常见操作。分享给大家供大家参考,具体如下: 1.文件是什么? 文件是存储在外部介质上的数据或信息集合,程序中源程序、数据中保存的数据、图像中的像素数据等等; 文件
C++0x 指定 std::atomic线程安全原子访问变量的模板。这个模板有一个成员函数 std::atomic::exchange原子地在“this”中存储一个新值并检索“this”的现有值。 W
VBA 中是否有任何方法可以读取和写入 INI 文件?我知道我可以使用; Open "C:\test.ini" For Input As #1 ...并解析数据。相反,我试图查看已有哪些工具可用。 我
我最近在 GitHub 存储库 system-design-primer 上看到了系统设计示例,它显示了读/写 API。我正在尝试实现 this one 以进行练习。大纲是这样的。 它分离了读写API
我在使用 DEVMODE 结构的 dmColor 字段时遇到问题。 我的默认打印机是彩色打印机,如果我通过控制面板将打印机属性的颜色默认输出为黑白,则 DEVMODE.dmColor 字段始终返回 D
我知道套接字等如何与 java/android 配合使用,但是如何使用 java 或 python 连接到桌面上的 COM 端口?您想使用地址吗?或者查找您想要的端口是否可用或者什么? 我不知道该怎么
什么构成 DynamoDB 中的实际读取? 它是读取表格中的每一行还是返回什么数据? 这就是扫描如此昂贵的原因 - 您读取整个表格并为读取的每一行表格付费吗? 能否将 ElasticCache (Me
我想用Java编写一个程序来检查src是否存在(如果不抛出FileNoot的话) 并将src.txt的内容复制到des.txt 并在开头和结尾处打印两个文件的大小 输出为: src.txt is in
我在 C++ 中有一个 float 数组,我想将它保存到一个二进制文件中(以节省空间),以便以后能够再次读取它。为此,我编写了以下代码来编写数组: float *zbuffer = new float
我试图为 websocket 创建一个 Read\Write 函数,但我遇到了一个问题...... var inarrivo = 0; var risposta = ""; function RDW_
在我的应用程序中是用 Qt 编写的,我有一个 QGraphicsScene。在这个 QgraphicsScene 中有一个图像和一些由用户绘制的项目。我想保存这个包含所有内容的 QgraphicsSc
我正在编写一个程序,该程序应该无限期运行并保持变量的值。其他两个程序可以更改变量的值。我使用命名管道接收变量值并将其发送到外部程序。 这是我的变量管理器代码。 manager.c: #includ
我和一位老师谈过,他告诉我读写系统调用使用缓冲区,因为在你的系统规范中有一个变量控制你可以访问你想要读/写的设备的次数on,系统在他等待写入设备时使用buffer来存储数据。 我在另一篇 Stack
我运行一个方法,有三个部分,第 1 部分和第 3 部分都是“读取文本文件”, 第二部分是将字符串保存到文本文件, // The Save Path is the text file's Path, u
我是一名优秀的程序员,十分优秀!