MySQL5.7数据库部署和安装

1. 准备系统环境

Vmawre安装CentOS7 略...

2. 下载MySQL5.7安装包

下载地址:
https://downloads.mysql.com/archives/get/p/23/file/mysql-5.7.38-linux-glibc2.12-x86_64.tar.gz

3. 卸载系统自带的MariaDB

bash 复制代码
sudo yum remove $(rpm -qa | grep mariadb)

4. 解压安装包

bash 复制代码
tar -zxvf mysql-5.7.38-linux-glibc2.12-x86_64.tar.gz -C /usr/local/
mv mysql-5.7.38-linux-glibc2.12-x86_64/ mysql/

5. 创建mysql用户和用户组

bash 复制代码
groupadd mysql
useradd -g mysql mysql

6. 创建mysql数据目录

bash 复制代码
mkdir -p /usr/local/mysql/data

7. 修改mysql安装目录归属mysql用户

bash 复制代码
cd /usr/local/
chown -R mysql:mysql ./mysql

8. 准备mysql的配置文件

在/etc目录下新建my.cnf文件

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

输入以下内容:

bash 复制代码
[mysqld]
pid-file = /usr/local/mysql/data/mysql.pid
# 设置3306端口
port = 3306
# 设置mysql的安装目录
basedir = /usr/local/mysql
# 设置mysql数据库的数据的存放目录
datadir = /usr/local/mysql/data
# 允许最大连接数
max_connections = 100
# 服务器的字符集默认为UTF8MB4
character-set-server=utf8mb4
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 设置max_allowed_packet,防止"Packet for query is too large"错误
max_allowed_packet = 16M
# 设置查询缓冲区的最大长度
query_cache_size = 16M
# 设置innodb缓冲池的大小
innodb_buffer_pool_size = 1G
# 设置innodb日志文件的大小
innodb_log_file_size = 64M
# 设置innodb日志文件的数量
innodb_log_files_in_group = 3
# 设置innodb重做日志的大小
innodb_log_buffer_size = 8M
# 启用查询缓存
query_cache_type = 1
# 设置时区
default-time-zone = '+08:00'

[client]
# 设置客户端连接服务端时默认使用的端口
port = 3306
# 设置客户端字符集
default-character-set = utf8mb4

9. 开始安装

bash 复制代码
cd /usr/local/mysql
./bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

10. 配置mysql启动脚本

bash 复制代码
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
vi /etc/init.d/mysqld

添加以下内容:

bash 复制代码
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data

11. 设置mysql系统服务并开启自启

bash 复制代码
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig --list mysqld

12. 将mysql的bin目录加入到PATH环境变量

bash 复制代码
vi ~/.bash_profile

添加:

bash 复制代码
export PATH=$PATH:/usr/local/mysql/bin
source ~/.bash_profile

13. 首次登陆mysql并修改root账号密码

bash 复制代码
service mysqld start
mysql -u root -p

密码从启动日志中查找:root@localhost:后面的部分即为密码。

14. 设置远程主机登录

sql 复制代码
use mysql;
update user set user.Host='%' where user.User='root';
flush privileges;

15. 验证远程连接

关闭防火墙或开启3306端口。

bash 复制代码
systemctl stop firewalld

用Navicat 远程连接

相关推荐
RestCloud6 小时前
SQL Server到Hive:批处理ETL性能提升30%的实战经验
数据库·api
RestCloud6 小时前
为什么说零代码 ETL 是未来趋势?
数据库·api
ClouGence8 小时前
CloudCanal + Paimon + SelectDB 从 0 到 1 构建实时湖仓
数据库
DemonAvenger15 小时前
NoSQL与MySQL混合架构设计:从入门到实战的最佳实践
数据库·mysql·性能优化
AAA修煤气灶刘哥1 天前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
RestCloud1 天前
揭秘 CDC 技术:让数据库同步快人一步
数据库·api
得物技术1 天前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
可涵不会debug2 天前
【IoTDB】时序数据库选型指南:工业大数据场景下的技术突围
数据库·时序数据库
ByteBlossom2 天前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
麦兜*2 天前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud