MySQL 多主多活 Galera 集群部署使用_MySQL
Galera是一款可以让MySQL同步复制的工具,实现真正的双主、多主,客户端连接到不同的MySQL实例进行读写操作就跟操作同一个实例一样,多个MySQL之间的数据是完全一致的。Galera主要是在保证数据一致性的前提下提高整体读的吞吐量,因此比MySQL自带主从方式更好。
Galera并没有分表分库功能,如果想要使用Galera,又想分表分库,可与Cobar结合使用,Cobar下如果使用Galara可以获得更高的可靠性,数据一致性,避免有些Cobar切换了主从,而另外一些没切换带来的数据不一致问题。
第一步:下载安装
使用galera时,还需要一个Galera库,官方下载地址是http://galeracluster.com/downloads/ 。
Galera需要的MySQL/MariaDB版本有一个额外wsrep的补丁,因此不能直接用普通的版本。MySQL的版本可以从Galera的官网下载到,目前提供5.5和5.6两个版本。
MariaDB的版本可以从MariaDB的官网下载到https://downloads.mariadb.org/mariadb-galera/ ,MariaDB的10.0对应MySQL的5.6。
源码编译galera前需要安装的依赖库有boost,scons,check,openssl的开发版,您可根据自己的情况安装。galera使用scons安装,因此跟常规的命令不同,其实只要执行一个脚本即可。
$ scripts/build.sh
编译后在当前目录下生成libgalera_smm.so文件。
第二步:配置
Galera只需要在MySQL的配置文件my.cnf中增加几行wsrep相关内容即可
[mysqld]
# 配置前面编译出来的libgalera_smm.so文件路径
wsrep_provider = /home/lyw/c2/galera-3-25.3.12/libgalera_smm.so
# 配置整个集群各实例的ip:port
wsrep_cluster_address = 'gcomm://192.168.1.8:24011,192.168.1.8:24021,192.168.1.8:24031'
# 配置自己的ip:port,每个配置各不相同
wsrep_node_address = '192.168.1.8:24011'
其他配置根据自己的情况配置。我这里配置了3个,my11.cnf,my21.cnf,my31.cnf。
第三步:初始化
初始化同MySQL一样,对每个数据库执行一下 mysql_install_db 脚本即可:
$ scripts/mysql_install_db --defaults-file=etc/my11.cnf
$ scripts/mysql_install_db --defaults-file=etc/my21.cnf
$ scripts/mysql_install_db --defaults-file=etc/my31.cnf
第四步:启动
前面配置的三台MySQL,我们先启动第一台,需要设置 --wsrep_cluster_address=gcomm:// 参数:
$ bin/mysqld_safe --defaults-file=etc/my11.cnf --wsrep_cluster_address=gcomm:// &
等待第一台启动成功后,我们启动后面两台,这个时候不需要上面的参数,实际上是使用了配置文件中的值:
$ bin/mysqld_safe --defaults-file=etc/my21.cnf &
$ bin/mysqld_safe --defaults-file=etc/my31.cnf &
这样就整个集群就启动好了,以后如果有某进程挂了,需要重启,就不需要加--wsrep_cluster_address参数。
第五步:测试
启动好后我们要测试下是否真的成功。我这里使用mysql客户端,您可使用自己喜欢的客户端工具,注意这里连接的端口是MySQL的端口,而不是上面Galera的端口。
$ bin/mysql -uroot -h127.0.0.1 -P14011 MariaDB [(none)]> create database lyw; $ bin/mysql -uroot -h127.0.0.1 -P14021 MariaDB [(none)]> show databases like 'lyw'; +----------------+ | Database (lyw) | +----------------+ | lyw | +----------------+ 1 row in set (0.00 sec) $ bin/mysql -uroot -h127.0.0.1 -P14031 MariaDB [(none)]> show databases like 'lyw'; +----------------+ | Database (lyw) | +----------------+ | lyw | +----------------+ 1 row in set (0.00 sec)
可见在一个库里作了一个操作,在其他库中也有了相同的修改,Galera启动成功。
我们也可以查看wsrep相关的参数判断是否启动成功:
MariaDB [(none)]> show variables like 'wsrep_on'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | wsrep_on | ON | +---------------+-------+ MariaDB [(none)]> show status like 'wsrep_connected'; +-----------------+-------+ | Variable_name | Value | +-----------------+-------+ | wsrep_connected | ON | +-----------------+-------+ MariaDB [(none)]> show status like 'wsrep_ready'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | wsrep_ready | ON | +---------------+-------+
wsrep_on 值为ON则说明启动成功。
wsrep_connected值为ON说明连接到了集群。
wsrep_ready值为ON说明已经准备好接受SQL请求了。该值最关键。
wsrep打头的参数都是跟galera相关的,其他的在使用中慢慢研究了。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











ProxmoxVE에서 노드를 완전히 제거하고 클러스터에 다시 합류하는 시나리오 설명 ProxmoxVE 클러스터의 노드가 손상되어 신속하게 복구할 수 없는 경우 결함이 있는 노드를 클러스터에서 완전히 추방하고 잔여 정보를 정리해야 합니다. 그렇지 않으면 결함이 있는 노드가 사용하는 IP 주소를 사용하는 새 노드는 클러스터에 정상적으로 합류할 수 없습니다. 마찬가지로 클러스터에서 분리된 결함이 있는 노드가 복구된 후에는 클러스터와 관련이 없지만 이 단일 노드의 웹 관리에 액세스할 수 없습니다. 백그라운드에서 원래 ProxmoxVE 클러스터의 다른 노드에 대한 정보가 표시되므로 매우 짜증납니다. 클러스터에서 노드를 제거합니다. ProxmoxVE가 Ceph 하이퍼 수렴형 클러스터인 경우 호스트 시스템 Debian에서 클러스터의 모든 노드(삭제하려는 노드 제외)에 로그인하고 명령을 실행해야 합니다.

오늘날의 클라우드 컴퓨팅 시대에 컨테이너화 기술은 오픈 소스 세계에서 가장 인기 있는 기술 중 하나가 되었습니다. Docker의 등장으로 클라우드 컴퓨팅은 더욱 편리하고 효율적이게 되었으며, 개발자와 운영 및 유지 관리 담당자에게 없어서는 안 될 도구가 되었습니다. 다중 노드 클러스터 기술의 적용은 Docker 기반으로 널리 사용됩니다. 다중 노드 클러스터 배포를 통해 리소스를 보다 효율적으로 활용하고, 안정성과 확장성을 향상시키며, 배포 및 관리에 있어 보다 유연해질 수 있습니다. 다음으로 Docker를 사용하는 방법을 소개하겠습니다.

PHP 높은 동시성 환경에서 데이터베이스 최적화 방법 인터넷의 급속한 발전으로 인해 점점 더 많은 웹사이트와 애플리케이션이 높은 동시성 문제에 직면해야 합니다. 이 경우 데이터베이스 성능 최적화가 특히 중요하며, 특히 PHP를 백엔드 개발 언어로 사용하는 시스템의 경우 더욱 그렇습니다. 이 기사에서는 PHP 높은 동시성 환경에서 몇 가지 데이터베이스 최적화 방법을 소개하고 해당 코드 예제를 제공합니다. 연결 풀링 사용 동시성이 높은 환경에서는 데이터베이스 연결을 자주 생성하고 삭제하면 성능 병목 현상이 발생할 수 있습니다. 따라서 연결 풀링을 사용하면

PHP의 일반적인 클러스터에는 LAMP 클러스터, Nginx 클러스터, Memcached 클러스터, Redis 클러스터 및 Hadoop 클러스터가 포함됩니다. 자세한 소개: 1. LAMP 클러스터는 Linux, Apache, MySQL 및 PHP의 조합을 의미합니다. LAMP 클러스터에서는 여러 서버가 동일한 애플리케이션을 실행하고 로드 밸런서를 통해 균형을 유지합니다. 2. Nginx 클러스터, Nginx는 고성능 웹 서버 등입니다.

MongoDB를 사용하여 데이터 클러스터링 및 로드 밸런싱 기능을 구현하는 방법 소개: 오늘날 빅 데이터 시대에 데이터 볼륨의 급속한 증가로 인해 데이터베이스 성능에 대한 요구 사항이 높아졌습니다. 이러한 요구 사항을 충족하기 위해 데이터 클러스터링과 로드 밸런싱은 필수적인 기술적 수단이 되었습니다. 성숙한 NoSQL 데이터베이스인 MongoDB는 데이터 클러스터링 및 로드 밸런싱을 지원하는 풍부한 기능과 도구를 제공합니다. 이 기사에서는 MongoDB를 사용하여 데이터 클러스터링 및 로드 밸런싱 기능을 구현하는 방법을 소개하고 특정 코드를 제공합니다.

Workerman은 PHP가 비동기 네트워크 통신을 보다 효율적으로 처리할 수 있게 해주는 고성능 PHPSocket 프레임워크입니다. Workerman의 문서에는 서버 클러스터를 구현하는 방법에 대한 자세한 지침과 코드 예제가 있습니다. 서버 클러스터를 구현하기 위해서는 먼저 서버 클러스터의 개념을 명확히 해야 합니다. 서버 클러스터는 여러 서버를 네트워크에 연결하여 로드와 리소스를 공유함으로써 시스템 성능, 안정성 및 확장성을 향상시킵니다. Workerman에서는 다음 두 가지 방법을 사용할 수 있습니다.

GNU/Linux의 전체 이름인 Linux는 자유롭게 사용하고 배포할 수 있는 Unix 계열 운영 체제입니다. POSIX 기반의 다중 사용자, 다중 작업, 다중 스레드 및 다중 CPU 운영 체제입니다. 그렇다면 Linux 서버 클러스터 시스템이란 무엇입니까? 주요 구성 요소는 무엇입니까? 다음은 구체적인 내용을 소개합니다. Linux 서버 클러스터 시스템은 Linux 운영 체제를 기반으로 하는 분산 컴퓨팅 환경으로, 여러 개의 독립적인 서버 노드로 구성됩니다. 이러한 노드는 고속 네트워크를 통해 서로 연결되어 다양한 컴퓨팅 작업을 공동으로 수행합니다. 클러스터 시스템은 높은 신뢰성, 고성능, 확장성을 갖추고 있어 사용자에게 안정적이고 강력한 서비스 지원을 제공할 수 있습니다. 클러스터 시스템을 통해 서버를 효과적으로 분할할 수 있습니다.

MySQL 데이터베이스의 클러스터 환경을 구성하는 방법은 무엇입니까? 서문: 인터넷의 발달과 데이터 양의 지속적인 증가로 인해 데이터베이스는 모든 기업에 필요한 핵심 시스템 중 하나가 되었습니다. 동시에 높은 데이터 가용성과 읽기 및 쓰기 성능 요구 사항을 보장하기 위해 데이터베이스 클러스터 환경은 점차 기업의 선택이 되었습니다. 이 글에서는 MySQL 데이터베이스의 클러스터 환경을 구성하는 방법을 소개하고 해당 코드 예제를 제공합니다. 1. 환경 준비 MySQL 데이터베이스의 클러스터 환경을 구성하기 전에 다음과 같은 환경 준비가 완료되었는지 확인해야 합니다. M 설치
