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

[经验分享] Centos6.5下安装Mysql集群

[复制链接]

尚未签到

发表于 2018-10-10 06:07:26 | 显示全部楼层 |阅读模式
  安装要求:
  安装环境:Centos6.5
  安装方式:源码安装
  软件名称: mysql-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
  软件安装位置:/usr/local/mysql
  数据存放位置:/var/mysql/data
  日志存放位置:/var/mysql/logs
  集群设计:
  首先设计集群的安装分配方式,至少需要三台服务器,sql节点和数据节点可以放在同一台服务器上,服务器分配如下:
  管理节点:192.168.147.129
  sql节点和数据节点1:192.168.147.130
  sql节点和数据节点2:192.168.147.132
  目前此设计存在的问题是管理节点是单点的,129管理节点服务器挂掉后整个集群就会瘫痪。
  检查安装的Mysql:
  检查系统中已经安装过的Mysql信息,如果有卸载之:
  [root@wjx /]# rpm -qa | grep mysql  #查看mysql信息
  [root@wjx /]# service mysql status   #查看mysql服务的状态
  [root@wjx /]# /etc/init.d/mysqld stop  #关闭目前的mysql服务
  [root@wjx /]# ps -ef | grep mysql  #检验mysql是否已经关闭 如果没关闭,执行kill -9 端口号
  [root@wjx /]# rpm -e --allmatches --nodeps mysql mysql-server   #执行删除或者用如下口令
  [root@wjx /]# yun remove mysql mysql-*
  [root@wjx /]#rm -rf /var/lib/mysql    #删除Mysql的安装目录
  管理节点的安装:
  安装管理节点在(192.168.147.129)上
  [root@wjx /]# groupadd mysql
  [root@wjx /]#  useradd mysql -g mysql
  [root@wjx /]# cd /usr/local
  [root@wjx local]# tar -zxvf mysql-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
  [root@wjx local]# mv mysql-cluster-gpl-7.2.26-linux2.6-x86_64 mysql
  [root@wjx local]# chown -R mysql:mysql mysql
  [root@wjx local]# cd mysql
  [root@wjx mysql]# scripts/mysql_install_db --user=mysql
  配置管理节点
  [root@wjx ~]#  mkdir /var/lib/mysql-cluster
  [root@wjx ~]# cd /var/lib/mysql-cluster
  [root@wjx mysql-cluster]# vi + /var/lib/mysql-cluster/config.ini
  在config.ini中添加如下内容
  [NDBD DEFAULT]
  NoOfReplicas=1
  [TCP DEFAULT]
  portnumber=3306
  [NDB_MGMD]
  #设置管理节点服务器
  HostName=192.168.147.129
  DataDir=/var/mysql/data
  [NDBD]
  #设置存储节点服务器(NDB节点)
  HostName=192.168.147.130
  DataDir=/var/mysql/data
  [NDBD]
  #第二个NDB节点
  HostName=192.168.147.132
  DataDir=/var/mysql/data
  [MYSQLD]
  #设置SQL节点服务器
  HostName=192.168.147.130
  [MYSQLD]
  #第二个SQL节点
  HostName=192.168.147.132
  管理节点启动
  [root@wjx ~]# /usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini#启动节点显示如下内容
  MySQL Cluster Management Server mysql-5.5.53 ndb-7.2.26
  2016-10-2200:40:32 [MgmtSrvr] INFO     -- The default config directory '/usr/local/mysql/mysql-cluster' does not   exist. Trying to create it...
  2016-10-22 00:40:32 [MgmtSrvr] INFO     -- Sucessfully created config directory
  2016-10-22 00:40:32 [MgmtSrvr] WARNING  -- at line 4: [TCP] portnumber is deprecated
  [root@wjx ~]# mkdir /var/mysql/logs
  [root@wjx ~]# netstat -lntpu
  [root@wjx mysql-cluster]# /usr/local/mysql/bin/ndb_mgm #打开管理节点显示如下内容
  -- NDB Cluster -- Management Client --
  ndb_mgm>  #输入show显示如下内容
  Connected to Management Server at: localhost:1186
  Cluster Configuration
  --------------------
  [ndbd(NDB)]     2 node(s)
  id=2 (not connected, accepting connect from 192.168.147.130)
  id=3 (not connected, accepting connect from 192.168.147.132)
  [ndb_mgmd(MGM)] 1 node(s)
  id=1    @192.168.147.129  (mysql-5.5.53 ndb-7.2.26)
  [mysqld(API)]   2 node(s)
  id=4 (not connected, accepting connect from 192.168.147.130)
  id=5 (not connected, accepting connect from 192.168.147.132)
  ndb_mgm>
  管理节点的关闭:
  [root@wjx /]# /usr/local/mysql/bin/ndb_mgm -e shutdown
  数据节点的安装
  数据节点1: 192.168.147.130
  数据节点2: 192.168.147.132
  [root@test /]# groupadd mysql
  [root@test /]# useradd mysql -g mysql
  [root@test /]# cd /usr/local
  [root@test local]# tar -zxvf mysql-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
  [root@test local]# mv mysql-cluster-gpl-7.2.26-linux2.6-x86_64 mysql
  [root@test local]# chown -R mysql:mysql mysql
  [root@test local]# cd mysql
  [root@test mysql]# scripts/mysql_install_db --user=mysql
  [root@test mysql]# cp support-files/my-medium.cnf /etc/my.cnf
  [root@test mysql]# cp support-files/mysql.server /etc/init.d/mysqld
  配置数据节点
  [root@test mysql]# mkdir -p /var/mysql/data
  [root@test mysql]# mkdir /var/mysql/logs
  [root@test mysql]# vi /etc/my.cnf  #添加如下内容
  [MYSQLD]
  ndbcluster
  ndb-connectstring=192.168.147.129
  [MYSQL_CLUSTER]
  ndb-connectstring=192.168.147.129
  [NDB_MGM]
  connect-string=192.168.147.129
  数据节点的启动
  [root@test mysql]# /usr/local/mysql/bin/ndbd --initial #只是在第一次启动或在备份/恢复或配置变化后重启ndbd时,才加–initial参数!
  第一次启动如下:
  2016-10-22 13:43:53 [ndbd] INFO     -- Angel connected to '192.168.147.129:1186'
  2016-10-22 13:43:53 [ndbd] INFO     -- Angel allocated nodeid: 2
  [root@localhost mysql]# /usr/local/mysql/bin/ndbd    #正常启动方式
  数据节点的关闭
  [root@test /]# /etc/rc.d/init.d/mysqld stop     #或者
  [root@test mysql]# /etc/init.d/mysql stop
  Shutting down MySQL.. SUCCESS!
  /usr/local/mysql/bin/mysqladmin -uroot shutdown
  SQL 节点的安装
  SQL节点和存储节点(NDB节点)安装相同,都执行以下操作;
  sql节点1: 192.168.147.130
  sql节点2: 192.168.147.132
  [root@test /]# groupadd mysql
  [root@test /]# useradd mysql -g mysql
  [root@test /]# cd /usr/local
  [root@test local]# tar -zxvf mysql-cluster-gpl-7.2.26-linux2.6-x86_64.tar.gz
  [root@test local]# mv mysql-cluster-gpl-7.2.26-linux2.6-x86_64 mysql
  [root@test local]# chown -R mysql:mysql mysql
  [root@test local]# cd mysql
  [root@test mysql]# scripts/mysql_install_db --user=mysql
  [root@test mysql]# cp support-files/my-medium.cnf /etc/my.cnf
  [root@test mysql]# cp support-files/mysql.server /etc/init.d/mysqld
  SQL节点配置
  [root@test mysql]# mkdir -p /var/mysql/data     #创建存储数据的文件夹
  [root@test mysql]# mkdir /var/mysql/logs        #创建存储日志的文件夹
  [root@test mysql]# vi /usr/local/mysql/my.cnf   #修改配置文件
  在my.cnf中追加以下内容
  [MYSQLD]
  ndbcluster
  ndb-connectstring=192.168.147.129
  [MYSQL_CLUSTER]
  ndb-connectstring=192.168.147.129
  [NDB_MGM]
  connect-string=192.168.147.129
  数据节点和sql节点安装在同一台服务器时3306端口会冲突导致数据库服务启动不了只需要在my.cnf中将端口号改了即可,如下
  [client]
  #password       = your_password
  port            = 3308
  socket          = /tmp/mysql.sock
  # Here follows entries for some specific programs
  # The MySQL server
  [mysqld]
  port            = 3308
  socket          = /tmp/mysql.sock
  skip-external-locking
  SQL节点启动
  [root@test mysql]# service mysqld start
  Starting MySQL.. SUCCESS!
  SQL节点关闭
  [root@test mysql]# /usr/local/mysql/bin/mysqladmin -uroot shutdown #最直接的方式
  [root@test mysql]# service mysqld stop
  [root@test mysql]# /etc/init.d/mysqld stop
  #至此数据节点和SQL节点安装配置完毕只需要在.130和.132两台服务器上启动数据节点服务和mysql服务即可,启动后正常显示如下
  [root@test ~]# /usr/local/mysql/bin/ndbd
  2016-10-22 15:17:58 [ndbd] INFO     -- Angel connected to '192.168.147.129:1186'
  2016-10-22 15:17:58 [ndbd] INFO     -- Angel allocated nodeid: 3
  [root@test ~]# service mysqld start
  Starting MySQL SUCCESS!
  功能测试
  在管理节点(192.168.147.129)上查看服务状态
  [root@wjx ~]# /usr/local/mysql/bin/ndb_mgmd -f /var/lib/mysql-cluster/config.ini
  MySQL Cluster Management Server mysql-5.5.53 ndb-7.2.26
  [root@wjx ~]# /usr/local/mysql/bin/ndb_mgm
  -- NDB Cluster -- Management Client --
  ndb_mgm> show
  Cluster Configuration
  ---------------------
  [ndbd(NDB)]     2 node(s)
  id=2    @192.168.147.130  (mysql-5.5.53 ndb-7.2.26, Nodegroup: 0, *)
  id=3    @192.168.147.132  (mysql-5.5.53 ndb-7.2.26, no nodegroup)
  [ndb_mgmd(MGM)] 1 node(s)
  id=1    @192.168.147.129  (mysql-5.5.53 ndb-7.2.26)
  [mysqld(API)]   2 node(s)
  id=4    @192.168.147.130  (mysql-5.5.53 ndb-7.2.26)
  id=5    @192.168.147.132  (mysql-5.5.53 ndb-7.2.26)
  可以看到这里的数据节点、管理节点、sql节点都是正常的。
  注意
  1. 在建表的时候一定要用ENGINE=NDB或ENGINE=NDBCLUSTER指定使用NDB集群存储引擎,或用ALTER TABLE选项更改表的存储引擎。
  2. NDB表必须有一个主键,因此创建表的时候必须定义主键,否则NDB存储引擎将自动生成隐含的主键
  3. Sql节点的用户权限表仍然采用MYISAM存储引擎保存的,所以在一个Sql节点创建的MySql用户只能访问这个节点,如果要用同样的用户访问别的Sql节点,需要在对应的Sql节点追加用户。虽然在MySql Cluster7.2版本开始提供了”用户权限共享”。
  数据同步测试
  在一个数据节点上进行相关数据库的创建,然后到另外一个数据节点上看看数据是否同步。
  1步:SQL节点1(192.168.147.130)上增加数据:
  [root@test mysql]#  /etc/rc.d/init.d/mysqld status                #检验mysql是否运行
  [root@test mysql]# /etc/rc.d/init.d/mysqld start                   #启动mysql
  [root@test mysql]# /usr/local/mysql/bin/mysql -u root -p
  Enter password:
  mysql> show databases;
  mysql> create database testdb2;
  mysql> use testdb2;
  mysql> CREATE TABLE td_test2 (i INT) ENGINE=NDB;       #这里必须指定数据库表的引擎为NDBCLUSTER,与配置文件中的名称相同
  mysql> INSERT INTO td_test2() VALUES (1);
  mysql> INSERT INTO td_test2() VALUES (152);
  mysql> SELECT * FROM td_test2;
  2步:进入到SQL节点2(192.168.147.132)上查看数据
  mysql> use testdb2;
  Database changed
  mysql> SELECT * FROM td_test2;
  +------+
  | i    |
  +------+
  |  152|
  |    1 |
  +------+
  2 rows in set (0.01 sec)
  3步:反向测试,SQL节点2(192.168.147.132)上增加数据:
  mysql> create database bb;
  mysql> use bb;
  mysql> CREATE TABLE td_test3 (i INT) ENGINE=NDB;
  mysql> INSERT INTO td_test3 () VALUES (98);
  mysql> SELECT * FROM td_test3;
  第四步:SQL节点1(192.168.15.232)上查看数据:
  mysql>  use bb;
  Database changed
  mysql>  SELECT * FROM td_test3;
  +------+
  | i    |
  +------+
  |   98 |
  +------+
  1 row in set (0.00 sec)
关闭集群
  先关闭管理节点,然后关闭SQL节点和数据节点。
集群启动操作顺序

  要再次启动集群,按照以下顺序执行:
管理节点-> 数据节点–> SQL节点 注意:此次启动数据节点时不要加”–initial”参数。 启动中的常见错误

  错误提示:
  Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
  解决办法1(端口占用) netstat -anp |grep 3306
  kill -9 进程号
  解决办法1(权限问题) [root@localhost mysql]# chown -R mysql:mysql /var/mysql          //修改自定义文件夹的访问权限
  修改root用户空密码语句:
  use mysql;
  update user setPassword=password('root') where User='root';
set PASSWORD FOR'root'@'localhost' = PASSWORD('root');赋予root用户所有权限:grant allprivileges on *.*  to 'root'@'%'identified  by 'root' with grant option;  权限即刻生效:
  flush privileges;


运维网声明 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-619654-1-1.html 上篇帖子: linux 安装php mysql扩展 下篇帖子: Mysql函数FIND_IN_SET()的使用方法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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