搭建mysql集群,使用Percona XtraDB Cluster搭建

Percona XtraDB Cluster提供的特性有:
1.同步复制,事务要么在所有节点提交或不提交。
2.多主复制,可以在任意节点进行写操作。
3.在从服务器上并行应用事件,真正意义上的并行复制。
4.节点自动配置。
5.数据一致性,不再是异步复制。

开始搭建:

 

三台服务器:先设置hosts
10.0.0.231  node1
10.0.0.232  node2
10.0.0.233  node3

 

1:下载安装文件

   官网:https://www.percona.com

   下载地址:https://www.percona.com/downloads/Percona-XtraDB-Cluster-LATEST/Percona-XtraDB-Cluster-5.7.18-29.20/binary/tarball/Percona-XtraDB-Cluster-5.7.18-rel15-29.20.1.Linux.x86_64.ssl100.tar.gz

2:解压到指定目录

tar -zxvf  Percona-XtraDB-Cluster-5.7.18-rel15-29.20.1.Linux.x86_64.ssl101.tar.gz  -C /usr/localln -s  Percona-XtraDB-Cluster-5.7.18-rel15-29.20.1.Linux.x86_64.ssl101  mysql5.7

3:创建目录

mkdir -p /usr/local/mysql5.7/data
mkdir -p /usr/local/mysql5.7/tmp

4:创建用户

useradd -d /usr/local/mysql5.7 -m mysql
chown -R /usr/local/mysql5.7 
chmod 600 /usr/local/mysql5.7 

 

5:配制/etc/my.cnf

note1:

[mysqld]server_id=231
datadir=/usr/local/mysql5.7/data
user=mysql
basedir=/usr/local/mysql5.7default_storage_engine=Innodbinnodb_buffer_pool_size=1610612736
innodb_log_file_size=104857600wsrep_provider=/usr/local/mysql5.7/lib/libgalera_smm.so
wsrep_cluster_address=gcomm://10.0.0.231,10.0.0.232,10.0.0.233
wsrep_node_name=node1
wsrep_node_address=10.0.0.231
wsrep_cluster_name=pxc_sampson
wsrep_sst_auth=sst:sampson
wsrep_sst_method=rsync
wsrep_slave_threads=2
pxc_strict_mode=ENFORCING
innodb_autoinc_lock_mode=2
wsrep_provider_options="debug=1;gcache.size=1G"

note2:

[mysqld] 
server_id=232
datadir=/usr/local/mysql5.7/data
user=mysql
basedir=/usr/local/mysql5.7default_storage_engine=Innodbinnodb_buffer_pool_size=1610612736
innodb_log_file_size=104857600wsrep_provider=/usr/local/mysql5.7/lib/libgalera_smm.so
wsrep_cluster_address=gcomm://10.0.0.231,10.0.0.232,10.0.0.233
wsrep_node_name=node2
wsrep_node_address=10.0.0.232
wsrep_cluster_name=pxc_sampson
wsrep_sst_auth=sst:sampson
wsrep_sst_method=rsync
wsrep_slave_threads=2
pxc_strict_mode=ENFORCING
innodb_autoinc_lock_mode=2
wsrep_provider_options="debug=1;gcache.size=1G"

note3:

[mysqld]server_id=233
datadir=/usr/local/mysql5.7/data
user=mysql
basedir=/usr/local/mysql5.7 
default_storage_engine=Innodbinnodb_buffer_pool_size=1610612736
innodb_log_file_size=104857600wsrep_provider=/usr/local/mysql5.7/lib/libgalera_smm.so
wsrep_cluster_address=gcomm://10.0.0.231,10.0.0.232,10.0.0.233
wsrep_node_name=node3
wsrep_node_address=10.0.0.233
wsrep_cluster_name=pxc_sampson
wsrep_sst_auth=sst:sampson
wsrep_sst_method=rsync
wsrep_slave_threads=2
pxc_strict_mode=ENFORCING
innodb_autoinc_lock_mode=2
wsrep_provider_options="debug=1;gcache.size=1G"

 6:初始化mysql

  note1,note2,note3

 /usr/local/mysql5.7/bin/mysql_install_db  --defaults-file=/etc/my.cnf  --user=mysql --basedir=/usr/local/mysql5.7/ --datadir=/usr/local/mysql5.7/data/

7:启动第一个节点

  node1:

/usr/local/mysql5.7/bin/mysqld_safe --ledir=/usr/local/mysql5.7/bin --wsrep-new-cluster &
完成后Ctrl+C

8:修改mysql密码

查看初使密码cat /root/.mysql_secret 假设初始密码为abcde修改初始密码先进入mysql命令行:mysql -u root -p输入初始密码abcde修改初始密码:SET PASSWORD = PASSWORD('123456');

9:启动第二,三个节点

  node2,node3

/usr/local/mysql5.7/bin/mysqld_safe --ledir=/usr/local/mysql5.7/bin &

10:查看

 登录mysql

 mysql>show global status like 'wsrep_cluster_size';mysql>show global status like 'wsrep%';

11:设置开机启动

cp /usr/local/mysql5.7/support-files/mysql.server /etc/init.d/mysql …复制启动文件 chmod 755 /etc/init.d/mysql    …增加执行权限 chkconfig --add mysql    …加入自动启动项chkconfig  --level 2345 mysql on  …设置MySQL 在345 等级自动启动

12:环境变量

export PATH=/usr/local/mysq5.7l/bin:$PATH

 

转载于:https://www.cnblogs.com/feiyun126/p/7268967.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/371579.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用NoSQL实现实体服务–第4部分:Java EE

现在,我已经准备好了框架式的合同优先型Web服务,并使用Ektorp和CouchDB创建了数据访问层 ,是时候将它们连接到一个可以正常工作的实体服务中了 。 为此,我将使用Java EE和Glassfish 3.1。 值得注意的是,对于他的那种R&…

yii2之DetailView小部件

DetailView小部件用于展示单条数据记录&#xff0c;可配置属性很少&#xff0c;使用也很简单&#xff0c;直接贴代码&#xff0c;一看就懂&#xff01; yii小部件数据小部件DetailView的使用示例&#xff1a; <? DetailView::widget([model > $user,//模型对象&#xff…

克隆安装oracle,Oracle 之 Cloning $oracle_home (克隆安装oracle软件)

用途&#xff1a;Cloning an Oracle Home &#xff0c; 可以免去多台机器重复安装oracle软件1、停止相关进程[rootnode1 bin]# ./crsctl stop cluster -all2、打包 dbhome_1 目录[rootnode1 11.2.0]# cd /u01/app/oracle/product/11.2.0/[rootnode1 11.2.0]# tar -zcvpf db_1.b…

gitlab的安装和基本维护

基本介绍 GitLab是一个自托管的Git项目仓库&#xff0c;可以自己搭建个人代码管理的仓库&#xff0c;功能与github类似。 安装 操作系统&#xff1a;CentOS6.5 gitlab官网下载安装地址&#xff1a;https://about.gitlab.com/downloads/#centos6 1.安装依赖的包 yum install cur…

Spring配置文件和Java配置

我的上一个博客介绍了Spring 3.1的配置文件&#xff0c;并解释了使用它们的业务案例&#xff0c;并演示了它们在Spring XML配置文件中的用法。 但是&#xff0c;似乎很多开发人员更喜欢使用Spring的基于Java的应用程序配置&#xff0c;因此Spring设计了一种使用带有现有Configu…

php 删除单个文件大小,php删除指定大小的jpg文件

function actionZmdel(){//set_time_limit(0);$dir dirname(dirname(dirname(dirname(__FILE__))))./2012jxgwyimg;$dirarr scandir($dir);echo 正在删除...;foreach($dirarr as $subdir){if($subdir ! . && $subdir ! ..){$path $dir./.$subdir;$files glob($path…

2017寒假零基础学习Python系列之函数之 函数之定义可变参数

若想让函数接受任意个参数&#xff0c;就可以定义一个可变的参数&#xff1a; def fn(*args): print args fn() >>>() fn(1,2,5,6) >>>(1,2,5,6) 原理是Python解释器把传入的一组参数封装在一个tuple传递给可变参数&#xff0c;因此在函数内部&#xff0c;直…

在Windows上构建OpenJDK

通过做一些实验&#xff0c;我发现手头提供JDK源代码来进行一些更改&#xff0c;使用它等等通常很有用。因此&#xff0c;我决定下载并编译该野兽。 显然&#xff0c;这花了我一些时间&#xff0c;尽管我最初的想法是&#xff0c;它应该和运行make命令一样简单&#xff1a;&…

unity中怎么在InspectorI面板加LOGO

转载于:https://www.cnblogs.com/unitySPK/p/7278925.html

oracle stream 主键,oracle stream配置向导

1. Stream 的工作原理Stream 是Oracle Advanced Queue技术的一种扩展应用&#xff0c;这种技术最基本的原理就是收集事件&#xff0c;把时间保存在队列中&#xff0c;然后把这些事件发布给不同的订阅者。从DBA的角度来说&#xff0c;就是把捕获Oracle数据库产生的Redo日志&…

JavaScriptDOM 十四. Event DOM的属性

1 <!DOCTYPE html>2 <html>3 <head>4 <title></title>5 <script type"text/javascript">6 7 /*8 1. --------------- Event DOM 事件DOM 用户交互 ------------------9 当事件发生时, 执行JS功能代码10 11 常用…

五、创建Bean的三种方式

五、创建Bean的三种方式转载于:https://www.cnblogs.com/ljiwej/p/7280614.html

重写到边缘–充分利用它! 在GlassFish上!

现代应用程序开发的一个重要主题是重写。 自从Java Server Faces引入和Java EE 6中新的轻量级编程模型以来&#xff0c;您一直在努力使用漂亮&#xff0c;简单&#xff0c;可添加书签的URL。 PrettyFaces很久以来就一直存在&#xff0c;即使它在3.3.3版本中可以说是成熟的&…

php yii框架路由,yii框架路由配置

首先要在服务器配置(httpd.conf)中开启重写模块#开启重写模块&#xff0c;将其前面的#去掉LoadModule rewrite_module modules/mod_rewrite.so#Directory中允许覆盖开启## Possible values for the Options directive are "None", "All",# or any combinat…

前端面试总结二

一、响应式和自适应的区别&#xff1a; 联系(相同点)&#xff1a; 响应式设计(responsive design)和自适应设计(adaptive design)都是用来解决网页在不同分辨率的屏幕和设备上展示的一项技术(或者说一种方法)。 区别&#xff1a; 响应式设计&#xff1a;通过CSS Media Queries(…

“Spring入门”教程系列

大家好&#xff0c; 我很高兴向您介绍“Spring入门”教程系列&#xff01; 这是一系列文章&#xff0c;最初由我们的JCG合作伙伴 Michal Vrtiak在vrtoonjava博客上撰写 。 本系列中将逐步创建一个时间表管理应用程序&#xff0c;并且每个教程都在前一个教程的基础上构建。 处…

【看番杂感】Clannad系列观后感(剧透慎入)

前言 之前看第一季时&#xff0c;弹幕里总有人在刷“写作cl&#xff0c;读作人生”。当时我想&#xff0c;盲目把一部催泪番上升到人生的高度&#xff0c;这未免有些武断&#xff0c;也是对作品本身的不尊重。当看完第二季的我蓦然回首&#xff0c;发现这才是最最贴切的评价&am…

oracle+tns+01106,TNS-01106:Listener using listener name already been started

最近在做HACMP双机互备切换测试的时候&#xff0c;发现一个问题&#xff1a;A节点的listener端口为1521 &#xff0c;B节点的listener端口为1522&#xff0c;为什么两个节点的监听要用不同的端口号&#xff1f;当时AB机使用不同端口是基于如下考虑&#xff1a;HACMP的切换数据库…

Centos7 开机显示 ERST: Failed to get Error Log Address Range” 导致无法开机解决方法

开机显示 ERST: Failed to get Error Log Address Range” 导致无法开机&#xff0c;也无法重新安装系统&#xff0c;解决方法&#xff1a;开机进入BIOS &#xff0c; 关闭ACPI选项即可正常开机 转载于:https://www.cnblogs.com/zhangjianghua/p/6376811.html

Spring MVC 3模板和Apache Tiles

对于任何Web应用程序而言&#xff0c;有效的设计考虑因素是使用模板引擎&#xff08;或工具&#xff09;&#xff0c;并且由于具有Spring的“可插拔”特性&#xff0c;因此集成模板机制&#xff08;例如Apache Tiles&#xff09;的确要容易得多。 在这篇简单的文章中&#xff0…