Linux安装Mysql
前提
使用Centos7进行安装教程
1、查看是否安装过mysql
rpm -qa | grep mysql

如果你查看出来有东西,可以使用下面命令将其删除(xxx 为文件全名)
rpm -e xxx
# 强力删除模式,如果使用上面命令删除时,提示有依赖的其它文件,则用该命令可以对其进行强制删除
rpm -e --nodeps mysql
如果没有直接进入第2步
2、下载官方Mysql安装包:https://downloads.mysql.com/archives/community/
选择对应的包,如下5.7:

已下载安装包:mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz
Mysql安装与配置
1、上传安装包至服务器并进行解压
# 创建安装包上传路径
mkdir -p /usr/local/mysql
# 进入到该目录下
cd /usr/local/mysql
#(解压后可删除安装包,节省空间)
tar -zxvf mysql-5.7.35-linux-glibc2.12-x86_64.tar.gz
# 重命名解压后的mysql安装目录
mv mysql-5.7.35-linux-glibc2.12-x86_64 /usr/local/service/mysql/mysql-5.7.35
# 进入该目录
cd /usr/local/service/mysql/mysql-5.7.35
2、创建用户组和用户
Root用户是最高权限用户,所以一般都是创建用户和用户组,防止最高权限用户进行操作。
# 添加用户组,命名为mysql
groupadd mysql
# 创建用户mysql,并指定所属群组为mysql
useradd -r -g mysql mysql
3、赋权,用用户组和用户具有操作权限
注意:.表示本级目录,一定要保证当前所在文件夹是/usr/local/service/mysql/mysql-5.7.35中
# 变更mysql用户组有操作当前文件夹权限
chgrp -R mysql .
# 变更mysql用户具有操作本级目录权限
chown -R mysql .
# 上面两个命令也可换成一条命令
chown -R mysql:mysql ./
4、配置Mysql
# 创建数据存储目录
mkdir /usr/local/service/mysql/mysql-5.7.35/data/
# 创建数据日志目录
mkdir /usr/local/service/mysql/mysql-5.7.35/log/
# 创建临时文件目录
mkdir /usr/local/service/mysql/mysql-5.7.35/tmp/
# 创建运行文件目录
mkdir /usr/local/service/mysql/mysql-5.7.35/run/
# 创建启动错误日志
touch /usr/local/service/mysql/mysql-5.7.35/log/mysqld_safe_error.log
# 创建默认的错误日志目的地
touch /usr/local/service/mysql/mysql-5.7.35/log/alert.log
# 创建慢查询日志文件
touch /usr/local/service/mysql/mysql-5.7.35/log/slow.log
# 创建通用查询日志文件的
touch /usr/local/service/mysql/mysql-5.7.35/log/general.log
5、编辑my.cnf配置文件
将以下内容写入配置文件 /etc/my.cnf
# mysqld_safe脚本启动时读取的配置
[mysqld_safe]
# 存放 MySQL 后台程序 pid 的文件位置
pid-file=/usr/local/service/mysql/mysql-5.7.35/run/mysqld.pid
# 启用TLS版本。 TLSv1已弃用
tls_version = TLSv1.2,TLSv1.3
# 启动错误日志
log-error=/usr/local/service/mysql/mysql-5.7.35/log/mysqld_safe_error.log
# 本地 mysql 客户端程序的配置块
[mysql]
# 本地 mysql 客户端连接的端口
port=3306
# 本地 mysql 客户端命令行提示信息
prompt=\\u@\\d \\r:\\m:\\s>
# 本地 mysql 客户端字符集
default-character-set=utf8mb4
# 开启命令补全
no-auto-rehash
# 所有mysql客户端程序读取的配置块
[client]
# 连接端口
port=3306
# mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体文件
socket=/usr/local/service/mysql/mysql-5.7.35/run/mysql.sock
# mysql服务端程序mysqld、mysqld_safe和mysqld_multi的配置文件
[mysqld]
# 进程崩溃时生成core file dump文件,便于程序调试和问题排查
core-file
#隐式默认值的TIMESTAMP类型在未来的版本中被弃用,减少警告
explicit_defaults_for_timestamp=true
# 该参数指定了安装 MySQL 的安装路径(mysql安装目录),填写全路径可以解决相对路径所造成的问题。
basedir=/usr/local/service/mysql/mysql-5.7.35
# 该参数指定MySQL的数据文件的存放目录,数据库文件即我们常说的 MySQL data 文件。
datadir=/usr/local/service/mysql/mysql-5.7.35/data
# 临时目录
tmpdir=/usr/local/service/mysql/mysql-5.7.35/tmp
# 用于错误消息的区域设置。默认值是en_US。服务器将参数转换为语言名,并将其与lc_messages_dir的值结合,以生成错误消息文件的位置。
lc_messages=zh_CN
# 错误消息所在的目录。服务器使用该值和lc_messages的值来生成错误消息文件的位置。
lc_messages_dir=/usr/local/service/mysql/mysql-5.7.35/share
# 默认的错误日志目的地。如果目标是控制台,则值为stderr。否则,目标是一个文件,log_error值是文件名。
log-error=/usr/local/service/mysql/mysql-5.7.35/log/alert.log
# 慢查询日志文件名。默认值是host_name-slow.log,但可以通过slow_query_log_file选项更改初始值。
slow_query_log_file=/usr/local/service/mysql/mysql-5.7.35/log/slow.log
# 通用查询日志文件的名称。默认值是host_name.log,但初始值可以通过general_log_file选项更改。
general_log_file=/usr/local/service/mysql/mysql-5.7.35/log/general.log
# mysql的主机和客户机在同一host上的时候,使用unix domain socket做为通讯协议的载体文件
socket=/usr/local/service/mysql/mysql-5.7.35/run/mysql.sock
# 服务端字符集
character-set-server=utf8mb4
# 此变量控制写入错误日志的消息中的时间戳的时区,以及写入文件的一般查询日志和慢查询日志消息中的时间戳的时区。
log_timestamps=SYSTEM
# 操作系统中可用于mysqld的文件描述符的数量。
open_files_limit=61535
# 同时允许的最大客户端连接数。
max_connections=1000
# mysql_stmt_send_long_data() C API函数发送的一个包或任何生成/中间字符串的最大大小,或任何参数的最大大小。默认是64MB。
max_allowed_packet=1G
# 如果设置为0,表名将按指定的方式存储,并且比较区分大小写。如果设置为1,表名将以小写形式存储在磁盘上,比较不区分大小写。如果设置为2,则表名按给定值存储,但以小写进行比较。此选项也适用于数据库名称和表别名。
lower_case_table_names=1
# 慢查询日志是否开启。取值为0(或OFF)表示关闭日志,取值为1(或ON)表示打开日志。默认值取决于是否给出——slow_query_log选项。日志输出的目标由log_output系统变量控制;如果该值为NONE,则即使启用了日志,也不会写入任何日志项。
slow_query_log=1
# validate_password插件的加载方法
plugin-load-add=validate_password.so
# validate-password在服务器启动时使用该选项来控制插件的激活
validate-password=FORCE_PLUS_PERMANENT
6、初始化
# 将安装目录的所有权授予用户、属组 mysql:mysql
chown -R mysql:mysql /usr/local/service/mysql/mysql-5.7.35
chmod -R 755 /usr/local/service/mysql/mysql-5.7.35
# 初始化数据库 如果初始化报权限错误,排查上一级目录的权限是否满足
cd /usr/local/service/mysql/mysql-5.7.35
./bin/mysqld --initialize --user=mysql --basedir=/usr/local/service/mysql/mysql-5.7.35/ --datadir=/usr/local/service/mysql/mysql-5.7.35/data/
# 再次将安装目录的所有权授予用户、属组 mysql:mysql
chown -R mysql:mysql /usr/local/service/mysql/mysql-5.7.35
chmod -R 755 /usr/local/service/mysql/mysql-5.7.35
7、配置开机自启动service服务文件
把启动脚本 mysql.server 放到开机初始化目录 /etc/init.d/ ,同时改名为 mysqld
cp /usr/local/service/mysql/mysql-5.7.35/support-files/mysql.server /etc/init.d/mysqld
8、配置环境变量(可选)
# 添加到 PATH
echo 'export PATH=/usr/local/mysql/bin:$PATH' | sudo tee -a /etc/profile
source /etc/profile
# 或者创建软链接
sudo ln -s /usr/local/mysql/bin/mysql /usr/bin/mysql
sudo ln -s /usr/local/mysql/bin/mysqldump /usr/bin/mysqldump
sudo ln -s /usr/local/mysql/bin/mysqladmin /usr/bin/mysqladmin
9、启动
启动、重启、关闭mysql服务
# start:启动 restart:重启 关闭:stop
service mysqld start
Mysql必须在启动状态下,才可修改密码(下一步操作)
9.1、将mysql加入到system服务中(可选)
先关闭数据库:service mysqld stop
添加system服务,如下:
tee /usr/lib/systemd/system/mysqld.service << EOF
[Unit]
Description=MySQL Server
After=network.target
After=syslog.target
[Service]
User=mysql
Group=mysql
Type=forking
PIDFile=/usr/local/mysql/data/mysqld.pid
ExecStart=/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf --daemonize
ExecStop=/usr/local/mysql/bin/mysqladmin -u root -pAbc@123456 shutdown
Restart=on-failure
RestartPreventExitStatus=1
PrivateTmp=false
LimitNOFILE=5000
[Install]
WantedBy=multi-user.target
EOF
ExecStart路径应指向你的MySQL安装目录中的mysqld_safe或mysqld脚本。ExecStop路径应指向你的MySQL安装目录中的mysqladmin脚本。- 确保
User和Group设置为运行MySQL服务的用户和组。通常,这是mysql用户。 - 确保
--defaults-file指向正确的配置文件路径。 - --daemonize : 后台运行
- LimitNOFILE=5000:用于限制 MySQL 数据库进程可打开的文件描述符数量的参数,该值默认设置为5000,可能在高并发或大量文件操作场景下导致“Too many open files”错误。
- RestartPreventExitStatus=1:退出码 1 结束时,systemd 不会触发自动重启,帮助避免服务在非临时性故障或预期关闭时无限重启,从而提升系统稳定性。
- PrivateTmp=true:用于增强服务的安全性和隔离性,systemd 会为该服务创建一个独立的临时文件系统目录(通常基于 tmpfs),并将其挂载到服务的命名空间中的
/tmp和/var/tmp路径,使服务只能访问自己的私有临时目录,与其他服务或进程隔离,从而防止非预期的文件交互或冲突,但需注意, 这种隔离可能导致依赖共享/tmp目录的工具(如jps、jconsole)无法正常工作,因为进程信息会写入私有目录而非全局/tmp,解决方法是根据需求将PrivateTmp设置为false或调整工具配置。
# 添加 user=mysql到/etc/my.cnf的【mysqld】下
vim /etc/my.cnf
# [mysqld]
# user=mysql
# 给予权限
chown mysql:mysql /etc/my.cnf
chmod 755 /etc/my.cnf
# 重新加载system服务
systemctl daemon-reload
# 查看服务状态
systemctl status mysqld
10、操作Mysql数据库
在mysql日志文件中找到初始密码,命令如下:
tail -n 1000 /usr/local/service/mysql/mysql-5.7.35/log/alert.log | grep root@localhost

root@localhost后面的内容,就是本机root用户的初始密码,需要记录下来。
初始密码: >Al+fUZdP6ZU
进入到mysql编辑模式
# 进入mysql安装目录
cd /usr/local/service/mysql/mysql-5.7.35
# 登录mysql
mysql -u root -p
# 如果提示没有mysql命令,需要添加软连接
ln -s /usr/local/service/mysql/mysql-5.7.35/bin/mysql /usr/bin/mysql
会提示要求输入密码,此时输入在mysql日志文件中找到初始密码,此时不能做任何事情,因为MySQL默认必须修改密码之后才能操作数据库
注意:输入密码期间不能输入其他内容,输入密码是隐藏不可见的
-- 修改为自己的密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
注意:Mysql密码设定有默认策略,简单的密码设置不了,还会报以下错误

解决方法:
可先按照策略修改一个密码,然后使用密码重新登录过后修改策略,策略修改后即可重复修改密码语句进行重新设定密码
默认策略:大写+小写+数字+符号
进入到mysql命令后,出现[mysql>]
此时就可以根据自己需要创建数据库、创建表等CRUD操作。
远程访问
--进入mysql数据库--
use mysql;
--修改user表的root账户的host内容--
update user set host="%" where user="root";
--刷新修改立即生效--
flush privileges;
注意:若修改后还无法远程连接,检查防火墙是否开放数据库相关端口或关闭防火墙后尝试重新远程连接。
11、策略修改
对比Mysql8.+和Mysql5.7及一下版本策略,注意变量名称的不同
-- 查看当前策略
SHOW VARIABLES LIKE 'validate_password%';


-- 更改密码验证规则 Mysql5.7-
set global validate_password_policy=0;
set global validate_password_length=1;
-- 更改密码验证规则 Mysql8.*
set global validate_password.policy=0;
set global validate_password.length=1;
更改完成之后就可以重复修改密码步骤进行再次修改啦
12、忘记密码后修改方式
进入/etc/my.cnf在[mysql]下添加skip-grant-tables启动安全模式
vim /etc/my.cnf
登录mysql,输入密码时直接回车
mysql -u root -p
修改密码:update user set password = password("root123") where user = 'root';
刷新权限:flush privileges;
退出Mysql编辑模式:exit
注意:密码修改完成后,将/etc/my.cnf配置文件中的skip-grant-tables去掉
13、设置用户具有远程访问权限
进入mysql编辑模式:mysql -u root -p
执行远程连接权限赋予命令:GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root123' WITH GRANT OPTION;
刷新权限:flush privileges;
mysql8.0需要分步骤执行,命令如下:
-- 创建新用户
create user 'admin'@'%' identified by 'password';
-- 执行授权
GRANT ALL PRIVILEGES ON *.* TO 'admin'@'%';
-- 刷新
flush privileges;
-- 授权远程
ALTER USER 'admin'@'%' IDENTIFIED WITH mysql_native_password BY 'password';
-- 刷新
flush privileges;
退出Mysql编辑模式:exit

浙公网安备 33010602011771号