Heim Datenbank MySQL-Tutorial MySQL双机热备+Heartbeat集群+自动故障转移(2秒)

MySQL双机热备+Heartbeat集群+自动故障转移(2秒)

Jun 07, 2016 pm 05:08 PM
集群

环境说明:本环境由两台mysql 数据库和heartbeat 组成,一台的ip 为192.168.10.197,一台为192.168.10.198,对外提供服务的vip 为

环境说明:本环境由两台mysql 数据库和heartbeat 组成,一台的ip 为192.168.10.197,,一台为192.168.10.198,对外提供服务的vip 为192.168.10.200

备注:heartbeat 本身是不能做到服务不可用自动切换的,所以用结合额外的脚本才可以做到,本文中提到的moniter 脚本即为实现某个mysql 服务不可用的时候自动切换的还可以自动报警

安装和配置过程分为如下几步:

第一部分:mysql 的安装配置
1 安装
1.1. 添加mysql 运行所需的用户和组
groupadd mysql
useradd -g mysql mysql
1.2. 解压安装
tar mysql-5.1.26-rc-linux-x86_64-glibc23.tar.gz
mv mysql-5.1.26-rc-linux-x86_64-glibc23 /usr/local/mysql/
chown -R mysql:mysql /usr/local/mysql
1.3. 复制主配置文件和启动脚本
cd /usr/local/mysql
cp support-files/my-medium.cnf /etc/my.cf
cp support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
1.4. 初始化数据库
cd /usr/local/mysql
scripts/mysql_install_db --user=mysql
1.5. 更改数据目录的所有者和组

2
chown -R mysql:mysql ./data
1.6. 注册mysql 为系统服务
chkconfig --add mysqld
chkconfig --levels 2345 mysqld on
1.7. 输出环境变量
#Vi /etc/profile(内容如下)
PATH=$PATH:/usr/local/mysql/bin
# source /etc/profile
1.8. 设置数据库密码
service mysqld start
mysqladmin password 123456(密码自己定这里只是个例子)
1.9. 开启root 远程访问权限
mysql –p123456
mysql> grant all on *.* to root@'%' identified by '123456';
Query OK, 0 rows affected (0.00 sec)
mysql> flush privileges;
mysql> quit
2 参数设置
2.1. 创建相关目录并设置权限
mkdir /usr/local/mysql/binlog/
chown –R mysql:mysql /usr/local/mysql/binlog/
touch /var/log/mysql.log
chown –R mysql:mysql /var/log/mysql.log
2.2. 添加同步复制的账号(主库和辅库的设置相同)
[root@master ~]# mysql -p
Enter password:(输入root 密码)
mysql> grant all on *.* to qiangao identified by '123456';(其中的账号和密码要
和配置文件中指定的相同)
mysql> flush privileges;
2.3. 修改主配置文件

3

注意:其中ip 要互相指向对方的ip 按实际情况来设定,用户名和密码要和上文的用户名密
码保持一致
主库设置
vi /etc/my.cnf(用如下内容覆盖原有内容)
################################################
##########
[client]
port = 3306
socket = /tmp/mysql.sock
[mysqld]
################### auto_increment
###########################
auto_increment_offset = 1
auto_increment_increment = 2
############## other options ##############
default-character-set = utf8
default-storage-engine = InnoDB
default-table-type = INNODB
max_connections = 800
port = 3306
socket = /tmp/mysql.sock
skip-locking
########## MyISAM options #################
myisam_max_sort_file_size = 10G
myisam_max_extra_sort_file_size = 10G
myisam_sort_buffer_size = 10M
myisam_repair_threads = 1
################ select cache options ##################
read_buffer_size = 2M
read_rnd_buffer_size = 16M
bulk_insert_buffer_size = 5M

4
max_allowed_packet = 1M
table_cache = 2048
query_cache_size = 32M
query_cache_limit = 2M
sort_buffer_size = 8M
join_buffer_size = 8M
thread_concurrency = 8
################ index cache options ##################
key_buffer_size = 32M
key_buffer_size = 32M
################# master #########################
server-id = 1
log-bin=/usr/local/mysql/binlog/master-bin
binlog_format=mixed
relay-log=/usr/local/mysql/binlog/mysqld-relay-bin
##################### slave
##########################
relay-log=/usr/local/mysql/binlog/slave-relay-bin
master-host=192.168.10.198
master-user=qiangao
master-password=123456
master-connect-retry=10
############## log ##################
log-error=/var/log/mysql.log
######### INNODB #########
innodb_file_per_table
#+++++++ log ++++++++#
innodb_log_buffer_size = 10M
innodb_mirrored_log_groups = 1
innodb_log_files_in_group = 3

5
innodb_log_file_size = 50M
innodb_flush_log_at_trx_commit = 0
#innodb_log_archive = 0
#+++++++ System buffer +++++++#
innodb_buffer_pool_size = 1024M
innodb_additional_mem_pool_size = 40M
#+++++++ Other +++++++#
innodb_file_io_threads = 4
innodb_lock_wait_timeout = 5
innodb_force_recovery = 0
innodb_fast_shutdown = 1
innodb_thread_concurrency = 8
innodb_lock_wait_timeout = 50
transaction-isolation = READ-COMMITTED
[mysqldump]
quick
max_allowed_packet = 16M
[mysql]
no-auto-rehash
# Remove the next comment character if you are not familiar with SQL
#safe-updates
[isamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 2M
write_buffer = 2M
[myisamchk]
key_buffer = 128M
sort_buffer_size = 128M
read_buffer = 2M

linux

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Der Knoten verlässt Proxmox VE vollständig und tritt dem Cluster wieder bei Der Knoten verlässt Proxmox VE vollständig und tritt dem Cluster wieder bei Feb 21, 2024 pm 12:40 PM

Szenariobeschreibung für die vollständige Evakuierung von Knoten aus ProxmoxVE und den erneuten Beitritt zum Cluster. Wenn ein Knoten im ProxmoxVE-Cluster beschädigt ist und nicht schnell repariert werden kann, muss der fehlerhafte Knoten sauber aus dem Cluster entfernt und die verbleibenden Informationen bereinigt werden. Andernfalls können neue Knoten, die die vom fehlerhaften Knoten verwendete IP-Adresse verwenden, dem Cluster nicht normal beitreten, nachdem der fehlerhafte Knoten, der sich vom Cluster getrennt hat, repariert wurde, obwohl dies nichts mit dem Cluster zu tun hat Sie können nicht auf die Webverwaltung dieses einzelnen Knotens zugreifen. Im Hintergrund werden Informationen zu anderen Knoten im ursprünglichen ProxmoxVE-Cluster angezeigt, was sehr ärgerlich ist. Entfernen Sie Knoten aus dem Cluster. Wenn es sich bei ProxmoxVE um einen hyperkonvergenten Ceph-Cluster handelt, müssen Sie sich bei jedem Knoten im Cluster (außer dem Knoten, den Sie löschen möchten) auf dem Hostsystem Debian anmelden und den Befehl ausführen

So verwenden Sie Docker zum Verwalten und Erweitern von Clustern mit mehreren Knoten So verwenden Sie Docker zum Verwalten und Erweitern von Clustern mit mehreren Knoten Nov 07, 2023 am 10:06 AM

Im heutigen Cloud-Computing-Zeitalter ist die Containerisierungstechnologie zu einer der beliebtesten Technologien in der Open-Source-Welt geworden. Das Aufkommen von Docker hat Cloud Computing komfortabler und effizienter gemacht und ist zu einem unverzichtbaren Werkzeug für Entwickler sowie Betriebs- und Wartungspersonal geworden. Die Anwendung der Multi-Node-Cluster-Technologie basierend auf Docker ist weit verbreitet. Durch die Bereitstellung von Clustern mit mehreren Knoten können wir Ressourcen effizienter nutzen, die Zuverlässigkeit und Skalierbarkeit verbessern und außerdem flexibler bei der Bereitstellung und Verwaltung sein. Als Nächstes stellen wir die Verwendung von Docker vor

Optimierungsmethode der Datenbank in einer PHP-Umgebung mit hoher Parallelität Optimierungsmethode der Datenbank in einer PHP-Umgebung mit hoher Parallelität Aug 11, 2023 pm 03:55 PM

Optimierungsmethode der Datenbank in einer PHP-Umgebung mit hoher Parallelität Mit der rasanten Entwicklung des Internets müssen sich immer mehr Websites und Anwendungen hohen Herausforderungen der Parallelität stellen. In diesem Fall wird die Optimierung der Datenbankleistung besonders wichtig, insbesondere für Systeme, die PHP als Backend-Entwicklungssprache verwenden. In diesem Artikel werden einige Datenbankoptimierungsmethoden in einer PHP-Umgebung mit hoher Parallelität vorgestellt und entsprechende Codebeispiele gegeben. Verwenden von Verbindungspooling In einer Umgebung mit hoher Parallelität kann das häufige Erstellen und Zerstören von Datenbankverbindungen zu Leistungsengpässen führen. Daher kann die Verwendung von Verbindungspooling erfolgen

Was sind die häufigsten Cluster in PHP? Was sind die häufigsten Cluster in PHP? Aug 31, 2023 pm 05:45 PM

Zu den gängigen Clustern in PHP gehören LAMP-Cluster, Nginx-Cluster, Memcached-Cluster, Redis-Cluster und Hadoop-Cluster. Detaillierte Einführung: 1. LAMP-Cluster. LAMP bezieht sich auf eine Kombination aus Linux, Apache, MySQL und PHP. In einem LAMP-Cluster wird die gleiche Anwendung ausgeführt und über einen Lastausgleichsdienst ausgeglichen 2. Nginx-Cluster, Nginx ist ein Hochleistungs-Webserver und so weiter.

Methode zur Servercluster-Implementierung in der Workerman-Dokumentation Methode zur Servercluster-Implementierung in der Workerman-Dokumentation Nov 08, 2023 pm 08:09 PM

Workerman ist ein leistungsstarkes PHPSocket-Framework, das es PHP ermöglicht, asynchrone Netzwerkkommunikation effizienter abzuwickeln. In der Dokumentation von Workerman finden Sie detaillierte Anweisungen und Codebeispiele zur Implementierung eines Serverclusters. Um einen Servercluster zu implementieren, müssen wir zunächst das Konzept eines Serverclusters klären. Ein Servercluster verbindet mehrere Server mit einem Netzwerk, um die Systemleistung, Zuverlässigkeit und Skalierbarkeit durch die gemeinsame Nutzung von Lasten und Ressourcen zu verbessern. In Workerman können Sie die folgenden zwei Methoden verwenden

So verwenden Sie MongoDB zur Implementierung von Daten-Clustering- und Lastausgleichsfunktionen So verwenden Sie MongoDB zur Implementierung von Daten-Clustering- und Lastausgleichsfunktionen Sep 19, 2023 pm 01:22 PM

So verwenden Sie MongoDB zum Implementieren von Daten-Clustering- und Lastausgleichsfunktionen. Einführung: Im heutigen Big-Data-Zeitalter hat das schnelle Wachstum des Datenvolumens höhere Anforderungen an die Datenbankleistung gestellt. Um diesen Anforderungen gerecht zu werden, sind Datenclustering und Lastausgleich zu unverzichtbaren technischen Mitteln geworden. Als ausgereifte NoSQL-Datenbank bietet MongoDB umfangreiche Funktionen und Tools zur Unterstützung von Datenclustering und Lastausgleich. In diesem Artikel wird erläutert, wie Sie mit MongoDB Datenclustering- und Lastausgleichsfunktionen implementieren und spezifischen Code bereitstellen

Welches Linux-Server-Cluster-System? Welche Komponenten sind enthalten? Welches Linux-Server-Cluster-System? Welche Komponenten sind enthalten? Feb 22, 2024 pm 07:55 PM

Linux, der vollständige Name von GNU/Linux, ist ein Unix-ähnliches Betriebssystem, das frei genutzt und verbreitet werden kann. Es ist ein Multi-User-, Multi-Task-, Multi-Thread- und Multi-CPU-Betriebssystem, das auf POSIX basiert. Was ist also ein Linux-Server-Cluster-System? Was sind seine Hauptkomponenten? Im Folgenden finden Sie eine Einführung in den spezifischen Inhalt. Das Linux-Serverclustersystem ist eine verteilte Computerumgebung, die auf dem Linux-Betriebssystem basiert. Es besteht aus mehreren unabhängigen Serverknoten. Diese Knoten sind über Hochgeschwindigkeitsnetzwerke miteinander verbunden, um verschiedene Computeraufgaben gemeinsam auszuführen. Das Clustersystem verfügt über eine hohe Zuverlässigkeit, hohe Leistung und Skalierbarkeit und kann Benutzern eine stabile und leistungsstarke Serviceunterstützung bieten. Durch das Clustersystem können Server effektiv aufgeteilt werden

So implementieren Sie verteilte Container und Cluster in PHP-Microservices So implementieren Sie verteilte Container und Cluster in PHP-Microservices Sep 24, 2023 pm 02:28 PM

So implementieren Sie verteilte Container und Cluster in PHP-Microservices. Bei der Entwicklung heutiger Internetanwendungen und -systeme ist die Microservice-Architektur zu einem beliebten Entwurfsmuster geworden. In der Microservice-Architektur sind verteilte Container und Cluster unverzichtbare Komponenten. In diesem Artikel wird die Implementierung verteilter Container und Cluster in PHP-Microservices vorgestellt und spezifische Codebeispiele bereitgestellt. 1. Das Konzept und die Implementierung verteilter Container. Verteilte Container beziehen sich auf eine Möglichkeit, verschiedene Komponenten einer Anwendung auf verschiedenen Servern bereitzustellen und über Netzwerkkommunikation zusammenzuarbeiten. existieren

See all articles