MySQL简介及安装
mysql 官方文档
- https://downloads.mysql.com/archives/community/
MySQL 介绍和安装
1、什么是数据?
-
数据:文字、图片、视频。。。人类认知的数据表现方式
-
计算机:二进制、16进制的机器语言
-
基于数据的重要性和复杂性的不同,我们可能有不同的管理方式。
哪些数据是适合存储到数据库的呢?
-
重要性比较高的
-
关系较复杂的数据
DBMS 数据库管理系统种类
-
RDBMS : Oracle ,MySQL ,PG,MSSQL
-
NoSQL : MongoDB ,Redis ,ES
-
NEWSQL (分布式): TiDB,Spanner ,AliSQL(RDS+DRDS) ,OB ,PolarDB
MySQL 企业版本GA(稳定发布版)选择
-
5.6 : 5.6.34 5.6.36 5.6.38(2017913) 5.6.40
-
5.7 : 5.7.18 ,20(2017913) ,24 ,(上课版本:5726)
-
8.0 : 8014, 8015 ,8016
二进制版本安装
下载并上传软件至/server/tools
mkdir -p /server/tools cd /server/tools/ yum install -y lrzsz tar xf mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz mkdir /application mv mysql-5.7.26-linux-glibc2.12-x86_64 /application/mysql
用户的创建处理原始环境
rpm -qa |grep mariadb yum remove mariadb-libs-5.5.60-1.el7_5.x86_64 -y useradd -s /sbin/nologin mysql
设置环境变量
vim /etc/profile export PATH=/application/mysql/bin:$PATH source /etc/profile mysql -V
创建数据路径并授权
添加一块新磁盘模拟数据盘
格式化并挂载磁盘
mkfs.xfs /dev/sdb mkdir /data # 查看磁盘的uuid blkid vim /etc/fstab UUID="18c98f72-ea42-4629-ba17-e65c8237a0ff" /data xfs defaults 0 0 mount -a df -h
授权
chown -R mysql.mysql /application/* chown -R mysql.mysql /data
初始化数据(创建系统数据)
版本初始化命令
/application/mysql/scripts/mysql_install_d
5.7 版本
mkdir /data/mysql/data -p chown -R mysql.mysql /data mysqld --initialize --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data
说明:
-
--initialize 参数:
-
1. 对于密码复杂度进行定制:12位,4种
-
2. 密码过期时间:180
-
3. 给root@localhost用户设置临时密码
报错:
mysqld: error while loading shared libraries: libaio.so.1: cannot open shared object file: No such file or directory
解决:
- yum install -y libaio-devel
- yum -y install numactl
mysqld --initialize --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data
5.7默认生成一个临时密码,还有过期限制,一般生产不用,直接删掉,使用一下命令
--initialize-insecure 参数:
无限制,无临时密码
\rm -rf /data/mysql/data/* mysqld --initialize-insecure --user=mysql --basedir=/application/mysql --datadir=/data/mysql/data
初始化完成生产的数据
配置文件的准备
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
启动数据库
1. sys-v
cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld service mysqld start
2. 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
systemd管理
systemctl start/stop/restart/status mysqld
如何分析处理MySQL数据库无法启动
without updating PID 类似错误
5.1 without updating PID 类似错误
查看日志:
在哪?
/data/mysql/data/主机名.err
[ERROR] 上下文
可能情况:
/etc/my.cnf 路径不对等
/tmp/mysql.sock文件修改过 或 删除过
数据目录权限不是mysql
参数改错了
管理员密码的设定(root@localhost)
# 一路回车 mysqladmin -uroot -p password 123
使用密码登录
mysql -uroot -p123
管理员用户密码忘记了?
-
--skip-grant-tables #跳过授权表
-
--skip-networking #跳过远程登录
关闭数据库
/etc/init.d/mysqld stop
启动数据库到维护模式
mysqld_safe --skip-grant-tables --skip-networking &
登录并修改密码
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) 关闭数据库,正常启动验证