mysql cluster 7.1搭建

2024-05-25 23:01:58

简单步骤,分享下:

hostname IP   应用
db1  192.168.50.10  MGM
db2  192.168.50.20  NDBD
db3  192.168.50.30  NDBD2
db4  192.168.50.40  MYSQLD
db5  192.168.50.50  MYSQLD

*****************************
1.安装配置管理节点(DB1)MGM
*****************************

# groupadd mysql

# useradd -g mysql -d /usr/local/mysql/var -M mysql

# tar zxvf mysql-cluster-gpl-7.1.8.tar.gz

# cd mysql-cluster-gpl-7.1.8

# ./configure --prefix=/usr/local/mysql/ --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/mysql/tmp/mysql.sock \
--sysconfdir=/usr/local/mysql/etc --without-debug --with-mysqld-user=mysql --with-plugins=max

# make

# make install

# cd /usr/local/mysql

# mkdir mysql-cluster

# cd mysql-cluster

# vi config.ini

[NDBD DEFAULT]
NoOfReplicas= 2
[MYSQLD DEFAULT]
[NDB_MGMD DEFAULT]
DataDir= /usr/local/mysql/mysql-cluster
[NDB_MGMD]
HostName= 192.168.50.10
[NDBD]
HostName= 192.168.50.20
DataDir= /usr/local/mysql/mysql-cluster
[NDBD]
HostName= 192.168.50.30
DataDir= /usr/local/mysql/mysql-cluster
[MYSQLD]
HostName= 192.168.50.40
[MYSQLD]
HostName= 192.168.50.50

----------启动cluster管理节点

在管理节点服务器上,执行以下命令启动MGM节点进程:

root# /usr/local/mysql/ndb_mgmd -f /usr/local/mysql/config.ini

必须用参数“-f”或“--config-file”告诉 ndb_mgm 配置文件所在位置,默认是在ndb_mgmd相同目录下。

------------------

#  /usr/local/mysql/libexec/ndb_mgmd -f /usr/local/mysql/mysql-cluster/config.ini

#  /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.50.20)
id=3 (not connected, accepting connect from 192.168.50.30)

[ndb_mgmd(MGM)] 1 node(s)
id=1    @192.168.50.10  (mysql-5.1.47 ndb-7.1.8)

[mysqld(API)]   2 node(s)
id=4 (not connected, accepting connect from 192.168.50.40)
id=5 (not connected, accepting connect from 192.168.50.50)

可以看到ndb_mgmd 是 连上的,nbd 和 mysqld 还没有连上~

****************************************
2.安装配置在两个数据节点(DB2,DB3)ndbd
****************************************

# groupadd mysql

# useradd -g mysql -d /usr/local/mysql/var -M mysql

#  tar xvzf mysql-cluster-gpl-7.1.8.tar.gz

# cd mysql-cluster-gpl-7.1.8

# ./configure --prefix=/usr/local/mysql/ --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/mysql/tmp/mysql.sock \
--sysconfdir=/usr/local/mysql/etc --without-debug --with-mysqld-user=mysql --with-plugins=max

# make

# make install

# cd /usr/local/mysql

# mkdir mysql-cluster etc

# chown root:mysql . -R

# vi /usr/local/mysql/etc/my.cnf

[mysqld]
ndbcluster
ndb-connectstring=192.168.50.10
[mysql_cluster]
ndb-connectstring=192.168.50.10

#./libexec/ndbd --initial ### 第一次启动需要 --initial 以后在启动不需要加

2010-06-21 14:09:38 [ndbd] INFO     -- Configuration fetched from '192.168.5.10:1186', generation: 1

--------------------------启动说明

--------------------------启动存储节点

在每台存储节点服务器上,如果是第一次启动ndbd进程的话,必须先执行以下命令:

root# /usr/local/mysql/libexec/ndbd --initial

注意,仅应在首次启动ndbd时,或在备份/恢复数据或配置文件发生变化后重启ndbd时使用“--initial”参数
。因为该参数会使节点删除由早期ndbd实例创建的、用于恢复的任何文件,包括用于恢复的日志文件。
如果不是第一次启动,直接运行如下命令即可:

root# /usr/local/mysql/libexec/ndbd

--------------------------

然后在 MGM 服务器上查看

[root@db1 ~]#  /usr/local/mysql/bin/ndb_mgm
-- NDB Cluster -- Management Client --
ndb_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)]     2 node(s)
id=2    @192.168.50.20  (mysql-5.1.47 ndb-7.1.8, Nodegroup: 0, Master)
id=3    @192.168.50.30  (mysql-5.1.47 ndb-7.1.8, Nodegroup: 0)

[ndb_mgmd(MGM)] 1 node(s)
id=1    @192.168.50.10  (mysql-5.1.47 ndb-7.1.8)

[mysqld(API)]   2 node(s)
id=4 (not connected, accepting connect from 192.168.50.40)
id=5 (not connected, accepting connect from 192.168.50.50)

从上面可以看出 两个 ndbd 节点 和 ndbd 上存储都已经连接上了。

****************************************

3、安装配置SQL节点(DB4、DB5)

****************************************

# groupadd mysql

# useradd -g mysql -d /usr/local/mysql/var -M mysql

# tar xvzf mysql-cluster-gpl-7.1.8.tar.gz

# cd mysql-cluster-gpl-7.1.8

# ./configure --prefix=/usr/local/mysql/ --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/mysql/tmp/mysql.sock \
--sysconfdir=/usr/local/mysql/etc --without-debug --with-mysqld-user=mysql --with-plugins=max

# make

# make install

# cd /usr/local/mysql

# mkdir mysql-cluster etc

# chown root:mysql . -R

# ./bin/mysql_install_db --user=mysql

# vi ./etc/my.cnf

[mysqld]
basedir = /usr/local/mysql/
datadir = /usr/local/mysql/var
user = mysql
port = 3306
socket = /usr/local/mysql/tmp/mysql.sock
ndbcluster
ndb-connectstring=192.168.50.10
[mysql_cluster]
ndb-connectstring=192.168.50.10

启动 mysql 服务

# ./bin/mysqld_safe --user=mysql &

--------------启动mysqld服务

最后,运行以下命令启动SQL节点服务器:

root# /usr/local/mysql/bin/mysqld_safe --defaults-file=/usr/local/mysql/my.cnf &

--------------

回到 MGM 上查看是否正常

./bin/ndb_mgm
-- NDB Cluster -- Management Client --

ndb_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)]     2 node(s)
id=2    @192.168.50.20  (mysql-5.1.47 ndb-7.1.8, Nodegroup: 0, Master)
id=3    @192.168.50.30  (mysql-5.1.47 ndb-7.1.8, Nodegroup: 0)

[ndb_mgmd(MGM)] 1 node(s)
id=1    @192.168.50.10  (mysql-5.1.47 ndb-7.1.8)

[mysqld(API)]   2 node(s)
id=4    @192.168.50.40  (mysql-5.1.47 ndb-7.1.8)
id=5    @192.168.50.50  (mysql-5.1.47 ndb-7.1.8)

好了,一切正常了,现在回到 mysql 节点上 创建和删除数据看是否同步。

****************************************
4.新建数据库测试
****************************************

那么就登录 DB4 的 mysql

DB4 # > /usr/local/mysql/bin/mysql -uroot -p

mysql > show databases;

+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| ndbinfo            |
| test               |
+--------------------+
4 rows in set (0.01 sec)

mysql > create database accp;

Query OK, 1 row affected (0.39 sec)

mysql > show databases;

+--------------------+
| Database           |
+--------------------+
| information_schema |
| accp               |
| mysql              |
| ndbinfo            |
| test               |
+--------------------+
5 rows in set (0.00 sec)

看 DB5 上是否同步

DB5 # > /usr/local/mysql/bin/mysql -uroot -p

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| accp               |
| mysql              |
| ndbinfo            |
| test               |
+--------------------+
5 rows in set (0.00 sec)

DB5 # > /usr/local/mysql/bin/mysql -uroot -p

mysql > show databases;

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| accp               |
| mysql              |
| ndbinfo            |
| test               |
+--------------------+
5 rows in set (0.00 sec)

都看到了 accp 数据库 安装配置完成。

****************************************
5.新建表测试
****************************************

DB5上新建测试表t1

mysql> use accp;
Database changed
mysql> create table t1
    -> (
    -> sid int not null primary key,
    -> sno int
    -> ) engine=ndbcluster;
Query OK, 0 rows affected (0.37 sec)

mysql> insert into t1 values (101,201);
Query OK, 1 row affected (0.01 sec)

mysql> select * from t1;
+-----+------+
| sid | sno  |
+-----+------+
| 101 |  201 |
+-----+------+
1 row in set (0.00 sec)

DB4上查看是否同步:

mysql> use accp;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+----------------+
| Tables_in_accp |
+----------------+
| t1             |
+----------------+
1 row in set (0.02 sec)

mysql> select * from t1;
+-----+------+
| sid | sno  |
+-----+------+
| 101 |  201 |
+-----+------+
1 row in set (0.01 sec)

转载于:https://blog.51cto.com/ocpyang/1194508

mysql cluster 7.1搭建相关推荐

  1. mysql cluster rpm包的作用_MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包)

    1.下载MySQL-cluster 7.3.7 http://dev.mysql.com/downloads/cluster/ 2.环境清理及安装 1)清理CentOS6.5自带的mysql服务,其中 ...

  2. 【Data Cluster】真机环境下MySQL数据库集群搭建

    真机环境下MySQL-Cluster搭建文档 MySQL Cluster简介 MySQL cluster 和 Oracle RAC 完全不同,它采用 无共享架构Shared nothing(share ...

  3. Mysql Cluster 8.0.26搭建

    Mysql Cluster 8.0.26搭建 一.基础环境部署 1.基本环境(每个节点都需要) 1.1 关闭防火墙 systemctl stop firewalld # 关闭防火墙 systemctl ...

  4. 利用MySQL Cluster 7.0 + LVS 搭建高可用环境

    1.前言 随着数据量规模的扩大,企业对 MySQL 的要求就不仅仅是能用了,也在寻求各种高可用方案.以前我们的大部分高可用方案其实还存在一定缺陷,例如 MySQL Replication 方案,Mas ...

  5. mysql搭建集群_Mysql搭建集群Mysql Cluster

    MySQL集群技术在分布式系统中为MySQL数据提供了冗余特性,增强了安全性,使得单个MySQL服务器故障不会对系统产生巨大的负面效应,系统的稳定性得到保障. mysql集群和主从复制的区别:   集 ...

  6. MySQL Cluster 日常维护

    在前面几篇文章已经详细介绍了MySQL Cluster的搭建,配置讲解.而且相信大家都掌握了基本用法.现在我们来看看Cluster的日常维护.熟悉日常维护,将有助于工作中更好的管理和使用Cluster ...

  7. 5.MySQL Cluster(MySQL集群)

    5.1 MySQL Cluster 简介 请参考官方文档:http://dev.mysql.com/doc/refman/5.1/zh/ndbcluster.html 下面是官方的MySQL Clus ...

  8. 第 16 章 MySQL Cluster

    前言: MySQL Cluster 是一个基于 NDB Cluster 存储引擎的完整的分布式数据库系统.不仅仅具有高可用性,而且可以自动切分数据,冗余数据等高级功能.和 Oracle Real Cl ...

  9. MySQL数据库管理(二)单机环境下MySQL Cluster的安装

    上文<MySQL数据库管理(一)MySQL Cluster集群简单介绍>对MySQL Cluster集群做了简要介绍.本文将教大家一步步搭建单机环境下的MySQL数据库集群. 一.单机环境 ...

最新文章

  1. COMMUNITY SERVER 的架构分析
  2. 2022-03-31 一些后续
  3. SQL 盲注GET /POST、布尔型,延时型Python脚本
  4. 算法真的太重要了!CSDN用动画帮你快速 get 核心原理
  5. Robust.ai 获得 1500 万美元融资,嘴炮 Gary Marcus 也难逃真香定律
  6. vue项目关于:Error: Cannot find module ‘D:\@vue\cli-service\bin\vue-cli-service.js‘的解决方案
  7. 基于shotgun蛋白质组学的MaxQuant质谱计算平台
  8. ROS下调用笔记本自带摄像头
  9. 【华人学者风采】丛京生 加州大学洛杉矶分校
  10. V for vendetta
  11. 我的所有的浏览器被hao123 挟持了,终极解决方案
  12. java依赖什么意思,JavaEE中的依赖性——依赖查找
  13. latex多行公式加大括号、整体编号及多行编号及不同方法的区别
  14. python switch to frame_iframe的操作switch_to_frame使用方法.
  15. 对LMAX架构以及Event Sourcing模式的一些新思考和问题的记录
  16. 学生白嫖阿里云服务器方法
  17. 你了解多少?空气净化器八大净化技术解读
  18. android alarmmanager进程,即使Android应用程序关闭,如何确保AlarmManager触发?
  19. 拼多多Java岗校招-4面获得年薪66万offer
  20. 新巴巴运动网项目需求书_项目申报书、项目可行性研究报告傻傻分不清楚?

热门文章

  1. goland远程调试Docker
  2. linux操作系统之竞态条件(时序竞态)
  3. Effective C++学习第九天
  4. php一行多个商品,【后端开发】php一行展示多个商品怎么实现
  5. UVA - 210:Concurrency Simulator
  6. C++ cin 实现循环读入
  7. BZOJ2809-左偏树合并
  8. Shuffle'm Up——简单模拟
  9. C语言实现单链表操作
  10. C++中引用与指针的区别(详细介绍)