Linux下安装Mysql多实例作为数据备份服务器实现多主到一从多实例的备份

  • A+
所属分类:数据库

由于第一次接触LINUX,花了三天时间才算有所成就,发出来希望可以给大伙带来方便
1、从MYSQL官方下载MYSQL的源码版本【一定要是源码版本】
2、按以下代码键入LINUX命令行

  1. [注] 添加mysql组和用户
  2. #groupadd mysql
  3. #useradd -g mysql mysql
  4. [注] 解包到/usr/local
  5. # tar -xzf mysql-standard-4.1.9-pc-linux-gnu-i686.tar.gz -C /usr/local
  6. [注] 建立软链接,方便操作(此处给此连接命名为mysql001,也可为其它的名字)
  7. #cd /usr/local
  8. #ln -s mysql-standard-5.0.15-linux-i686-glibc23 mysql001
  9. #cd mysql001
  10. #scripts/mysql_install_db
  11. #chown -R root .
  12. #chown -R mysql data
  13. #chgrp -R mysql .
  14. [注] 复制data,以供单版本多实例分配
  15. #cp -a data data_1
  16. #cp -a data data_2
  17. [注] 添加多实例配置文件
  18. #cd /usr/local/mysql001/bin
  19. #cat >my_multi.cnf
  20. [注] 以下是my_multi.cnf的配置信息,可依此复制
  21. [mysqld_multi]
  22. mysqld = /usr/local/mysql001/bin/mysqld_safe
  23. mysqladmin = /usr/local/mysql001/bin/mysqladmin
  24. user = root
  25. password = root
  26. [mysqld1]
  27. socket = /tmp/mysql_001.sock
  28. port = 3301
  29. pid-file = /usr/local/mysql001/data_1/hostname.pid
  30. datadir = /usr/local/mysql001/data_1
  31. log = /usr/local/mysql001/data_1/hostname.log
  32. user = mysql
  33. # slave setting
  34. server-id = 2
  35. master-host = 192.168.1.85
  36. master-port = 3306
  37. master-user = backup
  38. master-password = 123456
  39. replicate-do-db = gs_database
  40. replicate-do-db = gs_log
  41. master-connect-retry=30
  42. [mysqld2]
  43. socket = /tmp/mysql_5_2.sock
  44. port = 3302
  45. pid-file = /usr/local/mysql001/data_2/hostname.pid
  46. datadir = /usr/local/mysql001/data_2
  47. log = /usr/local/mysql001/data_2/hostname.log
  48. user = mysql
  49. # slave setting
  50. server-id = 3
  51. master-host = 192.168.1.69
  52. master-port = 3306
  53. master-user = backup
  54. master-password = 123
  55. replicate-do-db = gs_databaes
  56. replicate-do-db = gs_log
  57. master-connect-retry=30

CTRL+D退出。

  1. #vi /etc/profile # 添加系统环境变量。
  2. export MYSQL_HOME=/usr/local/mysql001/bin
  3. export PATH=$PATH:$MYSQL_HOME

重启系统让环境变量生效。
添加至开机自动启动【此处可不添加,依个人情况决定是否需要设置开机自动启动】

  1. vi /etc/rc.local
  2. # 添加
  3. mysqld_multi --defaults-extra-file=/usr/local/src/mysql_dir/bin/my_multi.cnf start 1,2

3、其它一些技巧
# 访问某个实例:
mysql -u root -S /tmp/mysql_5_1.sock -p

# 设置各个实例密码:
mysqladmin -u root password 'root' -S /tmp/mysql_5_1.sock

# 手动启动各个实例:
mysqld_multi --defaults-extra-file=/usr/local/src/mysql_dir/bin/my_multi.cnf start 1,2

# 停止各个实例:
mysqld_multi --defaults-extra-file=/usr/local/src/mysql_dir/bin/my_multi.cnf stop 1,2

# 参考文章
http://blog.liuts.com/post/13/

由于第一次接触LINUX,花了三天时间才算有所成就,发出来希望可以给大伙带来方便

图片引用自网络