052-linux安装MySQL数据库-保姆级

linux安装MySQL数据库

1.mysql数据库安装

1.1.安装环境

操作系统版本:CentOS-stream9

数据库版本:mysql-8.0.4

服务名称 服务器IP
mysql-master 192.168.6.137
shell 复制代码
[root@mysql-master ~]# ip a


关闭安全限制

shell 复制代码
[root@mysql-master ~]# sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
[root@mysql-master ~]# setenforce 0
[root@mysql-master ~]# systemctl stop firewalld
[root@mysql-master ~]# systemctl disable firewalld

1.2.安装部署

安装yum包

shell 复制代码
[root@mysql-master ~]# yum install epel-release -y


安装数据库所需依赖环境

shell 复制代码
[root@mysql-master ~]# yum install pv gcc libxml2 libxml2-devel net-snmp net-snmp-devel libevent libevent-devel curl curl-devel java-devel yum-utils -y

安装 REMI 软件仓库的配置文件

shell 复制代码
[root@mysql-master ~]# yum install https://rpms.remirepo.net/enterprise/remi-release-9.rpm -y

从 MySQL 官方软件仓库下载 MySQL 8.0 社区版的软件仓库配置文件

shell 复制代码
[root@mysql-master ~]# wget https://repo.mysql.com/mysql80-community-release-el9-1.noarch.rpm

安装MySQL 8.0 社区版的软件仓库配置文件

shell 复制代码
[root@mysql-master ~]# rpm -Uvh mysql80-community-release-el9-1.noarch.rpm


安装 MySQL 社区版的开发库

shell 复制代码
[root@mysql-master ~]# yum install mysql-community-devel --nogpgcheck -y

安装 MySQL 社区版的服务器软件

shell 复制代码
[root@mysql-master ~]# yum install mysql-community-server --nogpgcheck -y

启动数据库

shell 复制代码
[root@mysql-master ~]# systemctl start mysqld
[root@mysql-master ~]# systemctl enable mysqld

查看数据库初始密码

shell 复制代码
[root@mysql-master ~]# cat /var/log/mysqld.log | grep password

设置数据库远程登陆

shell 复制代码
[root@mysql-master ~]# mysql> use mysql;
[root@mysql-master ~]# mysql> update user set Host='%' where User='root';
[root@mysql-master ~]# mysql> flush privileges;

更新root密码

shell 复制代码
[root@mysql-master ~]# mysql> alter user 'root'@'localhost' identified by 'Admin@123321';
[root@mysql-master ~]# mysql> flush privileges;

2.mysql数据库主备实现

2.1.主备配置

2.1.1.前置环境准备

服务名称 服务器IP 角色 数据库版本
mysql-01 192.168.6.136 master mysql-8.0.4
mysql-02 192.168.6.135 slave mysql-8.0.4

1、确保2台数据库之间的网络是互通的

2、配置期间不能有数据写入

2.1.2.master数据库服务器配置

编辑数据库配置文件

shell 复制代码
vi /etc/my.cnf

cat  >> /etc/my.cnf <<EOF 
#服务器 id,随意,但要唯一
server-id = 1  
#二进制文件存放路径
log-bin = mysql-bin 
#参数用于排除自带的数据库。  
binlog-ignore-db = mysql 
binlog-ignore-db = information_schema
binlog-ignore-db = performance_schema
#二进制日志格式,建议使用ROW格式以获得更好的兼容性和可靠性。
binlog-format = ROW 
EOF

创建同步用户

shell 复制代码
use mysql;
#创建用户
create user 'user_sync'@'%' identified by 'mypassword';
#授权账号复制权限
grant replication slave on *.* to 'user_sync'@'%';
#刷新配置
FLUSH PRIVILEGES;

输出File 和 Position 值

shell 复制代码
show master status;
#记下输出中的 File 和 Position 值,后续在从库上使用
| mysql-bin.000001 |      157 | 

2.1.3.slave数据库服务器配置

编辑数据库配置文件

shell 复制代码
cat >>/etc/my.cnf <<EOF

server-id = 2
#中继日志文件的名称,用于从主服务器接收二进制日志事件。
relay-log = mysql-relay-bin 
#从服务器的二进制日志文件的名称。
log_bin = mysql-bin 
#不同步相关的库
replicate-ignore-db = mysql 
replicate-ignore-db = information_schema
replicate-ignore-db = performance_schema
EOF

编辑同步数据库指向

shell 复制代码
stop slave;
change master to
 master_host = '192.168.6.136',
 master_user = 'user_sync',
 master_password = 'mypassword',
  #主服务器数据库上的file值(不能有空格)
 master_log_file = 'mysql-bin.000001',
  #主服务器数据库的Position值
 master_log_pos = 157,
 get_master_public_key=1;

start slave;

显示同步情况

shell 复制代码
show slave status\G
当Slave_IO_Running和Slave_SQL_Running均为Yes时,代表正在保持同步

2.2.主备故障切换

3.mysql数据库主主实现

相关推荐
星霜笔记23 分钟前
Docker 部署 MariaDB+phpMyAdmin+Nextcloud 完整教程
运维·数据库·docker·容器·mariadb
一只栖枝3 小时前
华为 HCIE 大数据认证中 Linux 命令行的运用及价值
大数据·linux·运维·华为·华为认证·hcie·it
poemyang5 小时前
十年大厂员工终明白:MySQL性能优化的尽头,是对B+树的极致理解
mysql·pagecache·顺序i/o·局部性原理·b tree·b+ tree
wuicer5 小时前
ubuntu 20.04 安装anaconda以及安装spyder
linux·运维·ubuntu
wyiyiyi6 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
天宇_任7 小时前
Mysql数据库迁移到GaussDB注意事项
数据库·mysql·gaussdb
cui__OaO7 小时前
Linux软件编程--线程
linux·开发语言·线程·互斥锁·死锁·信号量·嵌入式学习
小狗爱吃黄桃罐头7 小时前
正点原子【第四期】Linux之驱动开发篇学习笔记-1.1 Linux驱动开发与裸机开发的区别
linux·驱动开发·学习
小晶晶京京8 小时前
day34-LNMP详解
linux·运维·服务器
画个太阳作晴天8 小时前
A12预装app
linux·服务器·前端