MySQL 数据库管理员:
1.数据管理
增删改查
2.用户管理
grant all on . to all@'%' identified by '123';
读 写 1.权限最小化 2.root,运维用户ops,程序连库用户(只读用户,读写用户)
3.集群管理
4.数据备份、恢复
逻辑备份
物理备份
热备
冷备
温备
全备
增备
差异备份
5.监控
进程,端口
集群状态
主从复制 延时情况
SQL读写速率
slowlog
01 什么是数据?
数据(data)是事实或观察的结果,是对客观事物的逻辑归纳,是用于表示客观事物的未经加工的的原始素材。
数据可以是连续的值,比如声音、图像,称为模拟数据。也可以是离散的,如符号、文字,称为数字数据。
在计算机系统中,数据以二进制信息单元0,1的形式表示。
数据的定义: 数据是指对客观事件进行记录并可以鉴别的符号,是对客观事物的性质、状态以及相互关系等进行记载的物理符号或这些物理符号的组合。它是可识别的、抽象的符号。*
数据库管理系统分类
1.RDBMS 关系型数据库
典型代表产品:MySQL,Oracle,Mariadb,MSSQL(SQLserver)
2.NoSQL 非关系型数据库
典型代表产品:Redis,memcache,MongoDB,elasticsearch
MySQL版本选择的潜规则:
5.6:GA 6-12个月 小版本是偶数版
5.7:GA 6-12个月 小版本是偶数版 选择5.7.17版本以上的 (MGR:MySQL自带的高可用功能)
MySQL安装方式
- rpm、yum安装
安装方便、安装速度快,无法定制 - 二进制
不需要安装,解压即可使用,不能定制功能 - 编译安装
3.1 可定制,安装慢
3.2 四个步骤:
3.2.1 解压(tar)
3.2.2 生成(./configure)cmake
3.2.3 编译(make)
3.2.4 安装(make install)
3.3 5.5版本之前:tar ./configure make make install
3.4 5.5版本之后:cmake gmake - 先编译,然后定制rpm包,制作yum仓库,然后yum安装
4.1 简单,速度快,可定制,比较复杂,制作时间极长 - 企业中选择的安装方式
5.1 中小型企业:以上方式都可以,运维偏向编译,dba偏向二进制 运维也偏向二进制
5.2 大型企业:可以选择: 先编译然后定制rpm包,制作yum仓库,然后yum安装
编译安装:
1.解压 tar
2.生成 ./configure cmake gmake
3.编译 make
4.安装 make install
1)下载epel源 [root@db01 ~]# wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-7.repo 2)安装依赖 [root@db01 ~]# yum install -y ncurses-devel libaio-devel autoconf cmake gcc gcc-c++ glibc [root@mysql mysql-5.6.40]# useradd mysql -s /sbin/nologin -M 3)解压MySQL源码包 [root@db01 ~]# tar xf mysql-5.6.40.tar.gz 4)进入源码包目录 [root@db01 ~]# cd mysql-5.6.40/ 5)创建目录 [root@db01 ~]# mkdir /application 6)生成编译文件 [root@db01 mysql-5.6.40]# cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.6.40 -DMYSQL_DATADIR=/application/mysql-5.6.40/data -DMYSQL_UNIX_ADDR=/application/mysql-5.6.40/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 -DWITH_ZLIB=bundled -DWITH_SSL=bundled -DENABLED_LOCAL_INFILE=1 -DWITH_EMBEDDED_SERVER=1 -DENABLE_DOWNLOADS=1 -DWITH_DEBUG=0 7)编译 [root@db01 mysql-5.6.40]# make 8)安装 [root@db01 mysql-5.6.40]# make install 9)创建mysql用户 [root@db01 mysql-5.6.40]# useradd mysql -s /sbin/nologin -M 10)做软链接 [root@db01 mysql-5.6.40]# ln -s /application/mysql-5.6.40 /application/mysql 11)进入其他文件目录 [root@db01 mysql-5.6.40]# cd /application/mysql/support-files 12)拷贝MySQL配置文件 [root@db01 support-files]# cp my-default.cnf /etc/my.cnf cp: overwrite ‘/etc/my.cnf’? y 13)拷贝启动脚本 [root@db01 support-files]# cp mysql.server /etc/init.d/mysqld 14)进入初始化目录 [root@db01 support-files]# cd /application/mysql/scripts 15)初始化MySQL [root@db01 scripts]# ./mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data 16)创建socket文件所在目录 [root@db01 scripts]# mkdir /application/mysql-5.6.40/tmp 17)授权MySQL服务目录 [root@db01 scripts]# chown -R mysql.mysql /application/mysql* 18)添加环境变量 [root@db01 scripts]# vim /etc/profile.d/mysql.sh export PATH="/application/mysql/bin:$PATH" 19)加载环境变量 [root@db01 scripts]# source /etc/profile 20)启动MySQL [root@db01 scripts]# /etc/init.d/mysqld start 21 /etc/init.d/mysqld stop 21 用systemctl启动 [root@db01 ~]# vim /usr/lib/systemd/system/mysqld.service 加入 [Unit] Description=MySQL Server Documentation=man:mysqld(8) Documentation=https://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
MySQL二进制安装步骤:
1)解压二进制包 [root@db02 ~]# tar xf mysql-5.6.40-linux-glibc2.12-x86_64.tar.gz 2)创建MySQL安装目录 [root@db02 ~]# mkdir /application 3)移动MySQL程序到安装目录下 [root@db02 ~]# mv mysql-5.6.40-linux-glibc2.12-x86_64 /application/mysql-5.6.40 4)做软链接 [root@db02 ~]# ln -s /application/mysql-5.6.40 /application/mysql 5)进入其他文件目录 [root@db02 ~]# cd /application/mysql/support-files 6)拷贝配置文件 [root@db02 support-files]# cp my-default.cnf /etc/my.cnf cp: overwrite ‘/etc/my.cnf’? y 7)拷贝启动脚本 [root@db02 support-files]# cp mysql.server /etc/init.d/mysqld 8)进入初始化目录 [root@db02 support-files]# cd ../scripts/ 9)创建mysql用户 [root@db02 scripts]# useradd mysql -s /sbin/nologin -M 10)安装初始化依赖 [root@db02 scripts]# yum install -y autoconf libaio-devel 11)初始化 [root@db02 scripts]# ./mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data 12)启动MySQL [root@db02 scripts]# /etc/init.d/mysqld start [root@db02 scripts]# sed -i 's#/usr/local#/application#g' /etc/init.d/mysqld /application/mysql/bin/mysqld_safe 13)添加环境变量 [root@db02 scripts]# vim /etc/profile.d/mysql.sh export PATH="/application/mysql/bin:$PATH" 给MySQL的root用户设置密码 [root@db02 scripts]# mysqladmin -uroot -p password '123' 连接MySQL [root@db01 ~]# mysql -uroot -p123 查看MySQL中所有用户 mysql> select user,host from mysql.user; 删除用户 mysql> drop user root@'db01'; mysql> drop user root@'::1'; mysql> drop user ''@'db01'; mysql> drop user ''@'localhost'; mysql> drop user root@'localhost'; mysql> drop user root@'127.0.0.1';