CentOS7 部署 galera cluster mariadb 10.1

环境

cpumemhostnamepublic ipcluster ipCentOSMariaDB
双核2GBmariadb_110.0.0.23110.10.10.17.510.1.33
双核2GBmariadb_210.0.0.23210.10.10.27.510.1.33
双核2GBmariadb_310.0.0.23310.10.10.37.510.1.33

安装数据库

离线安装

  • 下载 rpm
    • MariaDB-10.1.33-centos7-x86_64-client.rpm
    • MariaDB-10.1.33-centos7-x86_64-common.rpm
    • MariaDB-10.1.33-centos7-x86_64-server.rpm
    • MariaDB-10.1.33-centos7-x86_64-shared.rpm
    • galera-25.3.23-1.rhel7.el7.centos.x86_64.rpm
    • jemalloc-3.6.0-1.el7.x86_64.rpm
  • 安装 rpm
    yum erase mariadb-libs
    rpm -ivh *.rpm
    
  • 安装后会自动执行数据库初始化脚本,如果未执行,可手动运行
    mysql_install_db --user=mysql
    

yum 安装

  • 创建 MariaDB-10.1 的 yum 源文件(就近选择一个)

    #官方
    cat > /etc/yum.repos.d/MariaDB.repo <<-END
    [mariadb]
    name = MariaDB
    baseurl = http://yum.mariadb.org/10.1/centos7-amd64
    gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB
    gpgcheck=1
    END
    #中科大
    cat > /etc/yum.repos.d/MariaDB.repo <<-END
    [mariadb]
    name = MariaDB
    baseurl = https://mirrors.ustc.edu.cn/mariadb/yum/10.1/centos7-amd64
    gpgkey=https://mirrors.ustc.edu.cn/mariadb/yum/RPM-GPG-KEY-MariaDB
    gpgcheck=1
    END
    #上海大学
    cat > /etc/yum.repos.d/MariaDB.repo <<-END
    [mariadb]
    name = MariaDB
    baseurl = https://mirrors.shu.edu.cn/mariadb/yum/10.1/centos7-amd64
    gpgkey=https://mirrors.shu.edu.cn/mariadb/yum/RPM-GPG-KEY-MariaDB
    gpgcheck=1
    END
    
  • 安装 MariaDB

    yum install MariaDB-client MariaDB-server galera
    

启动server

systemctl start mariadb

安全设置

  • 设置root账户密码(推荐)
    mysqladmin -u root password 'password'
    
  • 数据库安全设置(推荐)
    mysql_secure_installation
    

配置Galera Cluster

  • 修改/etc/my.cnf.d/server.cnf如下
    [server]
    innodb_flush_log_at_trx_commit=0
    innodb_buffer_pool_size=1024M #一半内存
    innodb_autoinc_lock_mode=2
    default_storage_engine=InnoDB
    #
    [mysqld]
    #
    [galera]
    wsrep_on=ON
    wsrep_provider = /usr/lib64/galera/libgalera_smm.so
    wsrep_provider_options="gcache.size=300M; gcache.page_size=300M"
    wsrep_cluster_name="mariadb_galera_cluster"
    wsrep_cluster_address = "gcomm://10.10.10.1,10.10.10.2,10.10.10.3"
    wsrep_node_name = mariadb_1 #当前节点名字
    wsrep_node_address = 10.10.10.1 #当前节点地址
    binlog_format=ROW
    wsrep_slave_threads=2
    wsrep_sst_method=rsync
    #
    [embedded]
    #
    [mariadb]
    #
    [mariadb-10.1]
    

停止 server

```bash
systemctl stop mariadb
```

启动集群

  • 启动 galera cluster
    mysqld --wsrep-new-cluster --user=mysql
    
  • 查看集群状态
    show status like 'wsrep_%';
    
  • 在剩余两台服务器启动 server,向集群中添加节点
    systemctl start mariadb
    
  • 再次查看集群状态
    show status like 'wsrep_%';
    

注意事项

  • 防火墙开放 3306、4444 和 4567 端口
  • 关闭 selinux
  • 集群关闭时,/var/lib/mysql/grastate.dat 文件中 safe_to_bootstrap 项为 1 的节点服务器是最后关闭的数据库,数据最全,所以下次集群启动时应从这台节点服务器启动

转载于:https://my.oschina.net/colben/blog/882769

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值