首页 > 代码库 > MySQL同步复制
MySQL同步复制
1、安装cmake
tar zxvf cmake-2.8.11.2.tar.gz
cd cmake-2.8.11.2
./configure
make && make install
2、安装mysql
groupadd mysql
useradd -g mysql mysql
tar zxvf mysql-5.5.11.tar.gz
cd mysql-5.5.11
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql/ -DMYSQL_DATADIR=/usr/local/mysql/data -DWITH_INNOBASE_STORAGE_ENGINE=1 -DMYSQL_TCP_PORT=3306 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysql.sock -DMYSQL_USER=mysql -DWITH_DEBUG=0
make
make install
3、复制配置文件
cp support-files/my-medium.cnf /etc/my.cnf
cp support-files/mysql.server /etc/init.d/mysqld
chmod 755 /etc/init.d/mysqld
添加到开机启动
chkconfig --add mysqld
chkconfig --level 2345 mysqld on
chkconfig --list mysqld
4、添加环境变量
vi /root/.bashrc
PATH=/usr/local/mysql/bin:${PATH}
export PATH
5、修改root密码
mysql>use mysql ;
mysql>update user set password=PASSWORD("123456") where User=‘root‘;
mysql>FLUSH PRIVILEGES;
6、初始化数据库
chmod 755 /usr/local/src/mysql/scripts/mysql_install_db
./scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
7、修改mysql中data目录下的权限
chown -R mysql.mysql data
service mysqld start
8、数据的导入与导出
导入 :mysql --default-character-set=utf8 MAIN < MAIN.sql
导出 :mysqldump --default-character-set=utf8 MAIN > MAIN.sql
9、为master库添加slave用户,并设置密码和访问权限
mysql>GRANT REPLICATION SLAVE ON *.* TO root@"%" IDENTIFIED BY ‘123456‘;
10、修改slave库中my.cnf文件,添加server-id = slave主机号,重启mysqld
11、show master status;查看master是否正常,找出File和Position
+------------------+----------+--------------+------------------+
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000006 | 1051 | | |
+------------------+----------+--------------+------------------+
12、在slave库上执行
mysql>CHANGE MASTER TO MASTER_HOST=‘master ip地址‘,MASTER_USER=‘slave‘,MASTER_PASSWORD=‘slave‘,MASTER_LOG_FILE=‘master File‘,MASTER_LOG_POS=master Position;
mysql>FLUSH PRIVILEGES;
13、slave start
show slave status
14、测试同步复制
在master任一库中创建一张新表create table test (ename varchar(10));查看slave中是否同步出现此表。
15、远程备份数据库
在数据库机器上打开用户访问权限,如slave用户
mysql>GRANT ALL ON *.* TO slave@"%" IDENTIFIED BY ‘slave‘;
在本机环境上执行
mysqldump -uroot -p -h10.28.10.151 mysql > mysql.sql
问题:在启动mysql时如果不成功,一般是data目录的权限问题,还有查看my.cnf配置文件中内存分配的大小。
mysql slave Error_code: 1062
针对5.1以前的版本,使用
slave stop;
set global sql_slave_skip_counter=n; \\ n=正整数,,看你的错误有几条,就跳过几条
slave start;
针对5.1以上版本,有了变量设置了就不会出问题了,似乎比它以前的版本处理方式更人性化,不用skip.
SET GLOBAL SLAVE_EXEC_MODE = ‘IDEMPOTENT‘;
本文出自 “kimileonis” 博客,请务必保留此出处http://kimileonis.blog.51cto.com/5531747/1538418