Linux 安装Mysql
首先通过 xshell 或者 putty 远程进入Linux 命令行操作界面。
【1】查看是否已经安装 Mysql
1 | rpm -qa | grep mysql |
如果你查看出来有东西,可以使用下面命令将其删除(xxx 为文件全名)
1 | rpm -e xxx |
【2】下载官方 Mysql 包
1 | wget -i -c http: //dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm |
如果安装有提示:Cannot write to ‘mysql57-community-release-el7-10.noarch.rpm’ (No such file or directory),那就是权限不够
可以输入 su root 来解决,然后重新下载。
【3】安装 Mysql 包
1 | yum -y install mysql57-community-release-el7-10.noarch.rpm |
【4】安装 Mysql(这一步需要几分钟,静等安装)
1 | yum -y install mysql-community-server |
如果执行命令过程中提示:Unable to find a match: mysql-community-server
则可以通过命令解决
1 | yum module disable mysql |
如果执行命令过程中提示:
mysql-community-libs-5.7.44-1.el7.x86_64.rpm 的公钥尚未安装或源 “MySQL 5.7 Community Server“ 的 GPG 密钥已安装
则可以通过命令解决
1 | rpm --import https: //repo.mysql.com/RPM-GPG-KEY-mysql-2022 |
【5】 启动 Mysql 服务
1 | systemctl start mysqld.service |
【6】查看 Mysql 运行状态
1 | service mysqld status |
看到这个绿色就表示启动成功了
【7】查看初始密码(黄框部分为初始密码)
1 | grep 'password' / var /log/mysqld.log |
如果能正常查看到,则OK;如果查看不到,则表示没有密码。
【8】进入数据库
1 | mysql -u root -p |
输入命令后,点击回车,会让你输入密码,然后输入刚刚的初始密码(输密码的时候不可见),当然支持粘贴,你可以复制初始密码后,然后粘贴。如果没有密码,直接回车即可。
【9】修改 root 密码(xxxx为密码)
密码尽量复杂些(大小写加符号)。
1 | ALTER USER USER() IDENTIFIED BY 'XXXX' ; |
如果密码过于简单,则会提示如下信息:
如果本地访问Linux数据库失败,则记得看下下面三个配置是否OK。
(1)服务器的防火墙mysql端口3306是否开放
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | 查看防火墙是否已开放3306端口 firewall-cmd --query-port=3306/tcp 设置3306端口为永久开放 firewall-cmd --add-port=3306/tcp --permanent 查看firewalld状态,发现当前是dead状态,即防火墙未开启 systemctl status firewalld 关闭防火墙 systemctl stop firewalld 重启防火墙(设置了新的端口记得先关闭,再重启) systemctl status firewalld |
(2)如果链接提示如下,则是没有允许远程登录。
解决办法:
登录服务器mysql数据库
1 2 3 | 执行 use mysql; 执行 update user set host = '%' where user = 'root' ; 执行 FLUSH PRIVILEGES; |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)