1. 下载软件包

wget http://mirrors.163.com/mysql/Downloads/MySQL-5.7/mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz

2. 解压软件包

# 解压
tar xf mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz
# 移动
mv mysql-5.7.36-linux-glibc2.12-x86_64 /usr/local/mysql

3. 编辑配置文件

3.1 配置文件

# vi /etc/my.cnf
[mysqld]
datadir=/usr/local/mysql/data/
socket=/tmp/mysql.sock
symbolic-links=0

[mysqld_safe]
log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid

!includedir /etc/my.cnf.d

如果没有这个目录手动建立下

mkdir /etc/my.cnf.d

3.2 创建数据目录

mkdir /usr/local/mysql/data

3.3 创建pid文件存放目录

mkdir /var/run/mysqld

3.4 创建启动用户mysql

useradd mysql -s /sbin/nologin

3.5 将上面创建的数据目录及pid文件存放目录权限都改为mysql

chown mysql.mysql /var/run/mysqld/ /usr/local/mysql/  -R

4. 初始化数据库仓库

/usr/local/mysql/bin/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data

4.1 注意

这里如果执行上面命令报如下的错误

2021-12-29 09:33:06 [WARNING] mysql_install_db is deprecated. Please consider switching to mysqld --initialize
2021-12-29 09:33:06 [ERROR]   Child process: /usr/local/mysql/bin/mysqldterminated prematurely with errno= 32
2021-12-29 09:33:06 [ERROR]   Failed to execute /usr/local/mysql/bin/mysqld --bootstrap --datadir=/usr/local/mysql/data --lc-messages-dir=/usr/local/mysql/share --lc-messages=en_US --basedir=/usr/local/mysql
-- server log begin --

解决办法:

yum install libaio numactl -y

5. 添加MySQL全局环境变量

echo "export PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
source /etc/profile

6. 启动MySQL,并设为开机启动

# 复制启动文件
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

# 启动mysql
service mysqld start

7. 更改密码

7.1 查看初始密码

# cat /root/.mysql_secret 
# Password set for user 'root@localhost' at 2021-12-29 10:15:21 
'''显示你的密码'''

7.2 修改密码

mysqladmin -u root password "123456" -p
Enter password: #这里输入上面查看到的密码

7.3 验证密码是否修改成功

mysql -p123456 -e "show databases;"
mysql: [Warning] Using a password on the command line interface can be insecure.
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+

8. 设置远程登录

mysql> grant all on *.* to 'root'@'%' identified by '123456';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
mysql> \q
Bye

9. 设置防火墙通过

firewall-cmd --permanent --add-port=3306/tcp --zone=public
firewall-cmd --reload

标签: mysql

添加新评论