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.repo2)安装依赖[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 -M3)解压MySQL源码包[root@db01 ~]# tar xf mysql-5.6.40.tar.gz4)进入源码包目录[root@db01 ~]# cd mysql-5.6.40/5)创建目录[root@db01 ~]# mkdir /application6)生成编译文件[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=07)编译[root@db01 mysql-5.6.40]# make8)安装[root@db01 mysql-5.6.40]# make install9)创建mysql用户[root@db01 mysql-5.6.40]# useradd mysql -s /sbin/nologin -M10)做软链接[root@db01 mysql-5.6.40]# ln -s /application/mysql-5.6.40 /application/mysql11)进入其他文件目录[root@db01 mysql-5.6.40]# cd /application/mysql/support-files12)拷贝MySQL配置文件[root@db01 support-files]# cp my-default.cnf /etc/my.cnfcp: overwrite ‘/etc/my.cnf’? y13)拷贝启动脚本[root@db01 support-files]# cp mysql.server /etc/init.d/mysqld14)进入初始化目录[root@db01 support-files]# cd /application/mysql/scripts15)初始化MySQL[root@db01 scripts]# ./mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data16)创建socket文件所在目录[root@db01 scripts]# mkdir /application/mysql-5.6.40/tmp17)授权MySQL服务目录[root@db01 scripts]# chown -R mysql.mysql /application/mysql*18)添加环境变量[root@db01 scripts]# vim /etc/profile.d/mysql.shexport PATH="/application/mysql/bin:$PATH"19)加载环境变量[root@db01 scripts]# source /etc/profile20)启动MySQL[root@db01 scripts]# /etc/init.d/mysqld start21/etc/init.d/mysqld stop21 用systemctl启动[root@db01 ~]# vim /usr/lib/systemd/system/mysqld.service加入[Unit]Description=MySQL ServerDocumentation=man:mysqld(8)Documentation=https://dev.mysql.com/doc/refman/en/using-systemd.htmlAfter=network.targetAfter=syslog.target[Install]WantedBy=multi-user.target[Service]User=mysqlGroup=mysqlExecStart=/application/mysql/bin/mysqld --defaults-file=/etc/my.cnfLimitNOFILE = 5000
MySQL二进制安装步骤:
1)解压二进制包[root@db02 ~]# tar xf mysql-5.6.40-linux-glibc2.12-x86_64.tar.gz2)创建MySQL安装目录[root@db02 ~]# mkdir /application3)移动MySQL程序到安装目录下[root@db02 ~]# mv mysql-5.6.40-linux-glibc2.12-x86_64 /application/mysql-5.6.404)做软链接[root@db02 ~]# ln -s /application/mysql-5.6.40 /application/mysql5)进入其他文件目录[root@db02 ~]# cd /application/mysql/support-files6)拷贝配置文件[root@db02 support-files]# cp my-default.cnf /etc/my.cnfcp: overwrite ‘/etc/my.cnf’? y7)拷贝启动脚本[root@db02 support-files]# cp mysql.server /etc/init.d/mysqld8)进入初始化目录[root@db02 support-files]# cd ../scripts/9)创建mysql用户[root@db02 scripts]# useradd mysql -s /sbin/nologin -M10)安装初始化依赖[root@db02 scripts]# yum install -y autoconf libaio-devel11)初始化[root@db02 scripts]# ./mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data12)启动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_safe13)添加环境变量[root@db02 scripts]# vim /etc/profile.d/mysql.shexport 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';
