MySQL支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。主服务器将更新写入二进制日志文件,并维 护日志文件的一个索引以跟踪日志循环。当一个从服务器连接到主服务器时,它通知主服务器从服务器在日志中读取的最后一次成功更新的位置。从服务器接收从那 时起发生的任何更新,然后封锁并等待主服务器通知下一次更新。
为什么使用主从复制?
1、主服务器/从服务器设置增加了健壮性。主服务器出现问题时,你可以切换到从服务器作为备份。
2、通过在主服务器和从服务器之间切分处理客户查询的负荷,可以得到更好的客户响应时间。但是不要同时在主从服务器上进行更新,这样可能引起冲突。
3、使用复制的另一个好处是可以使用一个从服务器执行备份,而不会干扰主服务器。在备份过程中主服务器可以继续处理更新。
MySQL使用3个线程来执行复制功能(其中1个在主服务器上,另两个在从服务器上。当发出START SLAVE时,从服务器创建一个I/O线程,以连接主服务器并让主服务器发送二进制日志。主服务器创建一个线程将二进制日志中的内容发送到从服务器。从服 务器I/O线程读取主服务器Binlog Dump线程发送的内容并将该数据拷贝到从服务器数据目录中的本地文件中,即中继日志。第3个线程是SQL线程,从服务器使用此线程读取中继日志并执行日 志中包含的更新。SHOW PROCESSLIST语句可以查询在主服务器上和从服务器上发生的关于复制的信息。
默认中继日志使用host_name-relay-binnnnnnn形式的文件名,其中host_name是从服务器主机名,nnnnnn是序 列号。用连续序列号来创建连续中继日志文件,从000001开始。从服务器跟踪中继日志索引文件来识别目前正使用的中继日志。默认中继日志索引文件名为 host_name-relay-binindex。在默认情况,这些文件在从服务器的数据目录中被创建。中继日志与二进制日志的格式相同,并且可以用 mysqlbinlog读取。当SQL线程执行完中继日志中的所有事件后,中继日志将会被自动删除。
从服务器在数据目录中另外创建两个状态文件--masterinfo和relay-loginfo。状态文件保存在硬盘上,从服务器关闭时不会丢失。下次从服务器启动时,读取这些文件以确定它已经从主服务器读取了多少二进制日志,以及处理自己的中继日志的程度。
设置主从复制:
1、确保在主服务器和从服务器上安装的MySQL版本相同,并且最好是MySQL的最新稳定版本。
2、在主服务器上为复制设置一个连接账户。该账户必须授予REPLICATION SLAVE权限。如果账户仅用于复制(推荐这样做),则不需要再授予任何其它权限。
mysql> GRANT REPLICATION SLAVE ON
-> TO 'replication'@'%yourdomaincom' IDENTIFIED BY 'slavepass';
3、执行FLUSH TABLES WITH READ LOCK语句清空所有表和块写入语句:
mysql> FLUSH TABLES WITH READ LOCK;
保持mysql客户端程序不要退出。开启另一个终端对主服务器数据目录做快照。
shell> cd /usr/local/mysql/
shell> tar -cvf /tmp/mysql-snapshottar /data
如果从服务器的用户账户与主服务器的不同,你可能不想复制mysql数据库。在这种情况下,应从归档中排除该数据库。你也不需要在归档中包括任何日志文件或者masterinfo或relay-loginfo文件。
当FLUSH TABLES WITH READ LOCK所置读锁定有效时(即mysql客户端程序不退出),读取主服务器上当前的二进制日志名和偏移量值:
mysql > SHOW MASTER STATUS;
+---------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+---------------+----------+--------------+------------------+
| mysql-bin003 | 73 | test | manual,mysql |
+---------------+----------+--------------+------------------+
File列显示日志名,而Position显示偏移量。在该例子中,二进制日志值为mysql-bin003,偏移量为73。记录该值。以后设置从服务器时需要使用这些值。它们表示复制坐标,从服务器应从该点开始从主服务器上进行新的更新。
如果主服务器运行时没有启用--logs-bin,SHOW MASTER STATUS显示的日志名和位置值为空。在这种情况下,当以后指定从服务器的日志文件和位置时需要使用的值为空字符串('')和4
取得快照并记录日志名和偏移量后,回到前一中端重新启用写活动:
mysql> UNLOCK TABLES;
4、确保主服务器主机上mycnf文件的[mysqld]部分包括一个log-bin选项。该部分还应有一个server-id=Master_id选项,其中master_id必须为1到232–1之间的一个正整数值。例如:
[mysqld]
log-bin
server-id=1
如果没有提供那些选项,应添加它们并重启服务器。
5、停止从服务器上的mysqld服务并在其mycnf文件中添加下面的行:
[mysqld]
server-id=2
slave_id值同Master_id值一样,必须为1到232–1之间的一个正整数值。并且,从服务器的ID必须与主服务器的ID不相同。
6、将数据备据目录中。确保对这些文件和目录的权限正确。服务器 MySQL运行的用户必须能够读写文件,如同在主服务器上一样。
Shell> chown -R mysql:mysql /usr/local/mysql/data
7、启动从服务器。在从服务器上执行下面的语句,用你的系统的实际值替换选项值:
mysql> CHANGE MASTER TO
-> MASTER_HOST='master_host_name',
-> MASTER_USER='replication_user_name',
-> MASTER_PASSWORD='replication_password',
-> MASTER_LOG_FILE='recorded_log_file_name',
-> MASTER_LOG_POS=recorded_log_position;
8、启动从服务器线程:
mysql> START SLAVE;
执行这些程序后,从服务器应连接主服务器,并补充自从快照以来发生的任何更新。
9、如果出现复制错误,从服务器的错误日志(HOSTNAMEerr)中也会出现错误消息。
10、从服务器复制时,会在其数据目录中发现文件masterinfo和HOSTNAME-relay-loginfo。从服务器使用这两个文 件跟踪已经处理了多少主服务器的二进制日志。不要移除或编辑这些文件,除非你确切知你正在做什么并完全理解其意义。即使这样,最好是使用CHANGE MASTER TO语句。
用来查询语句时返回前几条或者中间某一行数据。
具体用法:
select from table [offset,] rows | rows OFFSET offsetlimit子句可以用于强制select语句返回制定的记录数,limit接受一个或两个数字的参数,如果给定两个参数第一个指定返回记录行的偏移量,第二个指定返回记录行的最大数目。
where子句设置了搜索条件 它在insert update delete语句中的应用方法也与在select语句中的应用方法完全相同 搜索条件紧跟在关键词where的后面 如果用户要在语句中使用多个搜索条件 则可用and或or连接 搜索条件的基本语法是[not] expression parison_operator expression;[not] expression [not] like match_string ;[not] expression is [not] null;[not] expression [not] beeen expression and expression;[not] column_name join_operator column_name;[not] boolean_expression
and 用来联结两个条件 并在两个条件都是TRUE的时候返回结果 当在同一语句中使用多个逻辑运算符时 and运算符总是最优先 除非用户用括号改变了运算顺序
or 用来联结两个条件 当两个条件中有任一条件是TRUE的时候返回结果 当在同一语句中使用多个逻辑运算符时 运算符or通常在运算符and之后进行运算 当然用户可以使用括号改变运算的顺序
beeen 用来标识范围下限的关键词 and后面跟范围上限的值 范围where @val beeen x and y包含首尾值 如果beeen后面指定的第一个值大于第二个值 则该查询不返回任何行
column_name 在比较中使用的列名 在会产生歧义时 一定要指明列所在的表名
parison_operator 比较运算符 见下表
Word WRAP: break word bgColor=#f f f > 以下是引用片段 符号 意义 = 等于 > 大于 < 小于 >= 大于等于 <= 小于等于 != 不等于 <> 不等于
在比较char varchar型 数据 时 < 的意思是更接近字母表头部 > 代表更接近字母表尾部 一般来说 小写字母大于大写字母 大写字母大于数字 但是这可能依赖于 服务器 上 *** 作系统 的比较顺序
在比较时 末尾的空格是被忽略的 例如 Dirk 等于 Dirk
在比较日期时 < 表示早于 > 表示晚于
在使用比较运算符比较character和datetime数据时 需用引号将所有数据引起来
expression 可能是列名 常数 函数或者是列名或常数的任意组合 以及以算术运算符或逐位运算符连接的函数 算术运算符如下表所示
以下是引用片段 符号 意义 + 加号 减号 乘号 / 除号
is null 在搜索一个NULL值时使用
like 关键词 对char varchar和datetime(不包括秒和毫秒)可以使用like 在 MySQL 中like也可以用在数字的表达式上
当用户在搜索datetime型 数据 时 最好是使用关键词like 因为完整的datetime记录包含各种各样的日期组件 例如用户在列arrival_time中加入一个值 : 而子句where arrival_time= : 却没有发现它 因为MySQL把录入的数据转换成了 Jan : AM 然而子句where arrival_time like % : % 就能找到它
boolean_expression 返回 true 或 false 值的表达式
match_string 由字符和通配符组成的串 用单引号或双引号引起来 是匹配模式 通配符如下表所示
Word WRAP: break word bgColor=#f f f > 以下是引用片段 符号 意义 % 或多个字符的字符串 _ 任何一单个字符 not 否定任何逻辑表达式 或是关键词 如like null beeen等 group by和having子句在select语句中使用 可以将表划分成组并返回匹配having子句条件的组 语法 select语句开头 group by [all] aggregate_free_expression [ aggregate_free_expression] [having search_conditions]
select语句结尾
group by 指定表将划分的组群 如果在select表项中包含集合函数 则为各组计算一个总计值 这些总计值的结果以新的列显示 而不是新的行 在having子句中用户可以引用这些新的总计列 在group by之前的select_list中可以使用avg count max min和sum等集合函数 表可以被任意列的组合分组
all 在结果中包含所有组群的Transact SQL扩展 这里的所有组群甚至包括那些被where子句所排除的组群 如果同时使用having子句 将对all的意义进行否定
aggregate_free_expression 不包含集合函数的表达式 Transact SQL扩展允许在用列名称分组的同时 用无集合函数的表达式分组
having 为group by子句设置条件 类似于where为select语句设置条件的方法 having的查找条件可以包括集合函数表达式 除此之外 它的查找条件与where查找条件相同
order by 按列排列结果 对select输出的列可以用列名 列别名或列位置来引用 例如 select id as myid name as myname from mytable group by id select id as myid name as myname from mytable group by myid select id as myid name as myname from mytable group by 这三句是完全等价的 当然 我们不赞成用第三种用法 这将给程序的可读性带来不好的影响 为了以降序排列 把DESC关键词加到order by子句中你要排序的列名前 缺省是升序 你也可以用ASC关键词明确指定
limit 子句 用来限制select语句返回的行数 limit取 个或 个数字参数 如果给定 个参数 第一个指定要返回的第一行的偏移量 第二个指定返回行的最大数目 初始行的偏移量是 (不是 ) 如果给定一个参数 它指出偏移量为 的返回行的最大数目 也就是说limit 和limit 完全等价
至于procedure关键词的含义 我也没搞得太清楚 好象是对存储过程的支持 而MySQL本身不支持存储过程 看来是为了将来扩充的需要而保留的吧
lishixinzhi/Article/program/MySQL/201311/29617
当业务上按照月份分表,但是前端h5需要分页展示,小伙伴们不知有没有遇到这个这个需求最后怎么完成的。
我这里想了一个解决思路,可能还不完善,希望能抛转引玉。
1、入参pageNo 为页号码,如果为1那么就是第一页。pageSize 可以是入参也可定死,这里定死10条。Limit 是数据偏移标记,根据入参pageNo 计算出来的,Limit=(pageNo-1)pageSize。假设A表有41条数据符合,B表有51条数据符合,如下图。
有几种种情况 1如果limit<A表41条 那么需要从A表中取数据,(1)如果Limit+pageSize<Count直接获取数据即可(2)如果Limit+pageSize>Count,那么需要从A 表取部分数据从B表取一部分数据。
1如果limit>A表41条 那么需要从B表取数据,如果B数据依然不足,那么重复以上的步骤。如下图
以上就是关于如何配置MySQL数据库主从复制全部的内容,包括:如何配置MySQL数据库主从复制、MYSQL中LIMIT用法是什么、快速掌握MySQL数据库中SELECT语句[2]等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)