MySQL的完整安装(无报错)和shell脚本一键安装MySQL

安装MySQL的步骤(无报错版本)--11步

1.首先:停止MySQL服务(如果存在)

sudo systemctl stop mysqld 2>/dev/null

2.卸载MySQL相关软件包

sudo yum remove -y mysql* mysql-community*

3.删除MySQL相关文件和目录

sudo rm -rf /var/lib/mysql

sudo rm -rf /var/log/mysqld.log

sudo rm -rf /etc/my.cnf

sudo rm -rf /etc/my.cnf.d/

4.下载 MySQL 5.7 的 YUM 源配置文件

wget https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm -O /tmp/mysql57.rpm

5.安装 MySQL YUM 源

sudo rpm -ivh /tmp/mysql57.rpm

rm -f /tmp/mysql57.rpm

6.验证 YUM 源是否生效

echo "检查YUM源..."

yum repolist enabled | grep mysql

7.安装 MySQL 5.7 服务器

echo "正在安装MySQL 5.7..."

sudo yum install -y mysql-community-server 如果报错,说密钥的问题导致不能正常下载

就在后面再加一个--nogpgcheck,表示跳过密钥

sudo yum install -y mysql-community-server --nogpgcheck

8.启动 MySQL 并设置开机自启

sudo systemctl start mysqld

sudo systemctl enable mysqld

9.检查服务状态

echo "检查MySQL服务状态..."

sudo systemctl status mysqld --no-pager

10.获取临时密码并修改

sudo grep 'temporary password' /var/log/mysqld.log

输出类似:

Note A temporary password is generated for root@localhost: Abc123def456!

记下这个临时密码(Abc123def456! 部分)

然后用临时密码登录 MySQL:

mysql -u root -p

11.修改 root 密码

ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码';

#如果密码太简单,可能会报错 ERROR 1819 (HY000): Your password does not satisfy the

#current policy requirements,此时需要设置更复杂的密码。

一键安装脚本:

停止MySQL服务(如果存在)

sudo systemctl stop mysqld 2>/dev/null

卸载MySQL相关软件包

sudo yum remove -y mysql* mysql-community*

删除MySQL相关文件和目录

sudo rm -rf /var/lib/mysql

sudo rm -rf /var/log/mysqld.log

sudo rm -rf /etc/my.cnf

sudo rm -rf /etc/my.cnf.d/

下载 MySQL 5.7 的 YUM 源配置文件

wget https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm -O /tmp/mysql57.rpm

安装 MySQL YUM 源

sudo rpm -ivh /tmp/mysql57.rpm

rm -f /tmp/mysql57.rpm

验证 YUM 源是否生效

echo "检查YUM源..."

yum repolist enabled | grep mysql

安装 MySQL 5.7 服务器

echo "正在安装MySQL 5.7..."

sudo yum install -y mysql-community-server 如果报错,说密钥的问题导致不能正常下载

就在后面再加一个--nogpgcheck,表示跳过密钥

sudo yum install -y mysql-community-server --nogpgcheck

启动 MySQL 并设置开机自启

sudo systemctl start mysqld

sudo systemctl enable mysqld

检查服务状态

echo "检查MySQL服务状态..."

sudo systemctl status mysqld --no-pager

获取临时密码

echo "获取临时密码..."

TEMP_PWD=(sudo grep 'temporary password' /var/log/mysqld.log \| awk '{print NF}')

if -z "$TEMP_PWD" ; then

echo "错误:未找到临时密码!请检查日志文件 /var/log/mysqld.log"

exit 1

fi

echo "临时密码: $TEMP_PWD"

提示用户手动修改密码(因为需要交互)

echo "请执行以下命令完成密码修改:"

echo "mysql -u root -p"

echo "输入临时密码后执行:"

echo "ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新密码';"

echo "注意: 密码需符合策略(至少8位,含大小写字母、数字和特殊字符)"

可选:自动尝试修改密码(非交互式,但可能因策略失败)

echo "尝试自动修改密码(可能因策略失败)..."

mysql -u root -p"$TEMP_PWD" <<EOF

ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPassword123';

EOF

相关推荐
这个DBA有点耶2 小时前
NULL不是空——数据库里最反直觉的设计,90%新人踩过的坑
数据库·mysql·代码规范
这个DBA有点耶3 小时前
AI写的SQL跑崩了生产库,这锅谁背?
数据库·人工智能·程序员
阿里云大数据AI技术4 小时前
阿里云 EMR AI 助手正式发布:从问答工具到全栈智能运维助手
运维·人工智能
镜舟科技4 小时前
Databricks 再提 LTAP,AI 时代的数据底座为何重回大一统叙事?
数据库·架构·agent
Databend5 小时前
从湖仓升级为 Agent 时代的数据控制面,Snowflake 和 Databricks 有哪些布局
大数据·数据库·agent
ClouGence8 小时前
SQL Server CDC 能放到 Always On 备库读吗?一文讲透原理与实践
数据库·sql server
先吃饱再说1 天前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
Nturmoils1 天前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
SkyWalking中文站1 天前
认识 Horizon UI · 6/17:Trace 探索器
运维·监控·自动化运维
Databend1 天前
Agent 轨迹分析与归因的数据工程实践
大数据·数据库·agent