实际案例香港云服务器部署项目中数据库高可用方案解析

2026年5月4日

1. 方案概览与前提条件

- 概览:采用三节点MariaDB Galera集群(节点A/B/C)+ HAProxy负载均衡 + Keepalived虚拟IP,保证读写可用性与自动切换。
- 前提:每台云服务器建议Ubuntu 20.04,内存>=4GB;可用私有网络互通;开放端口TCP 3306, TCP/UDP 4567, TCP 4444, TCP 4568;时间同步(ntp或chrony)。

2. 环境准备与主机设置

- 步骤1:设置主机名并修改/etc/hosts,例如:10.0.0.11 db1 hk, 10.0.0.12 db2 hk, 10.0.0.13 db3 hk。
- 步骤2:关闭swap(sudo swapoff -a)并禁用开机swap,安装chrony并让时间同步(sudo apt install chrony)。

3. 安装MariaDB与依赖

- 在三台机器上执行:sudo apt update && sudo apt install mariadb-server galera-3 rsync socat -y。
- 确认MariaDB版本支持Galera(建议10.3/10.5),并确保mysqld服务已停止以备配置(sudo systemctl stop mariadb)。

4. 配置Galera核心参数(/etc/mysql/mariadb.conf.d/50-server.cnf)

- 在每台机器的[mysqld]段添加:server-id=1(分别改1/2/3);binlog_format=row;default_storage_engine=InnoDB;innodb_autoinc_lock_mode=2。
- 添加wsrep参数:wsrep_on=ON;wsrep_cluster_name="hk_galera_cluster";wsrep_cluster_address="gcomm://10.0.0.11,10.0.0.12,10.0.0.13";wsrep_node_address="本机IP";wsrep_node_name="db1/db2/db3";wsrep_sst_method=xtrabackup-v2(需安装mariadb-backup或xtrabackup)。

5. 初始化第一个节点并加入其余节点

- 第一个节点启动为主集群:sudo galera_new_cluster 或者 sudo systemctl start mariadb 后检查wsrep_cluster_size=1。
- 在第二、第三节点直接启动服务:sudo systemctl start mariadb,然后查看状态:mysql -e "SHOW STATUS LIKE 'wsrep%';" 确认wsrep_cluster_size=3。

6. 创建应用用户与权限同步

- 在任一节点创建用户并确保GTID一致性:mysql -e "CREATE USER 'app'@'%' IDENTIFIED BY 'password'; GRANT ALL ON mydb.* TO 'app'@'%'; FLUSH PRIVILEGES;"。
- 因为Galera同步DDL/DML,用户权限会自动同步到其他节点。

7. 配置HAProxy负载均衡

- 安装:sudo apt install haproxy -y。
- 示例haproxy.cfg:frontend mysql_fe bind *:3306 mode tcp default_backend mysql_be;backend mysql_be mode tcp balance roundrobin option tcp-check server db1 10.0.0.11:3306 check port 3306 inter 2s rise 2 fall 3(为每个节点添加)。重启haproxy。

8. Keepalived配置虚拟IP实现VIP漂移

- 安装:sudo apt install keepalived。
- keepalived.conf示例:配置vrrp_instance VI_1 { state MASTER/ BACKUP; interface eth0; virtual_router_id 51; priority 100/90/80; authentication { auth_type PASS; auth_pass secret } virtual_ipaddress { 10.0.0.100 } }。
- 在主Haproxy节点设置优先级最高,测试停止主节点时VIP漂移到备节点。

9. 防火墙与安全组规则

- 在云控制台或服务器上开放:TCP 3306,TCP/UDP 4567,TCP 4444,TCP 4568,Keepalived使用的VRRP(通常协议47或在内部网允许)。
- 推荐仅允许负载均衡器和应用服务器访问3306,并禁用公网直接访问。

10. 备份与恢复流程(mariabackup)

- 全量备份:sudo mariabackup --backup --target-dir=/data/backup/$(date +%F) --user=root --password='密码'。
- 准备备份:mariabackup --prepare --target-dir=/data/backup/日期。恢复时停止mysql,清空datadir,复制备份并chown mysql,然后启动并加入集群。

11. 验证故障转移与故障演练

- 模拟步骤:1) 在主节点上 sudo systemctl stop mariadb,2) 在应用侧验证连接通过VIP和HAProxy仍能访问到其他节点并写入,3) 检查wsrep_cluster_size变化与数据完整性。
- 建议做定期演练并验证事务一致性与延迟。

12. 常见问题与优化建议

- 建议:调整innodb_buffer_pool_size、禁用不必要的复杂查询、在高延迟网络中避免同步写入热点。
- 监控:使用Prometheus + Grafana或Zabbix采集wsrep指标和延迟告警。

13. 问:为什么选择MariaDB Galera而不是单主主从?答:

问:为什么选择MariaDB Galera而不是单主主从? 答:Galera提供同步复制、任意节点可写、自动节点加入和冲突检测,适合要求高可用低恢复时间的场景;而主从在主节点故障时存在切换复杂性和数据丢失风险。

14. 问:如果发生split-brain怎么办?答:

问:如果发生split-brain怎么办? 答:Galera通过gcomm和quorum机制避免分裂;若出现小概率分裂,先不要随意重启节点,检查wsrep_cluster_size和gtid,使用安全的方式重建集群(将多数节点作为基础,使用备份恢复少数分支)。

15. 问:如何做日常维护与扩容?答:

问:如何做日常维护与扩容? 答:扩容时逐一在新机配置同样my.cnf并启动加入集群;维护时先把节点设为只读、drain haproxy流量再停止服务,做好备份并在低峰期操作。

香港云服务器

来源:实际案例香港云服务器部署项目中数据库高可用方案解析

相关文章
  • 评测便宜的香港云服务器的性能与服务

    在选择云服务器时,价格、性能和服务质量是用户最关心的几个因素。特别是对于希望以较低成本获得高效能的用户来说,评测便宜的香港云服务器显得尤为重要。下面,我们将通过五个问题来详细分析其性能与服务。 1. 便宜的香港云服务器性能如何? 便宜的香港云服务器通常在硬件配置上会有所妥协,但这并不意味着它们的性能不佳。许多服务商提供的入门级服务器配置,虽然
    2026年1月15日
  • 选择正规香港云服务器的标准与建议

    在当今数字化时代,选择合适的云服务器对企业和个人的网络运营至关重要。特别是香港云服务器,因其地理位置和政策优势,受到越来越多用户的青睐。然而,市场上云服务商众多,如何选择一款可靠的云服务器呢?本文将从多个角度为您提供标准与建议,帮助您做出明智的决策。 在选择香港云服务器时,首先需要考虑的就是其可靠性。可靠的云服务器应具备稳定的运行时间和高效的客户支
    2026年1月16日
  • 选择云服务器免费 香港时需要关注的网络与带宽要素

    核心精华 在选择香港区域的云服务器或VPS时,重点在于确认带宽类型与计费模型、链路质量与回程路由、延迟与丢包表现、以及是否配备完善的CDN与DDoS防御。同时评估服务商的SLA、监控能力和多线接入策略。综合这些要素可有效降低访问延迟、控制成本并提升可用性,推荐德讯电讯作为在香港机房和网络优化方面的优选服务商(推荐德讯电讯)。 带宽类型与计费方
    2026年5月24日
  • 华为云香港服务器地址变更对业务的影响以及平滑切换方案

    随着云服务商调整网络策略或底层资源,华为云香港服务器地址变更会对线上业务造成多方面影响。了解这些影响并提前准备,是保证网站、API和游戏业务稳定运行的关键。 首先,IP地址或机房变更会影响域名解析(A记录/AAAA记录)和反向解析(PTR)。若未及时更新DNS,用户将无法访问网站或被导向旧的IP,导致访问中断或服务失败。建议在迁移前降低DNS记录T
    2026年5月27日
  • 选择香港VPS10M的理由和使用场景

    1. 引言 选择合适的VPS(虚拟专用服务器)对于企业和个人用户来说至关重要。香港VPS10M因其优越的网络环境和高效的服务成为许多用户的首选。本文将详细探讨选择香港VPS10M的理由以及适合的使用场景,并提供实际的操作步骤指南。 2. 香港VPS10M的优势 香港VPS10M具备以下几个显著优势:
    2026年1月24日
  • 阿里云香港服务器近期变化对用户的影响

    近年来,随着云计算技术的迅猛发展,越来越多的企业和个人用户选择使用云服务器来满足他们的需求。其中,阿里云作为国内领先的云服务提供商,其在香港地区的服务器也备受关注。近期,阿里云香港服务器发生了一些变化,这对用户的使用体验及选择将产生一定的影响。 首先,阿里云香港服务器的价格策略有所调整。根据最新的信息,阿里云在香港地区的VPS和主机产品的定价变得更
    2025年10月19日
  • 使用腾讯云轻量应用服务器香港ssr的优势

    在现代互联网环境中,选择一款合适的服务器对于企业和个人用户来说至关重要。尤其是对于需要快速访问和稳定连接的应用程序,腾讯云轻量应用服务器(Lighthouse)成为了许多用户的首选。本文将重点讨论腾讯云轻量应用服务器在香港地区使用SSR(科学上网)所带来的优势。 首先,腾讯云轻量应用服务器提供了高性价比的解决方案。与传统的VPS(虚拟专用服务器)相
    2025年12月28日
  • 安全加固 香港云vps-a2能开私服 的防火墙与访问控制实战

    精华总结 在香港云环境部署私服(香港云vps-a2开私服)必须从防火墙与访问控制两方面入手,结合DDoS防御与CDN缓解网络层风险,并做好域名与TLS配置、日志监控与定期更新。实践要点是最小暴露端口、强认证、IP白名单与限流策略,同时备份与自动化运维能显著降低故障恢复时间。为了稳定与运维支持,推荐德讯电讯。 构建多层防火墙策略 对运行私
    2026年4月20日
  • 香港匿名云服务器地址 隐私保护与合规风险全面评估

    随着跨境业务与内容分发需求增长,香港匿名云服务器(包括VPS与专用主机)因网络中立与连通性优势而受关注。本文从隐私保护与合规风险两大维度,评估选择此类服务时应注意的要点,并提供技术与采购建议。 隐私保护方面,匿名云服务器常被理解为减少用户身份直接暴露的服务。实际层面涉及服务器日志策略、WHOIS代理、域名隐私、以及支付信息处理。优质供应商应明确
    2026年5月13日
TG客服-1 TG客服-2 在线客服