2019-04-18 MYSQL 介绍

第一章 MySQL 大纲介绍

(1)运维DBA

初级:各版本、各平台安装搭建、升级

中级:体系结构原理、基础管理(启动关闭、初始化配置文件管理、多实例管理、用户权限管理、基本SQL(增删改查))、

日志管理、备份与恢复、主从复制(构建、状态监控)

高级:高可用(MGR、InnoDB Cluster)、高性能(优化)

(2)开发DBA

懂至少一门开发语言 :JAVA、Python

基本SQL语句深入学习(增删改查)、数据库结构设计(建模)

高级SQL:存储过程、函数、触发器、视图、事件

2、老男孩MySQL课程-2019-03月-中级DBA要求(80%以上)

(1)MySQL5.7安装部署(二进制)

(2)MySQL升级步骤扩展

(3)MySQL5.7体系结构原理

(4)MySQL基础管理

(5)基础SQL语句使用

(6)SQL高级应用

(7)Information_schema获取元数据

(8)索引、执行计划管理(基础优化)

(9)存储引擎

(10)日志管理

11)备份与恢复

(12)主从复制及架构演变

(13)传统的高可用及读写分离(MHA&Atlas)

(14)传统分布式架构设计与实现-扩展(Mycat--->DBLE,DRDS)

(15)MySQL5.7高可用及分布式架构-扩展(MGR,InnoDBCluster)

(16)MySQL优化(安全、性能)

(17)MySQL监控(zabbix、Open-falcon)

(18)RDS(阿里云课程) *****额外要会的:Redismongodb了解:PGOracle

第二章: MySQL 介绍和安装

1、什么是数据?

数据:文字、图片、视频。。。人类认知的数据表现方式
计算机:二进制、16进制的机器语言
基于数据的重要性和复杂性的不同,我们可能有不同的管理方式。

哪些数据是适合存储到数据库的呢?
重要性比较高的
关系较复杂的数据

2、什么是数据库管理系统(DBMS)?

RDBMS: 关系型数据库管理系统
比较适合于,安全级别要求高的数据以及关系较复杂的数据

NoSQL:非关系型数据库管理系统
适合于高性能存取数据,一般是配合RDBMS进行使用的
针对大数据处理分析,分布式架构更加擅长

3、数据库管理系统种类

RDBMS :
MySQL 、Oracle、MSSQL(SQL Server)、PG

NoSQL:Not Only SQL
键-值(key-value):Redis, memcached
文档(document):Mongodb

4.1 MySQL行业主流版本:

5.6  
5.7    
8.0(现在开始研究新特性

4.2 企业版本选择(MySQL分支版本),笔试题

Oracle:
MySQL官方版
红帽 :
MariaDB
Percona:
PerconaDB

4.3 版本选择建议要上新环境

1.一般选择官方主流版本:5.6,5.7
2.GA(稳定发布版)
3.6-12月的产品版本

4.4 课程版本:

5.7.20 二进制安装,其他安装方式自己扩展

4.5 如何获取MySQL软件

企业版:Enterprise , 互联网行业一般不选择.
社区版本:选择
源码包:source code .tar.gz
通用二进制
面试题:
你们公司用什么版本数据库? 具体什么小版本号?
5.6.20 5.6.34 5.6.36 5.6.38 5.6.40
5.7.18 5.7.20 5.7.22

5、MySQL二进制安装

5.1.创建软件目录:

[root@db01 ~]# mkdir -p /app/

上传软件到此目录

5.2. 解压并改名为mysql

[root@db01 app]# mv mysql-5.7.20-linux-glibc2.12-x86_64 mysql
[root@db01 app]# ls -l /app/mysql/
total 36
drwxr-xr-x  2 root root   4096 Mar  4 14:55 bin
-rw-r--r--  1 7161 31415 17987 Sep 13  2017 COPYING
drwxr-xr-x  2 root root     55 Mar  4 14:55 docs
drwxr-xr-x  3 root root   4096 Mar  4 14:55 include
drwxr-xr-x  5 root root    229 Mar  4 14:55 lib
drwxr-xr-x  4 root root     30 Mar  4 14:55 man
-rw-r--r--  1 7161 31415  2478 Sep 13  2017 README
drwxr-xr-x 28 root root   4096 Mar  4 14:55 share
drwxr-xr-x  2 root root     90 Mar  4 14:55 support-files

修改环境变量:
vim /etc/profile
export PATH=/app/mysql/bin:$PATH
[root@db01 bin]# source /etc/profile

5.3. 建立mysql用户和组(如果已有可忽略)

useradd mysql

5.4. 创建相关目录并修改权限

mkdir /data/mysql -p
chown -R mysql.mysql /app/*
chown -R mysql.mysql /data/*

5.5 初始化数据(建库)

方法一:

初始化数据,初始化管理员的临时密码
mysqld --initialize --user=mysql --basedir=/app/mysql --datadir=/data/mysql

image.png

报错原因: Linux系统中缺少libaio-devel 软件包
解决:
yum install -y libaio-devel

image.png
报错原因
error while loading shared libraries: libnuma.so.1: 
yum -y install numactl

报错原因:
在/data/mysql 存在文件
解决:
\rm -rf /data/mysql/*

新特性重要说明:

5.7开始,MySQL加入了全新的 密码的安全机制:
1.初始化完成后,会生成临时密码(显示到屏幕上,并且会往日志中记一份)
2.密码复杂度:长度:超过12位? 复杂度:字符混乱组合
3.密码过期时间180天

方法二 :
初始化数据,初始化管理员的密码为空

\rm -rf  /data/mysql/*
[root@db01 ~]# mysqld --initialize-insecure  --user=mysql --basedir=/app/mysql --datadir=/data/mysql

注释:5.6初始化的区别

/application/mysql/scripts/mysql_install_db  --user=mysql --datadir=/application/mysql/data --basedir=/application/mysql

5.6 书写默认配置文件

vim /etc/my.cnf
[mysqld]
user=mysql
basedir=/app/mysql
datadir=/data/mysql
server_id=6
port=3306
socket=/tmp/mysql.sock
[mysql]
socket=/tmp/mysql.sock
prompt=3306 [\\d]>

5.7 配置启动脚本:

[root@db01 mysql]# cd /app/mysql/support-files
[root@db01 support-files]# ./mysql.server start
Starting MySQL.Logging to '/data/mysql/db01.err'.
 SUCCESS!

5.8 使用systemd管理mysql

vim /etc/systemd/system/mysqld.service 
[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=/app/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000

注意:将原来模式启动mysqld先关闭,然后再用systemd管理。

systemctl start/stop/restart/status mysqld

  1. 安装后的简单管理
[root@db01 ~]# mysqladmin -uroot -p password 123
Enter password: 
mysqladmin: [Warning] Using a password on the command line interface can be insecure.
Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.

5.6版本:
select user,password,host from mysql.user;

5.7 中用户基本信息
select user,authentication_string,host from mysql.user;
desc mysql.user;

你可能感兴趣的:(2019-04-18 MYSQL 介绍)