Mysql集群
一:集群机器介绍
四台机器:
1.balance节点安装haproxy和keepalived
机器名:
balance01 172.18.48.1
balance02 172.18.48.2
2.galera节点安装mysql数据库和galera
机器名:
galera01 172.18.48.3
galera02 172.18.48.4
操作系统:ubuntu14.04 server64
注:每台机器/etc/hosts上要写上涉及到的所有对应的ip和主机名
二:balance节点安装
balance节点安装配置haproxy和keepalived
1./etc/sysctl.conf添加
vim /etc/sysctl.conf
net.ipv4.ip_nonlocal_bind=1
2.加载sysctl.conf
sysctl -p
3.安装haproxy和keepalived
apt-get install -y keepalived haproxy
4.创建/var/lib/haproxy
mkdir /var/lib/haproxy
5.把/var/lib/haproxy权限改为root所有
chown root:root /var/lib/haproxy/
6.vim /etc/keepalived/keepalived.conf
balance01添加如下:
global_defs {
notification_email {
root@[YOUR_DOMAIN_NAME]
}
notification_email_from keepalived@[YOUR_DOMAIN_NAME]
smtp_server localhost
smtp_connect_timeout 30
router_id balance01
}
vrrp_script haproxy {
script “killall -0 haproxy”
interval 2
weight 2
}
vrrp_instance 50 {
virtual_router_id 50
advert_int 1
priority 101
state MASTER
interface eth0
virtual_ipaddress {
172.18.48.20 dev eth0
}
track_script {
haproxy
}
}
balance02如下:
global_defs {
notification_email {
root@[YOUR_DOMAIN_NAME]
}
notification_email_from keepalived@[YOUR_DOMAIN_NAME]
smtp_server localhost
smtp_connect_timeout 30
router_id balance02
}
vrrp_script haproxy {
script “killall -0 haproxy”
interval 2
weight 2
}
vrrp_instance 50 {
virtual_router_id 50
advert_int 1
priority 101
state MASTER
interface eth0
virtual_ipaddress {
172.18.48.20 dev eth0
}
track_script {
haproxy
}
}
7.vim /etc/haproxy/haproxy.cfg
balance01上添加如下:
global
chroot /var/lib/haproxy
daemon
group haproxy
log 172.18.48.1 local0
maxconn 4000
pidfile /var/run/haproxy.pid
stats socket /var/lib/haproxy/stats
user haproxy
defaults
log global
maxconn 8000
option redispatch
retries 3
timeout http-request 10s
timeout queue 1m
timeout connect 10s
timeout client 1m
timeout server 1m
timeout check 10s
listen mysql_cluster
bind 172.18.48.20:3306
mode tcp
balance roundrobin
option mysql-check user root
option tcpka
server galera01 172.18.48.3:3306
server galera02 172.18.48.4:3306
balance02添加如下:
global
chroot /var/lib/haproxy
daemon
group haproxy
log 172.18.48.2 local0
maxconn 4000
pidfile /var/run/haproxy.pid
stats socket /var/lib/haproxy/stats
user haproxy
defaults
log global
maxconn 8000
option redispatch
retries 3
timeout http-request 10s
timeout queue 1m
timeout connect 10s
timeout client 1m
timeout server 1m
timeout check 10s
listen mysql_cluster
bind 172.18.48.20:3306
mode tcp
balance roundrobin
option mysql-check user root
option tcpka
server galera01 172.18.48.3:3306
server galera02 172.18.48.4:3306
8.balance节点修改/etc/default/haproxy
ENABLED=1
9.启动keepalived和haproxy
service keepalived restart
service haproxy restart
三:galera节点安装
(一)安装MariaDB,所有galera节点
1.安装软件源
sudo apt-get install software-properties-common
sudo apt-key adv –recv-keys –keyserver hkp://keyserver.ubuntu.com:80 0xcbcb082a1bb943db
sudo add-apt-repository 'deb http://mirrors.hustunique.com/mariadb/repo/10.0/ubuntu trusty main'
2.安装MariaDB
sudo apt-get update
sudo apt-get install mariadb-server
(二)安装galera cluster,所有galera节点
1.安装软件安装源
apt-get install python-software-properties
apt-key adv –recv-keys –keyserver keyserver.ubuntu.com 0xcbcb082a1bb943db
add-apt-repository 'deb http://mirror3.layerjet.com/mariadb/repo/5.5/ubuntu precise main'
apt-get update
2.安装galera包
DEBIAN_FRONTEND=noninteractive apt-get install -y rsync galera mariadb-galera-server
3.配置galera cluster
/etc/mysql/conf.d/galera.cnf
[mysqld]
mysql settings
binlog_format=ROW
default-storage-engine=innodb
innodb_autoinc_lock_mode=2
query_cache_size=0
query_cache_type=0
bind-address=0.0.0.0
galera settings
wsrep_provider=/usr/lib/galera/libgalera_smm.so
wsrep_cluster_name=“my_wsrep_cluster”
wsrep_cluster_address=“gcomm://172.18.48.3,172.18.48.4”
wsrep_sst_method=rsync
4.galera01和galera02关闭mysql
galera01 service mysql stop
galera02 service mysql stop
5.启动集群,第一个启动的节点要加上集群初始化命令,相当于主节点
galera01 service mysql start –wsrep-new-cluster
galera02 service mysql start
6.检查集群规模
galera01 mysql -u root -e 'SELECT VARIABLE_VALUE as “cluster size” FROM INFORMATION_SCHEMA.GLOBAL_STATUS WHERE VARIABLE_NAME=“wsrep_cluster_size”'
+————–+
| cluster size |
+————–+
| 2 |
+————–+
7.在galera上创建数据库,并授权允许远程访问
mysql>create database nova;
mysql>GRANT ALL ON nova.* TO 'nova'@'%' IDENTIFIED BY 'password';
四:balance节点和galera的弹性和容灾
添加新节点时候直接重启服务即可,galera节点必须有一个主节点,即执行如下语句的节点:
service mysql start –wsrep-new-cluster

本文討論了使用MySQL的Alter Table語句修改表,包括添加/刪除列,重命名表/列以及更改列數據類型。

文章討論了為MySQL配置SSL/TLS加密,包括證書生成和驗證。主要問題是使用自簽名證書的安全含義。[角色計數:159]

文章討論了流行的MySQL GUI工具,例如MySQL Workbench和PhpMyAdmin,比較了它們對初學者和高級用戶的功能和適合性。[159個字符]

本文討論了使用Drop Table語句在MySQL中放下表,並強調了預防措施和風險。它強調,沒有備份,該動作是不可逆轉的,詳細介紹了恢復方法和潛在的生產環境危害。

本文討論了在PostgreSQL,MySQL和MongoDB等各個數據庫中的JSON列上創建索引,以增強查詢性能。它解釋了索引特定的JSON路徑的語法和好處,並列出了支持的數據庫系統。

文章討論了使用準備好的語句,輸入驗證和強密碼策略確保針對SQL注入和蠻力攻擊的MySQL。(159個字符)


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

Dreamweaver CS6
視覺化網頁開發工具

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

記事本++7.3.1
好用且免費的程式碼編輯器

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中