mysql+复制root,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 /usr/local/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';

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值