首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >centos7安装mysql(完整)

centos7安装mysql(完整)

作者头像
执笔记忆的空白
修改2025-07-10 15:05:34
修改2025-07-10 15:05:34
1.3K00
代码可运行
举报
文章被收录于专栏:Java日常Java日常
运行总次数:0
代码可运行

一、下载安装包

官网5.7版本:https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.29-1.el7.x86_64.rpm-bundle.tar

二、安装

使用tar命令解压

代码语言:javascript
代码运行次数:0
运行
复制
tar -xvf mysql-5.7.29-1.el7.x86_64.rpm-bundle.tar

安装新版mysql前,需将系统自带的mariadb-lib卸载

代码语言:javascript
代码运行次数:0
运行
复制
rpm -qa|grep mariadb

mariadb-libs-5.5.60-1.el7_5.x86_64 删除自带的mariadb

代码语言:javascript
代码运行次数:0
运行
复制
rpm -e --nodeps mariadb-libs-5.5.60-1.el7_5.x86_64

为了避免出现权限问题,给mysql解压文件所在目录赋予最大权限

代码语言:javascript
代码运行次数:0
运行
复制
chmod -R 777 mysql

严格按照顺序安装:mysql-community-common-5.7.29-1.el7.x86_64.rpm、mysql-community-libs-5.7.29-1.el7.x86_64.rpm、mysql-community-client-5.7.29-1.el7.x86_64.rpm、mysql-community-server-5.7.29-1.el7.x86_64.rpm这四个包

代码语言:javascript
代码运行次数:0
运行
复制
rpm -ivh mysql-community-common-5.7.29-1.el7.x86_64.rpm
代码语言:javascript
代码运行次数:0
运行
复制
rpm -ivh mysql-community-libs-5.7.29-1.el7.x86_64.rpm
代码语言:javascript
代码运行次数:0
运行
复制
rpm -ivh mysql-community-client-5.7.29-1.el7.x86_64.rpm
代码语言:javascript
代码运行次数:0
运行
复制
rpm -ivh mysql-community-server-5.7.29-1.el7.x86_64.rpm

如果安装过程中出现这个错误就在后面添加 --force --nodeps,这可能是由于yum安装了旧版本的GPG keys造成的

三、配置数据库

代码语言:javascript
代码运行次数:0
运行
复制
vim /etc/my.cnf

添加这三行

代码语言:javascript
代码运行次数:0
运行
复制
skip-grant-tables
character_set_server=utf8
init_connect='SET NAMES utf8'

skip-grant-tables:跳过登录验证 character_set_server=utf8:设置默认字符集UTF-8 init_connect=‘SET NAMES utf8’:设置默认字符集UTF-8

四、启动mysql服务

设置开机启动

代码语言:javascript
代码运行次数:0
运行
复制
systemctl start mysqld.service

启动mysq

代码语言:javascript
代码运行次数:0
运行
复制
mysql

五、设置密码和开启远程登录

5.1先设置一个简单的密码

代码语言:javascript
代码运行次数:0
运行
复制
update mysql.user set authentication_string=password('123456') where user='root';

立即生效

代码语言:javascript
代码运行次数:0
运行
复制
flush privileges;

退出mysql并停止mysql服务

代码语言:javascript
代码运行次数:0
运行
复制
systemctl stop  mysqld.service

编辑my.cnf配置文件将:skip-grant-tables这一行注释掉

重启mysql服务

代码语言:javascript
代码运行次数:0
运行
复制
systemctl start mysqld.service

再次登录mysql

代码语言:javascript
代码运行次数:0
运行
复制
mysql -uroot -p123456

输入命令错误再执行重设密码

代码语言:javascript
代码运行次数:0
运行
复制
set password=password('123456');

5.2设置密码策略(这步可以跳过)

如果想要设置简单一点的密码就要设置密码策略,否则设置简单的密码会出错 查看密码策略

代码语言:javascript
代码运行次数:0
运行
复制
 SHOW VARIABLES LIKE 'validate_password%'; 

1)、validate_password_length 固定密码的总长度; 2)、validate_password_dictionary_file 指定密码验证的文件路径; 3)、validate_password_mixed_case_count 整个密码中至少要包含大/小写字母的总个数; 4)、validate_password_number_count 整个密码中至少要包含阿拉伯数字的个数; 5)、validate_password_policy 指定密码的强度验证等级,默认为 MEDIUM;

设置密码的验证强度等级,设置 validate_password_policy 的全局参数为 LOW

代码语言:javascript
代码运行次数:0
运行
复制
set global validate_password_policy=LOW;

只要设置密码的长度小于 3 ,都将自动设值为 4

代码语言:javascript
代码运行次数:0
运行
复制
 set global validate_password_length=4;

5.3开放端口

开放3306端口

代码语言:javascript
代码运行次数:0
运行
复制
firewall-cmd --zone=public --add-port=3306/tcp --permanent

–zone #作用域 –add-port=80/tcp #添加端口,格式为:端口/通讯协议 –permanent #永久生效,没有此参数重启后失效

重启防火墙

代码语言:javascript
代码运行次数:0
运行
复制
firewall-cmd --reload

5.4开启远程登录

代码语言:javascript
代码运行次数:0
运行
复制
grant all privileges on *.* to 'root'@'%' identified by '123123' with grant option;

by后面的就是远程登录密码,远程登录密码可以和用户密码不一样

六、参考

CSDN:https://blog.csdn.net/HM_1011000000/article/details/92831688 CSDN:https://blog.csdn.net/hello_world_qwp/article/details/79551789

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/03/17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、下载安装包
  • 二、安装
  • 三、配置数据库
  • 四、启动mysql服务
  • 五、设置密码和开启远程登录
    • 5.1先设置一个简单的密码
    • 5.2设置密码策略(这步可以跳过)
    • 5.3开放端口
    • 5.4开启远程登录
  • 六、参考
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档