MySQL 5.7.26 二进制版本安装(免安装绿色版)
下载地址
https://downloads.mysql.com/archives/community/
https://cdn.mysql.com/archives/mysql-5.7/mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz
PS:下载一些国外站点软件,用迅雷还是比较管用
下载并上传软件至/opt/software
[root@mysql01 ~]# mkdir -p /opt/software
[root@mysql01 ~]# cd /opt/software/
[root@mysql01 software]# yum install -y lrzsz #文件拖拽软件
[root@mysql01 software]# rz -E
rz waiting to receive.
[root@mysql01 software]# ll
总用量 629756
-rw-r--r-- 1 root root 644869837 4月 18 23:48 mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz
解压软件
[root@mysql01 software]# tar -xvf mysql-5.7.29-linux-glibc2.12-x86_64.tar.gz
[root@mysql01 software]# mkdir /application
[root@mysql01 software]# mv mysql-5.7.26-linux-glibc2.12-x86_64 /application/mysql
[root@mysql01 software]# cd /application/mysql/
[root@mysql01 mysql]# ls
bin COPYING docs include lib man README share support-files
处理原始环境,删除系统自带mariadb-libs,创建mysql用户
[root@mysql01 ~]# rpm -qa | grep mariadb
mariadb-libs-5.5.64-1.el7.x86_64
[root@mysql01 ~]# yum remove mariadb-libs.x86_64 -y
[root@mysql01 ~]# useradd -s /sbin/nologin mysql
[root@mysql01 ~]# id mysql
uid=1001(mysql) gid=1001(mysql) 组=1001(mysql)
设置环境变量
[root@mysql01 ~]# vim /etc/profile
export PATH=/application/mysql/bin:$PATH
[root@mysql01 ~]# source /etc/profile
查看MySQL版本
[root@mysql01 ~]# mysql -V
mysql Ver 14.14 Distrib 5.7.26, for linux-glibc2.12 (x86_64) using EditLine wrapper
[root@mysql01 ~]# mysql --version
mysql Ver 14.14 Distrib 5.7.26, for linux-glibc2.12 (x86_64) using EditLine wrapper
创建数据路径并授权
1.添加一块新磁盘模拟数据盘
2.格式化并挂载
[root@mysql01 ~]# fdisk -l #查看磁盘、分区信息
[root@mysql01 ~]# mkfs.xfs /dev/sdb
[root@mysql01 ~]# blkid #查看磁盘UUID
/dev/sdb: UUID="5b995ceb-96be-4408-9125-51b931c5c543" TYPE="xfs"
[root@mysql01 ~]# vim /etc/fstab
UUID="5b995ceb-96be-4408-9125-51b931c5c543" /data xfs defaults 0 0
[root@mysql01 ~]# mount -a #是将/etc/fstab的所有内容重新加载
3.对MySQL软件和数据目录进行授权
[root@mysql01 ~]# chown -R mysql.mysql /application/*
[root@mysql01 ~]# chown -R mysql.mysql /data
4.初始化数据(创建系统数据)
# 5.6 版本 初始化命令 /application/mysql/scripts/mysql_install_db
# 5.7 版本
[root@mysql01 ~]# mkdir -p /data/mysql/data #创建初始化数据路径
[root@mysql01 ~]# chown -R mysql.mysql /data
方法一
[root@mysql01 ~]# mysqld --initialize --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data
2020-04-19T14:27:50.401324Z 1 [Note] A temporary password is generated for root@localhost: dr7uTgZ/q!JI
5.7说明:
--initialize 参数:
1. 对于密码复杂度进行定制:12位,4种
2. 密码过期时间:180
3. 给root@localhost用户设置临时密码
方法二
--initialize-insecure 参数:
无限制,无临时密码
[root@mysql01 ~]# rm -rf /data/mysql/data/* #先删除方法一初始化信息
[root@mysql01 ~]# mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data
2020-04-19T15:24:41.446386Z 1 [Warning] root@localhost is created with an empty password ! Please consider switching off the --initialize-insecure option.
5.配置文件准备
cat >/etc/my.cnf <<EOF
[mysqld]
user=mysql
basedir=/application/mysql
datadir=/data/mysql/data
socket=/tmp/mysql.sock
server_id=6
port=3306
[mysql]
socket=/tmp/mysql.sock
EOF
6.启动数据库
方法一:
sys-v #centos6中使用
[root@mysql01 ~]# cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld
[root@mysql01 ~]# service mysqld restart
ERROR! MySQL server PID file could not be found!
Starting MySQL.Logging to '/data/mysql/data/mysql01.err'.
.. SUCCESS!
[root@mysql01 ~]# netstat -lnp | grep 3306 #通过端口查看是否启动
tcp6 0 0 :::3306 :::* LISTEN 4982/mysqld
方法二:
systemd #centos7中使用
[root@mysql01 ~]# /etc/init.d/mysqld stop #先关闭方法一中启动的MySQL
Shutting down MySQL.. SUCCESS!
[root@mysql01 ~]# cat >/etc/systemd/system/mysqld.service <<EOF
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/application/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000
EOF
[root@mysql01 ~]# systemctl start mysqld.service
[root@mysql01 ~]# netstat -nlp | grep 3306
tcp6 0 0 :::3306 :::* LISTEN 5134/mysqld
7.如何分析MySQL数据库无法启动情形
查看日志:
在哪?
/data/mysql/data/主机名.err
[ERROR] 上下文
可能情况:
/etc/my.cnf 路径不对等
/tmp/mysql.sock文件修改过 或 删除过
数据目录权限不是mysql
参数改错了
8.修改数据库密码
[root@mysql01 ~]# mysqladmin -uroot -p password
Enter password: #输入旧密码,第一次使用密码为空
New password: #输入新密码
Confirm new password: #再次确认新密码
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.
9.管理员用户密码忘记了
--skip-grant-tables #跳过授权表
--skip-networking #跳过远程登录
1)关闭数据库
[root@mysql01 ~]# /etc/init.d/mysqld stop
Shutting down MySQL.. SUCCESS!
2)启动数据库到维护模式
[root@mysql01 ~]# mysqld_safe --skip-grant-tables --skip-networking &
3)登录并修改密码
[root@mysql01 ~]# mysql
mysql> select user,host from mysql.user; #查看用户信息
mysql> select user,host,authentication_string from mysql.user; #查看用户和密码字段信息
mysql> alter user root@'localhost' identified by '123456'; #关闭认证后无法使用这条命令
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement
mysql> flush privileges; #手动加载刷新授权表
mysql> alter user root@'localhost' identified by '123456'; #再次执行命令重置密码成功
Query OK, 0 rows affected (0.00 sec)
mysql> exit #退出数据库
Bye
4)停止数据库,再正常启动 登录验证修改密码是否成功
[root@mysql01 ~]# /etc/init.d/mysqld stop
Shutting down MySQL..2020-04-20T15:55:40.277521Z mysqld_safe mysqld from pid file /data/mysql/data/mysql01.pid ended
SUCCESS!
[1]+ 完成 mysqld_safe --skip-grant-tables --skip-networking
[root@mysql01 ~]# /etc/init.d/mysqld start
Starting MySQL. SUCCESS!
[root@mysql01 ~]# mysql -uroot -p
Enter password: #输入修改后密码验证