环境
cpu | mem | hostname | public ip | cluster ip | CentOS | MariaDB |
---|---|---|---|---|---|---|
双核 | 2GB | mariadb_1 | 10.0.0.231 | 10.10.10.1 | 7.5 | 10.1.33 |
双核 | 2GB | mariadb_2 | 10.0.0.232 | 10.10.10.2 | 7.5 | 10.1.33 |
双核 | 2GB | mariadb_3 | 10.0.0.233 | 10.10.10.3 | 7.5 | 10.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 的节点服务器是最后关闭的数据库,数据最全,所以下次集群启动时应从这台节点服务器启动