设为首页 收藏本站
查看: 688|回复: 0

[经验分享] 5.MySQL Cluster(MySQL集群)

[复制链接]
发表于 2018-9-28 13:29:04 | 显示全部楼层 |阅读模式
5.1 MySQL Cluster 简介
  请参考官方文档:http://dev.mysql.com/doc/refman/5.1/zh/ndbcluster.html
  下面是官方的MySQL Cluster 的基本架构图:

5.2 MySQL Cluster环境搭建
  搭建MySQL Cluster至少需要三个节点,一个管理节点来实现管理功能,一个SQL节点主机来实现MySQL server功能,一个ndb节点主机实现NDB Cluster的功能。
  5.2.1  实验环境
  主机名
  IP地址
  作用
  MySQL-SQL-Node1
  192.168.140.128
  SQL 节点服务器
  MySQL-Data-Node1
  192.168.140.129
  Data 节点服务器
  MySQL-MGM-Node
  192.168.140.130
  管理节点服务器
  注意:如果你的实验环境是根据本文的设置,为了对MySQL Cluster的配置不冲突,请整理前面的实验环境,如下:
  [root@MySQL-Proxy ~]# /etc/init.d/mysql-proxy stop
  [root@MySQL-Slave ~]# /etc/init.d/mysqld stop
  [root@MySQL-Master ~]# /etc/init.d/mysqld stop
 5.2.2 部署安装环境
  [root@MySQL-SQL-Node1 src]# wget
  http://ftp.jaist.ac.jp/pub/mysql/Downloads/MySQL-Cluster-7.1/mysql-cluster-gpl-7.1.3.tar.gz
  [root@MySQL-SQL-Node1 src]# chmod +x mysql-cluster-gpl-7.1.3.tar.gz
  [root@MySQL-SQL-Node1 src]# scp mysql-cluster-gpl-7.1.3.tar.gz 192.168.140.129:/usr/local/src
  [root@MySQL-SQL-Node1 src]# scp mysql-cluster-gpl-7.1.3.tar.gz 192.168.140.130:/usr/local/src
 5.2.3 部署管理(MGM)节点
  1> 安装MGM节点
  [root@MySQL-MGM-Node ~]# cd /usr/local/src
  [root@MySQL-MGM-Node src]# tar zxvf mysql-cluster-gpl-7.1.3.tar.gz
  [root@MySQL-MGM-Node src]# cd mysql-cluster-gpl-7.1.3
  [root@MySQL-MGM-Node mysql-cluster-gpl-7.1.3]# ./configure --prefix=/usr/local/mysqlcluster \
  --with- --with-collation=utf8_general_ci \
  --with-client-ldflags=-all-static -with-mysqld-ldflags=-all-static \
  --enable-assembler --with-extra-charsets=complex \
  --enable-thread-safe-client --with-big-tables --with-readline \
  --with-ssl --with-embedded-server --enable-local-infile \
  --with-unix-socket-path=/usr/local/mysqlcluster/tmp/mysql.sock \
  --sysconfdir=/usr/local/mysqlcluster/etc --without-debug \
  --with-mysqld-user=mysql --with-plugins=max
  [root@MySQL-MGM-Node mysql-cluster-gpl-7.1.3]# make && make install
  2> 配置MGM节点
  [root@MySQL-MGM-Node ~]# cd /usr/local/mysqlcluster/
  [root@MySQL-MGM-Node mysqlcluster]# mkdir mysql-cluster
  [root@MySQL-MGM-Node mysqlcluster]# vi mysql-cluster/config.ini
  [NDBD DEFAULT]
  NoOfReplicas= 1
  DataMemory=50M
  IndexMemory=10M
  [NDB_MGMD]
  id=1
  HostName=192.168.140.130
  DataDir=/usr/local/mysqlcluster/mysql-cluster
  [NDBD]
  id=2
  HostName=192.168.140.129
  DataDir=/usr/local/mysqlcluster/ndbdata
  [MYSQLD]
  id=3
  HostName=192.168.140.128
  3> 启动MGM节点
  [root@MySQL-MGM-Node mysqlcluster]# libexec/ndb_mgmd -f
  /usr/local/mysqlcluster/mysql-cluster/config.ini
  5.2.4 部署NDBD节点
  1> 安装NDBD节点
  [root@MySQL-Data-Node1 ~]# cd /usr/local/src
  [root@MySQL-Data-Node1 src]# tar zxvf mysql-cluster-gpl-7.1.3.tar.gz
  [root@MySQL-Data-Node1 src]# cd mysql-cluster-gpl-7.1.3
  [root@MySQL-Data-Node1 mysql-cluster-gpl-7.1.3]# ./configure --prefix=/usr/local/mysqlcluster \
  --with-charset=utf8 --with-collation=utf8_general_ci \
  --with-client-ldflags=-all-static -with-mysqld-ldflags=-all-static \
  --enable-assembler --with-extra-charsets=complex \
  --enable-thread-safe-client --with-big-tables --with-readline \
  --with-ssl --with-embedded-server --enable-local-infile \
  --with-unix-socket-path=/usr/local/mysqlcluster/tmp/mysql.sock \
  --sysconfdir=/usr/local/mysqlcluster/etc --without-debug \
  --with-mysqld-user=mysql --with-plugins=max
  [root@MySQL-Data-Node1 mysql-cluster-gpl-7.1.3]# make && make install
  2> 配置NDBD节点
  [root@MySQL-Data-Node1 ~]# cd /usr/local/mysqlcluster/
  [root@MySQL-Data-Node1 mysqlcluster]# mkdir etc ndbdata
  [root@MySQL-Data-Node1 mysqlcluster]# vi etc/my.cnf
  [mysqld]
  basedir=/usr/local/mysqlcluster/
  datadir=/usr/local/mysqlcluster/var
  user=mysql
  port=3306
  socket=/usr/local/mysql/tmp/mysql.sock
  ndbcluster
  ndb-connectstring=192.168.140.130
  [mysql_cluster]
  ndb-connectstring=192.168.140.130
  3> 启动NDBD节点
  [root@MySQL-Data-Node1 mysqlcluster]# libexec/ndbd --initial
  注意:
  第一次启动需要加--initial参数进行初始化工作,在以后的启动中,千万不要加该参数,因为ndbd程序会清除之前建立的所有用于恢复的数据文件和日志文件。
5.2.5 部署SQL 节点
  1> 安装SQL节点
  [root@MySQL-SQL-Node1 ~]# cd /usr/local/src/
  [root@MySQL-SQL-Node1 src]# tar zxvf mysql-cluster-gpl-7.1.3.tar.gz
  [root@MySQL-SQL-Node1 src]# cd mysql-cluster-gpl-7.1.3
  [root@MySQL-SQL-Node1 mysql-cluster-gpl-7.1.3]# ./configure --prefix=/usr/local/mysqlcluster \
  --with-charset=utf8 --with-collation=utf8_general_ci \
  --with-client-ldflags=-all-static -with-mysqld-ldflags=-all-static \
  --enable-assembler --with-extra-charsets=complex \
  --enable-thread-safe-client --with-big-tables --with-readline \
  --with-ssl --with-embedded-server --enable-local-infile \
  --with-unix-socket-path=/usr/local/mysqlcluster/tmp/mysql.sock \
  --sysconfdir=/usr/local/mysqlcluster/etc --without-debug \
  --with-mysqld-user=mysql --with-plugins=max
  [root@MySQL-Data-Node1 mysql-cluster-gpl-7.1.3]# make && make install
  2> 配置SQL节点
  [root@MySQL-SQL-Node1 ~]# cd /usr/local/mysqlcluster/
  [root@MySQL-SQL-Node1 mysqlcluster]# mkdir etc
  [root@MySQL-SQL-Node1 mysqlcluster]# chown -R root:mysql .
  [root@MySQL-SQL-Node1 mysqlcluster]# bin/mysql_install_db --user=mysql
  [root@MySQL-SQL-Node1 mysqlcluster]# vi etc/my.cnf
  [mysqld]
  basedir=/usr/local/mysqlcluster/
  datadir=/usr/local/mysqlcluster/var
  user=mysql
  port=3306
  socket=/usr/local/mysql/tmpcluster/mysql.sock
  ndbcluster
  ndb-connectstring=192.168.140.130
  [mysql_cluster]
  ndb-connectstring=192.168.140.130
  3> 启动SQL节点
  [root@MySQL-SQL-Node1 mysqlcluster]# bin/mysqld_safe --user=mysql &
5.3 MySQL Cluster 测试
  在管理节点上测试:
  [root@MySQL-MGM-Node ~]# cd /usr/local/mysqlcluster/
  [root@MySQL-MGM-Node mysqlcluster]# bin/ndb_mgm
  -- NDB Cluster -- Management Client --
  ndb_mgm> show
  Connected to Management Server at: localhost:1186
  Cluster Configuration
  ---------------------
  [ndbd(NDB)]1 node(s)
  id=2@192.168.140.129  (mysql-5.1.44 ndb-7.1.3, Nodegroup: 0, Master)
  [ndb_mgmd(MGM)]1 node(s)
  id=1@192.168.140.130  (mysql-5.1.44 ndb-7.1.3)
  [mysqld(API)]1 node(s)
  id=3@192.168.140.128  (mysql-5.1.44 ndb-7.1.3)


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-603342-1-1.html 上篇帖子: 调试(一)——mysql连接不到 下篇帖子: mysql连接报错 ERROR 2002 (HY000): Can't connect to local MySQL server through socket
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表