mysql主从配置.doc_第1页
mysql主从配置.doc_第2页
mysql主从配置.doc_第3页
mysql主从配置.doc_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

mysql-master-slave Install #CreateDate:2009-02-03#LastUpdated:#Version:0.0.1#Compatible: Cent-os 5.2 Linux X64#Comment: NULL.#Format:Pure Text#By:zhangheli#在master安装的mysql版本是:5.0.51b#在slave安装的mysql版本也要是:5.0.51b或者更高#在master服务器上设置假设:master_ip:28 : slave_ip:29 grant replication slave on *.* to root29 identified by 123456;vi /opt/modules/mysql/etc/f#在mysqld下添加如下内容:server-id = 1log-bin=mysql-binbinlog-do-db=newbbsbinlog-ignore-db=testbinlog-ignore-db=mysqlbinlog-ignore-db=information_schemamax_binlog_size = 1024Mexpire-logs-days = 7binlog_cache_size = 4Mmax_binlog_cache_size = 512M#在slave服务器上设置:vi /opt/modules/mysql/etc/f#在mysqld下添加如下内容:server-id = 2log-bin=mysql-binmaster-host=28master-user=rootmaster-password=123456master-port=3306replicate-do-db=newbbsmaster-connect-retry=30#分别重启主从服务器reboot#在slave使用如下命令测试/opt/modules/mysql/bin/mysql -uroot -p123456mysqlslave startmysqlshow slave status#看到有下面三项相同就成功:Slave_IO_State: Waiting for master to send eventSlave_IO_Running: YesSlave_SQL_Running: Yes#进行测试#在master插入几条语句,insert into student values (,zhangsan);#在slave上查看select * from student;*#同步数据新方法在主数据库上添加grant super,reload on *.* to root28 identified by 123456;mysqlload data from master;就可以把主数据同步过来*#常见问题处理补充:在从服务器上使用show slave statusSlave_IO_Running,为No,则说明IO_THREAD没有启动,请执行slave start IO_THREADSlave_SQL_Running为No则复制出错,查看Last_error字段排除错误后执行slave start SQL_THREAD查看Slave_IO_State字段空 /复制没有启动Connecting to master/没有连接上masterWaiting for master to send event/已经连上补充:可以使用LOAD DATA FROM MASTER语句来建立slave。但有约束条件:数据表要全部是MyISAM表,必须有SUPER权限,master的复制用户必须具备RELOAD和SUPER权限。在master端执行RESET MASTER清除已有的日志变更,此时slave端会因为找不到master日志无法启动IO_THREAD,请清空data目录下,hosname-relay-bin*等文件重新启动mysql中继日志文件默认的文件为hostname-relay-bin.nnn和hostname-relay-bin.index。可用从服务器的relay-log和relay-log-index选项修改。在从服务器中还有一个中继信息文件,可用relay-log-info-file启动选项修改文件名。双机互备则是两个mysql同时配置为master及slave主服务器上的相关命令:show master statusshow slave hostsshow logsshow binlog eventspurge logs to log_namepurge logs before datereset master(老版本flush master)set sql_log_bin=从服务器上的相关命令:slave startslave stopSLAVE STOP IO_THREAD /此线程把master段的日志写到本地SLAVE start IO_THREADSLAVE STOP SQL_THREAD /此线程把写到本地的日志应用于数据库SLAVE start SQL_THREADreset slaveSET GLOBAL SQL_SLAVE_SKIP_COUNTERload data from mastershow slave status(SUPER,REPLICATION CLIENT)CHANGE MASTER TO MASTER_HOST=, MASTER_PORT=,MASTER_USER=, MASTER_PASSWORD= /动态改变master信息PURGE MASTER before date 删除master端已同步过的日志*几个跟热备有关的mysql命令:(需要在mysql命令行界面或query )stop slave #停止同步 start slave #开始同步,从日志终止的位置开始更新。 SET SQL_LOG_BIN=0|1 #主机端运行,需要super权限,用来开停日志,随意开停,会造成主机从机数据不一致,造成错误 SET GLOBAL SQL_SLAVE_SKIP_COUNTER=n # 客户端运行,用来跳过几个事件,只有当同步进程出现错误而停止的时候才可以执行。 RESET MASTER #主机端运行,清除所有的日志,这条命令就是原来的FLUSH MASTER RESET SLAVE #从机运行,清除日志同步位置标志,并重新生成虽然重新生成了,但是并不起用,最好,将从机的mysql进程重启一下, LOAD TABLE tblname FROM MASTER #从机运行,从主机端重读指定的表的数据,每次只能读取一个,受timeout时间限制,需要调整timeout时间。执行这个命令需要同步账号有reload和super权限。以及对相应的库有select权限。如果表比较大,要增加net_read_timeout 和 net_write_timeout的值 LOAD DATA FROM MASTER #从机执行,从主机端重新读入所有的数据。执行这个命令需要同步账号有reload和super权限。以及对相应的库有select权限。如果表比较大,要增加net_read_timeout 和 net_write_timeout的值 CHANGE MASTER TO master_def_list #在线改变一些主机设置,多个用逗号间隔,比如CHANGE MASTER TO MASTER_HOST=, MASTER_USER=replication, MASTER_PASSWORD=bigs3cret MASTER_POS_WAIT() #从机运行 SHOW MASTER STATUS #主机运行,看日志导出信息 SHOW SLAVE HOSTS #主机运行,看连

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论