下载mysql二进制包
1.创建目录
mkdir /application
2.下载并解压二进制安装包,将mysql的系统文件放在以下目录
/application/mysql
3.创建用户[root@db01 ~]# useradd -s /sbin/nologin mysql
4.设置环境变量
vim /etc/profile #打开profile 文件
export PATH=/application/mysql/bin:$PATH #添加环境变量
[root@db01 ~]# source /etc/profile #让修改生效
[root@db01 ~]# mysql -V #查看版本
5.创建数据路径并授权
1.添加一块新磁盘模拟数据盘
2.格式化并挂载磁盘
[root@db01 ~]# mkfs.xfs /dev/sdb
[root@db01 ~]# mkdir /data
[root@db01 ~]# blkid
[root@db01 ~]# vim /etc/fstab
[root@db01 ~]# UUID="32ea4103-da7e-48b6-a3b9-5c5b637b81fb" /data xfs defaults 0 0
[root@db01 ~]# mount -a
[root@db01 ~]# df -h
授权
chown -R mysql.mysql /application/*
chown -R mysql.mysql /data
初始化数据(创建系统数据)
mysql5.7 版本的初始化命令
[root@db01 ~]# mkdir /data/mysql/data -p
[root@db01 ~]# chown -R mysql.mysql /data
[root@db01 ~]# mysqld --initialize --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data
--initialize 参数:
-
对于密码复杂度进行定制:12位,4种
-
密码过期时间:180
-
给root@localhost用户设置临时密码
4.5.7 配置文件的准备
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
4.5.8 启动数据库
- sys-v
[root@db01 /etc/init.d]# cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld
[root@db01 /etc/init.d]# service mysqld restart
- systemd
注意: sysv方式启动过的话,需要先提前关闭,才能以下方式登录
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
systemctl start mysqld
- 如何分析处理MySQL数据库无法启动
5.1 without updating PID 类似错误
查看日志:
在哪?
/data/mysql/data/主机名.err
/data/mysql/data/localhost.localdomain.err
[ERROR] 上下文
可能情况:
/etc/my.cnf 路径不对等
/tmp/mysql.sock文件修改过 或 删除过
数据目录权限不是mysql
参数改错了
6.管理员密码的设定(root@localhost)
[root@db01 ~]# mysqladmin -uroot -p password oldboy123
Enter password:
- 管理员用户密码忘记了?
--skip-grant-tables #跳过授权表
--skip-networking #跳过远程登录
7.1 关闭数据库
[root@db01 ~]# /etc/init.d/mysqld stop
Shutting down MySQL.. SUCCESS!
7.2 启动数据库到维护模式
[root@db01 ~]# mysqld_safe --skip-grant-tables --skip-networking &
7.3 登录并修改密码
mysql> alter user root@'localhost' identified by '1';
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 '1';
Query OK, 0 rows affected (0.01 sec)
7.4 关闭数据库,正常启动验证