热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

分布式mysql数据库mysqlcluster

2019独角兽企业重金招聘Python工程师标准IP规划mgm管理节点:192.168.88.199data1:192.168.88.204data2:192.

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

IP规划
mgm管理节点:192.168.88.199
data1:       192.168.88.204
data2:       192.168.88.205
sql1:        192.168.88.202
sql2:        192.168.88.203
所有节点执行
[root@localhost Desktop]# service iptables stop
[root@localhost Desktop]# yum remove  mysql-libs-5.1.71-1.el6.x86_64
[root@localhost Desktop]# rpm -qa|grep mysql
[root@localhost Desktop]#
同步mysql文件



添加mysql用户和组,这是必需的。
[root@localhost mysql]# groupadd mysql
[root@localhost mysql]# useradd -g mysql mysql
解压mysql cluster
[root@localhost soft]# tar -zxf mysql-cluster-gpl-7.4.10-linux-glibc2.5-x86_64.tar.gz
[root@localhost soft]# cp -rp mysql-cluster-gpl-7.4.10-linux-glibc2.5-x86_64/ /usr/local/mysql
[root@localhost soft]# cd /usr/local/mysql
设置权限
[root@localhost mysql]# chown -R root .
[root@localhost mysql]# chown -R mysql data
[root@localhost mysql]# chgrp -R mysql .
初始表空间
[root@localhost mysql]# scripts/mysql_install_db --user=mysql
开机自启动
[root@localhost mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
[root@localhost mysql]# chmod +x /etc/rc.d/init.d/mysqld
[root@localhost mysql]# chkconfig --add mysqld
启动mysql服务,如果报错请参考

service mysqld start
在管理节点
[root@localhost mysql]# cp bin/ndb_mgm* /usr/local/bin
[root@localhost mysql]# cp bin/ndb_mgm* /usr/local/bin
[root@localhost mysql]# cd /usr/local/bin
[root@localhost bin]# chmod +x ndb_mgm*

配置

数据节点和SQL节点

[client]

port    =3306

socket  =/tmp/mysql.sock

[mysqld]

basedir         =/usr/local/mysql/

datadir         =/usr/local/mysql/data

user            = mysql

log-error       =/var/lib/mysql/mysqld.err

ndbcluster   #运行NDB存储引擎

#指定管理节点  以上两行声明其为SQL节点

ndb-connectstring=192.168.88.199

[mysql_cluster]

#指定管理节点  以上两行声明其为数据节点

ndb-connectstring=192.168.88.199


管理节点:
[root@localhost bin]# cd /var/lib
[root@localhost lib]# mkdir mysql-cluster
[root@localhost lib]# cd mysql-cluster
[root@localhost mysql-cluster]# vi  config.ini


[ndbd default]

NoOfReplicas=2

DataMemory=80M

IndexMemory=18M

[tcp default]

portnumber=2202

[ndb_mgmd]

hostname=192.168.88.199

datadir=/var/lib/mysql-cluster   

[ndbd]

hostname=192.168.88.204

datadir=/usr/local/mysql/data

[ndbd]

hostname=192.168.88.205

datadir=/usr/local/mysql/data

[mysqld]

hostname=192.168.88.202

[mysqld]

hostname=192.168.88.203

[NDBD DEFAULT]:表示每个数据节点的默认配置在每个节点的[NDBD]中不用再写这些选项,只能有一个。
[NDB_MGMD]:表示管理节点的配置,只有一个。
[NDBD]:表示每个数据节点的配置,可以有多个。
[MYSQLD]:表示SQL节点的配置,可以有多个,分别写上不同SQL节点的IP地址,也可以什么都不写,只保留一个空节点,表示任意一个IP地址都可以进行访问,此节点的个数表明了可以用来连接数据节点的SQL节点总数。
四、启动
1、管理节点

mysql cluster 需要各个节点都 进行启动后才可以工作,节点的启动顺序为管理节点->数据节点->SQL节点。首先启动管理节点
[root@localhost mysql-cluster]# ndb_mgmd -f /var/lib/mysql-cluster/config.ini
MySQL Cluster Management Server mysql-5.6.28 ndb-7.4.10
[root@localhost mysql-cluster]# ndb_mgm
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.88.204)
id=3 (not connected, accepting connect from 192.168.88.205)

[ndb_mgmd(MGM)]    1 node(s)
id=1    @192.168.88.199  (mysql-5.6.28 ndb-7.4.10)

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

命令行中的ndb_mgmd是mysql cluster的管理服务器,后面的-f表示后面的参数是启动的参数配置文件。如果在启动后过了几天又添加了一个数据节点,这时修改了配置文件启动时就必须加上--initial参数,不然添加的节点不会作用在mysql cluster中。

ndb_mgmd -f /var/lib/mysql-cluster/config.ini --initial

2、数据节点

安装后第一次启动数据节点时要加上--initial参数,其它时候不要加,除非是在备份、恢复或配置变化后重启时。

cd mysql/bin/ndbd --initial

如果显示以下信息说明启动完成
NDBD1
[root@localhost mysql]# ./bin/ndbd --initial
2016-02-18 05:00:38 [ndbd] INFO     -- Angel connected to '192.168.88.199:1186'
2016-02-18 05:00:38 [ndbd] INFO     -- Angel allocated nodeid: 3

NDBD1
[root@localhost mysql]# ./bin/ndbd --initial
2016-02-18 05:00:38 [ndbd] INFO     -- Angel connected to '192.168.88.199:1186'
2016-02-18 05:00:38 [ndbd] INFO     -- Angel allocated nodeid: 2
在管理节点查看链接状况
db_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)]    2 node(s)
id=2    @192.168.88.204  (mysql-5.6.28 ndb-7.4.10, Nodegroup: 0, *)
id=3    @192.168.88.205  (mysql-5.6.28 ndb-7.4.10, Nodegroup: 0)

[ndb_mgmd(MGM)]    1 node(s)
id=1    @192.168.88.199  (mysql-5.6.28 ndb-7.4.10)

[mysqld(API)]    2 node(s)
id=4 (not connected, accepting connect from 192.168.88.202)
id=5 (not connected, accepting connect from 192.168.88.203)
启动mysql

[root@localhost mysql]# service mysqld start
Starting MySQL. ERROR! The server quit without updating PID file (/usr/local/mysql/data/localhost.localdomain.pid).
发现找不了日志
用mysqld——safe启动
[root@localhost mysql]# /usr/local/mysql/bin/mysqld_safe --user=mysql &
[1] 4228
[root@localhost mysql]# 160218 05:20:37 mysqld_safe Logging to '/var/lib/mysql/mysqld.err'.
touch: cannot touch `/var/lib/mysql/mysqld.err': No such file or directory
chmod: cannot access `/var/lib/mysql/mysqld.err': No such file or directory
touch: cannot touch `/var/lib/mysql/mysqld.err': No such file or directory
chown: cannot access `/var/lib/mysql/mysqld.err': No such file or directory
160218 05:20:37 mysqld_safe Starting mysqld daemon with databases from /usr/local/mysql/data
创建目录
mkdir /var/lib/mysql/
同样方法启动第二SQL个节点
[root@localhost data]# /usr/local/mysql/bin/mysqld_safe --user=mysql &
查看状态
ndb_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)]    2 node(s)
id=2    @192.168.88.204  (mysql-5.6.28 ndb-7.4.10, Nodegroup: 0, *)
id=3    @192.168.88.205  (mysql-5.6.28 ndb-7.4.10, Nodegroup: 0)

[ndb_mgmd(MGM)]    1 node(s)
id=1    @192.168.88.199  (mysql-5.6.28 ndb-7.4.10)

[mysqld(API)]    2 node(s)
id=4    @192.168.88.202  (mysql-5.6.28 ndb-7.4.10)
id=5    @192.168.88.203  (mysql-5.6.28 ndb-7.4.10)

测试
在SQL1节点上
[root@localhost bin]# /usr/local/mysql/bin/mysql
mysql> create database tt;
mysql> use tt
Database changed
mysql> create table teacher(t_id int) engine=ndb;#创建一个存储引擎为ndb的存储引擎
Query OK, 0 rows affected (0.28 sec)
ysql> insert into teacher values(133);#插入一条记录
Query OK, 1 row affected (0.01 sec)
在SQL2节点上
[root@localhost data]#  /usr/local/mysql/bin/mysql
mysql> select * from tt.teacher;
+------+
| t_id |
+------+
|  133 |
+------+
1 row in set (0.07 sec)

2、模拟NDB节点Crash:
在节点2上终止掉NDB进程,然后再分别通过两个SQL节点去访问teacher表,查看是否可以正常访问,数据是否一致。如下:
查看进程
kill -9 3492杀掉一个ndb
db_mgm> show
Cluster Configuration
---------------------
[ndbd(NDB)]    2 node(s)
id=2 (not connected, accepting connect from 192.168.88.204)###########被傻掉了
id=3    @192.168.88.205  (mysql-5.6.28 ndb-7.4.10, Nodegroup: 0, *)

[ndb_mgmd(MGM)]    1 node(s)
id=1    @192.168.88.199  (mysql-5.6.28 ndb-7.4.10)

[mysqld(API)]    2 node(s)
id=4    @192.168.88.202  (mysql-5.6.28 ndb-7.4.10)
id=5    @192.168.88.203  (mysql-5.6.28 ndb-7.4.10)

ysql> select * from tt.teacher;############在sql2节点任然能够访问,数据是写在sql1上,
+------+
| t_id |
+------+
|  133 |
+------+
1 row in set (0.00 sec)

[root@localhost bin]# ps -ef |grep mysql
root      4405  2444  0 05:22 pts/0    00:00:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --user=mysql
mysql     4567  4405  2 05:22 pts/0    00:00:29 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql//lib/plugin --user=mysql --log-error=/var/lib/mysql/mysqld.err --pid-file=/usr/local/mysql/data/localhost.localdomain.pid
root      4670  4598  0 05:33 pts/1    00:00:00 /usr/local/mysql/bin/mysql
root      4752  4742  0 05:46 pts/2    00:00:00 grep mysql
[root@localhost bin]# kill -9 4567
[root@localhost bin]# kill -9 4670
SQL2节点任然能够访问,虽然insert在sql1上
mysql> select * from tt.teacher;
+------+
| t_id |
+------+
|  133 |
+------+
1 row in set (0.00 sec)

























转:https://my.oschina.net/goudingcheng/blog/614862



推荐阅读
  • 基于PgpoolII的PostgreSQL集群安装与配置教程
    本文介绍了基于PgpoolII的PostgreSQL集群的安装与配置教程。Pgpool-II是一个位于PostgreSQL服务器和PostgreSQL数据库客户端之间的中间件,提供了连接池、复制、负载均衡、缓存、看门狗、限制链接等功能,可以用于搭建高可用的PostgreSQL集群。文章详细介绍了通过yum安装Pgpool-II的步骤,并提供了相关的官方参考地址。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • 微软评估和规划(MAP)的工具包介绍及应用实验手册
    本文介绍了微软评估和规划(MAP)的工具包,该工具包是一个无代理工具,旨在简化和精简通过网络范围内的自动发现和评估IT基础设施在多个方案规划进程。工具包支持库存和使用用于SQL Server和Windows Server迁移评估,以及评估服务器的信息最广泛使用微软的技术。此外,工具包还提供了服务器虚拟化方案,以帮助识别未被充分利用的资源和硬件需要成功巩固服务器使用微软的Hyper - V技术规格。 ... [详细]
  • 安装mysqlclient失败解决办法
    本文介绍了在MAC系统中,使用django使用mysql数据库报错的解决办法。通过源码安装mysqlclient或将mysql_config添加到系统环境变量中,可以解决安装mysqlclient失败的问题。同时,还介绍了查看mysql安装路径和使配置文件生效的方法。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 本文详细介绍了在Centos7上部署安装zabbix5.0的步骤和注意事项,包括准备工作、获取所需的yum源、关闭防火墙和SELINUX等。提供了一步一步的操作指南,帮助读者顺利完成安装过程。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • Python实现变声器功能(萝莉音御姐音)的方法及步骤
    本文介绍了使用Python实现变声器功能(萝莉音御姐音)的方法及步骤。首先登录百度AL开发平台,选择语音合成,创建应用并填写应用信息,获取Appid、API Key和Secret Key。然后安装pythonsdk,可以通过pip install baidu-aip或python setup.py install进行安装。最后,书写代码实现变声器功能,使用AipSpeech库进行语音合成,可以设置音量等参数。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • CentOS 6.5安装VMware Tools及共享文件夹显示问题解决方法
    本文介绍了在CentOS 6.5上安装VMware Tools及解决共享文件夹显示问题的方法。包括清空CD/DVD使用的ISO镜像文件、创建挂载目录、改变光驱设备的读写权限等步骤。最后给出了拷贝解压VMware Tools的操作。 ... [详细]
  • 本文介绍了将mysql从5.6.15升级到5.7.15的详细步骤,包括关闭访问、备份旧库、备份权限、配置文件备份、关闭旧数据库、安装二进制、替换配置文件以及启动新数据库等操作。 ... [详细]
  • CEPH LIO iSCSI Gateway及其使用参考文档
    本文介绍了CEPH LIO iSCSI Gateway以及使用该网关的参考文档,包括Ceph Block Device、CEPH ISCSI GATEWAY、USING AN ISCSI GATEWAY等。同时提供了多个参考链接,详细介绍了CEPH LIO iSCSI Gateway的配置和使用方法。 ... [详细]
  • 本文介绍了MVP架构模式及其在国庆技术博客中的应用。MVP架构模式是一种演变自MVC架构的新模式,其中View和Model之间的通信通过Presenter进行。相比MVC架构,MVP架构将交互逻辑放在Presenter内部,而View直接从Model中读取数据而不是通过Controller。本文还探讨了MVP架构在国庆技术博客中的具体应用。 ... [详细]
  • 本文介绍了如何在Azure应用服务实例上获取.NetCore 3.0+的支持。作者分享了自己在将代码升级为使用.NET Core 3.0时遇到的问题,并提供了解决方法。文章还介绍了在部署过程中使用Kudu构建的方法,并指出了可能出现的错误。此外,还介绍了开发者应用服务计划和免费产品应用服务计划在不同地区的运行情况。最后,文章指出了当前的.NET SDK不支持目标为.NET Core 3.0的问题,并提供了解决方案。 ... [详细]
author-avatar
手机用户2502897401
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有