>  기사  >  데이터 베이스  >  MySQL - MySQL Cluster 클러스터 구성에 대한 자세한 설명 (RPM 설치 패키지 이중 관리 센터 기반)

MySQL - MySQL Cluster 클러스터 구성에 대한 자세한 설명 (RPM 설치 패키지 이중 관리 센터 기반)

黄舟
黄舟원래의
2017-01-21 12:01:371390검색

1. mysql-cluster 7.3.7 다운로드

http://dev.mysql.com/downloads/cluster/


2. 정리 및 설치

1) CentOS6.5에 포함된 MySQL 서비스를 정리합니다. 다른 시스템에서 불가능하다면 첫 번째 명령을 실행하지 않아도 됩니다.

# yum -y remove mysql  
# rpm -qa | grep mysql*  
# rpm -e --nodeps mysql-libs-5.1.71-1.el6.x86_64

2) 환경 준비
폴더 생성(다음 3개 카테고리로 나누어 해당 폴더 생성)

存储节点:# mkdir /var/lib/mysql/data   
管理节点:# mkdir /var/lib/mysql-cluster    SQL节点:可不用  文件夹授权  
进程DIR:# mkdir /var/run/mysqld                
使用如下的命令来变更权限保证可写入:  
# chmod -R 1777 /var/lib/mysql  
# chmod -R 1777 /var/run/mysqld  
# chmod -R 1777 /var/lib/mysql-cluster

3) mysql-cluster 설치

首先解压MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar  
# tar xvf MySQL-Cluster-gpl-7.4.2-1.el6.x86_64.rpm-bundle.tar  
然后执行如下命令安装  
# rpm -ivh MySQL-Cluster-server-gpl-7.3.4-1.el6.x86_64.rpm  
# rpm -ivh MySQL-Cluster-client-gpl-7.3.4-1.el6.x86_64.rpm

설치가 완료되면 특히 주의하십시오. 서버 gpl 패키지 이후에는 다음과 같은 프롬프트 메시지가 나타나며, 전체 클러스터 설치 후 첫 번째 슈퍼 계정 비밀번호가 /root/.mysql_secret 파일에 존재함을 알려줍니다.

---------------------------------------------------------------------------------------------------------------------  
A RANDOM PASSWORD HAS BEEN SET FOR THE MySQL root USER !  
You will find that password in '/root/.mysql_secret'.  
You must change that password on your first connect,  
no other statement but 'SET PASSWORD' will be accepted.  
See the manual for the semantics of the 'password expired' flag.  
Also, the account for the anonymous user has been removed.  
In addition, you can run:  
/usr/bin/mysql_secure_installation  
which will also give you the option of removing the test database.  
This is strongly recommended for production servers.  
-----------------------------------------------------------

3. 관리 노드 구성

1) 다음 명령을 실행합니다.

# cd /var/lib/mysql-cluster  
# vi config.ini

2) 다음 구성과 같이 config.ini 파일을 구성합니다. 첨부 파일
100.218 파일:

config.ini

구성 정보:

[computer]  
Id=mgr-server-01  
HostName=192.168.100.218  
[mgm default]  
datadir=/var/lib/mysql-cluster  
[mgm]  
HostName=192.168.100.218  
NodeId=60  
[mgm]  
HostName=192.168.100.217  
NodeId=61  
[ndbd default]  
NoOfReplicas = 2  
DataMemory = 50M  
IndexMemory = 50M  
MaxNoOfTables = 1024  
MaxNoOfAttributes = 5000000  
MaxNoOfOrderedIndexes = 10000  
[ndbd]  
HostName=192.168.100.217  
DataDir=/var/lib/mysql  
NodeId=1  
[ndbd]  
HostName=192.168.100.218  
DataDir=/var/lib/mysql  
NodeId=2  
[mysqld]  
HostName=192.168.100.217  
NodeId=81  
[mysqld]  
HostName=192.168.100.218  
NodeId=82

100.217 구성 파일
config.ini

[computer]  
Id=mgr-server-02  
HostName=192.168.100.217  
[mgm default]  
datadir=/var/lib/mysql-cluster  
[mgm]  
HostName=192.168.100.218  
NodeId=60  
[mgm]  
HostName=192.168.100.217  
NodeId=61  
[ndbd default]  
NoOfReplicas = 2  
DataMemory = 50M  
IndexMemory = 50M  
MaxNoOfTables = 1024  
MaxNoOfAttributes = 5000000  
MaxNoOfOrderedIndexes = 10000  
[ndbd]  
HostName=192.168.100.217  
DataDir=/var/lib/mysql  
NodeId=1  
[ndbd]  
HostName=192.168.100.218  
DataDir=/var/lib/mysql  
NodeId=2  
[mysqld]  
HostName=192.168.100.217  
NodeId=81  
[mysqld]  
HostName=192.168.100.218  
NodeId=82

사실 두 파일 사이에는 차이가 없습니다. 가장 큰 것은 컴퓨터 구성의 이름과 ID에 있습니다


4.

my.cnf 파일을 수정하고 다음 내용을 추가합니다:

[client]  
socket=/var/lib/mysql/mysql.sock  
[mysqld]  
max_connections=100  
datadir=/var/lib/mysql  
socket=/var/lib/mysql/mysql.sock  
ndbcluster  
ndb-connectstring=192.168.100.218,192.168.100.217  
[mysqld_safe]  
log-error=/var/log/mysqld.log  
#pid-file=/var/run/mysqld/mysqld.pid  
pid-file=/var/lib/mysql/mysqld.pid  
[mysql_cluster]  
ndb-connectstring=192.168.100.218,192.168.100.217

5. MySQL 클러스터 초기 시작 명령 및 사용자 비밀번호 변경 조정: (시작 순서를 엄격히 따르십시오)

1) mysql-cluster 시작
초기 시작 수행 두 시스템의 방화벽이 꺼져 있는지 확인하십시오(서비스 iptables가 중지되거나 방화벽 포트가 액세스 가능하도록 설정, 두 포트는 통신 포트 1186 및 데이터 포트 3306) )
처음으로 mgt 콘솔 명령 시작: ndb_mgmd -f /var/ lib/mysql-cluster/config.ini(초기화에는 --initial을 추가해야 함)
균등화된 노드 명령 시작: NDBD-Initial
데이터 노드 시작 명령: MySQLD_SAFE-DEFAULTS-FILE =/usr/my.cnf --explicit_defaults_for_timestamp &
my.cnf는 일부 시스템의 etc 디렉터리에 있습니다.
전체 콘솔 출력을 모니터링해야 합니다. 시작 프로세스 중에 오류 메시지가 발견되면 오류 로그 내용을 기반으로 적시에 해결해야 합니다.
---------------------------------- --- ---------------------------------- --- --------
모든 것이 정상이면 다음 명령을 사용하여 관리 콘솔을 엽니다. ndb_mgm
Execute # show
다음과 같이 각 노드가 완전히 시작되었는지 확인합니다. , 각 노드가 연결되었으며, 연결되지 않은 노드가 있으면

ndb_mgm> show  
Connected to Management Server at: 192.168.100.218:1186  
Cluster Configuration  
---------------------  
[ndbd(NDB)] 2 node(s)  
id=1 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0)  
id=2 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0, *)  
[ndb_mgmd(MGM)] 1 node(s)  
id=60 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)  
id=61 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)  
[mysqld(API)] 2 node(s)  
id=81 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)  
id=82 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)

가 표시됩니다. 연결되지 않은 노드가 있으면 아래와 같이 id=81인 줄이 있음을 의미합니다. 연결이 되지 않았는지 확인하세요

ndb_mgm> show  
Cluster Configuration  
---------------------  
[ndbd(NDB)] 2 node(s)  
id=1 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0)  
id=2 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2, Nodegroup: 0, *)  
[ndb_mgmd(MGM)] 1 node(s)  
id=60 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)  
id=61 @192.168.100.217 (mysql-5.6.21 ndb-7.4.2)  
[mysqld(API)] 2 node(s)  
id=81 (not connected, accepting connect from 192.168.100.217)  
id=82 @192.168.100.218 (mysql-5.6.21 ndb-7.4.2)

2) 비밀번호 수정
mysqld가 정상적으로 시작되면(pgrep mysqld를 사용하여 프로세스 ID를 얻을 수 있음) 다음 명령을 사용하여 확인할 수 있습니다. 수정하세요:
mysql -u root -p;
임의 비밀번호(자세한 내용은 /root 참조) /.mysql_secret 파일), 입력 후 비밀번호를 변경하려면 다음 명령을 사용하세요. '새 비밀번호');
단, 이 새 비밀번호는 해시 값이어야 하므로 다음 방법을 사용하여 비밀번호 문자를 얻으세요. 문자열의 해시 값
selectpassword('111111');
단 , 위 명령을 실행하면 먼저 비밀번호를 설정하라는 메시지가 나오는데 답답하지만 다시 나오므로 다른 곳에서 mysql에 가서 실행하세요
111111의 해시 값은 "*FD571203974BA9AFE270FE62151AE967ECA5E0AA"
SET PASSWORD = PASSWORD('*FD571203974BA9AFE270FE62151AE967ECA5E0AA');
설정 후에도 여전히 비밀번호를 사용하여 로그인해야 합니다. 텍스트, 그럼 그냥 암호 텍스트를 사용하세요. 들어가서 다음 명령을 입력한 후 강제로 입력하세요. 일반 텍스트를 사용하여 로그인

use mysql;  
delete from user;  
grant all on *.* to root@'%' identified by "111111" with grant option;  
flush privileges;  
quit;
然后,可以使用明文密码登陆了
几台装有SQL数据节点的服务器皆需要执行一遍上述命令;

6、当上面步奏都操作完成以后,测试cluster是否正常工作
1)简单功能测试
在218上进入mysql后执行如下:
create database clustertest;  
use clustertest;   
CREATE TABLE testtable(Count INT) ENGINE=NDBCLUSTER;

참고: ENGINE=NDBCLUSTER; 엔진은 동기화를 위해 NDBCLUSTER를 사용해야 합니다. 그렇지 않으면 동기화가 수행되지 않습니다

217에서 성공 여부를 확인하세요. mysql을 실행하여 데이터베이스와 테이블이 자동으로 생성되는지 확인합니다. 실패하면 환경 구성을 확인하세요
2) 재해 복구 상황에서 데이터를 동기화할 수 있는지 테스트합니다. 중지 및 재시작 손실된 데이터가 자동으로 보충됩니까?)
217에서 mysql 서비스를 중지하고 218에서

insert into testtable values (1);

를 실행하여 217의 mysql 서비스를 시작하고 show를 사용하여 217의 데이터베이스 노드를 확인합니다. 이제 다음 문장을 실행해 보세요


select * from testtable;

데이터가 발견되면 기능이 완료된 것입니다



7. 클러스터 닫기: (순서대로 엄격한 실행 필요)

데이터 노드 종료: # mysqld stop (SQL 노드는 mysqladmin shutdown 또는 다른 방법을 사용하여 종료할 수 있습니다. )

관리 노드에서 실행: # ndb_mgm -e shutdown
은 관리 노드와 데이터 노드를 안전하게 종료합니다.
닫은 후 다음 프로세스 감지 명령을 사용하여 종료되었는지 확인하십시오.

# pgrep mysqld  
# ps aux | grep nbdb

그렇지 않은 경우 해당 pid를 찾아 종료 작업을 수행합니다.

kill -9 프로세스 번호


8. 클러스터 계획을 다시 시작합니다.

전체 클러스터를 시작하는 순서는 일부 문이 초기화 내용으로 축소되었습니다.

ndb_mgmd -f /var/lib/mysql-cluster/config.ini  
ndbd  
mysqld_safe --defaults-file=/usr/my.cnf --explicit_defaults_for_timestamp &

备注:

1、mysql安装后,默认会自动启动的,每次启动cluster的时候,都需要先把mysql的服务关闭,太麻烦,于是可以执行如下命令(我出手有点狠):

chkconfig --level 123456 mysql off

2、防火墙问题,偷个懒,我懒得去一一开放端口,干脆把防火墙直接关了(极不推荐的做法)

chkconfig --level 123456 iptables off

参考相关文档:

MySQL Cluster config.ini文件配置详解:

    http://note.youdao.com/share/?id=376407a1136d2032afb6ef68aa39fba5&type=note

    http://note.youdao.com/share/?id=3906996cbe3298a22fbb5a2196d6cbed&type=note

MySQL Cluster 备份与恢复 http://www.linuxidc.com/Linux/2013-06/85295.htm

MySQL Cluster安装配置 http://www.linuxidc.com/Linux/2013-07/87705.htm

MySQL Cluster 3台机器搭建集群环境 DOC http://www.linuxidc.com/Linux/2013-01/78249.htm

MySQL Cluster7.2在线增加数据节点存在重大弊端 http://www.linuxidc.com/Linux/2012-08/67605.htm

搭建MySQL-Cluster集群架构   http://www.linuxidc.com/Linux/2014-05/102218.htm

以上就是 MySQL之——MySQL Cluster集群搭建详解(基于RPM安装包 双管理中心)的内容,更多相关内容请关注PHP中文网(www.php.cn)!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.