MySQL04-- 版本区别及管理
MySQL版本区别及管理
一.MySQL5.6与MySQL5.7安装的区别
- 1、cmake的时候加入了bostorg
- 2、初始化时 使用mysqld --initialize 替代mysql_install_db,其它参数没有变化:--user= --basedir= --datadir=
- 3、--initialize会生成一个临时密码
- 4、还可以用另外一个参数--initialize-insecure
[root@db02 mysql-5.7.20]# yum install -y gcc gcc-c++ automake autoconf
[root@db02 mysql-5.7.20]# yum install make cmake bison-devel ncurses-devel libaio-devel
[root@db02 mysql-5.7.20]#
wget httpss://dl.bintray.com/boostorg/release/1.65.1/source/boost_1_59_0.tar.gz
#登录boost.org下载也可以
[root@db02 mysql-5.7.20]# tar xf boost_1_59_0.tar.gz -C /usr/local/
[root@db02 mysql-5.7.20]#
cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.7.20 \
-DMYSQL_DATADIR=/application/mysql-5.7.20/data \
-DMYSQL_UNIX_ADDR=/application/mysql-5.7.20/tmp/mysql.sock \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=/usr/local/boost_1_59_0 \
-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

二.MySQL用户权限管理
- 1.MySQL用户基础操作
Linux用户的作用:
- 1)登陆系统
- 2)管理系统文件
Linux用户管理:
- 1)创建用户:useradd adduser
- 2)删除用户:userdel
- 3)修改用户:usermod
MySQL用户的作用:
- 1)登陆MySQL数据库
- 2)管理数据库对象
MySQL用户管理:
1)创建用户:create user 、grant
#创建用户
create user zls@'%';
#创建用户同时给密码(5.7)如果用户不存在没法使用grant
create user qls@'%' identified by '123';
grant all on *.* to qls@'%';
2)删除用户:delete user 、drop user
mysql> drop user root@'db02';
Query OK, 0 rows affected (0.00 sec)
mysql> drop user ''@'db02';
Query OK, 0 rows affected (0.00 sec)
3)修改用户:update 、 alter 、 grant
mysql> update mysql.user set password=PASSWORD('123') where user='root' and host='localhost';
MySQL用户的定义:
- username@’主机域’
- 主机域:可以理解为是MySQL登陆的白名单
- 主机域格式:
root@'%' select
root@'localhost' 超级用户
root@'127.0.0.1' 超级用户
root@'10.0.0.%'
root@'10.%.%.%'
root@'10.0.0.0/255.255.255.0'
root@'db01' mysql> select user,host from mysql.user;
+------+-----------+
| user | host |
+------+-----------+
| root | localhost |
+------+-----------+
1 row in set (0.00 sec)
MySQL用户管理实战
刚装完MySQL数据库该做的事情
- 1、设定初始密码(root@localhost)
[root@db02 mysql-5.7.20]# mysqladmin -uroot -p password ‘oldboy123’
- 2、修改密码
- 3、使用密码登陆
[root@db02 mysql-5.7.20]# mysql -uroot -p123
- 4、清理无用的用户
误删除了所有用户
#关闭数据库
[root@db02 mysql-5.7.20]# /etc/init.d/mysqld stop
#启动数据库(加上参数后,不能使用tcp连接,只能socket连接,保证安全性)
[root@db02 mysql-5.7.20]# mysqld_safe --skip-grant-tables --skip-networking &
--skip-grant_tables #跳过授权表
[root@db01 bin]# mysqld_safe --skip-grant-tables --skip-networking &
--skip-networking # 跳过网络(安全)
mysql> insert into user(user,host,password) values('root','localhost',PASSWORD('123'));
mysql> insert into user(user,host,password,ssl_cipher,x509_issuer,x509_subject) values('root','localhost',PASSWORD('123'),'null','null','null');
忘记root密码
先启动数据库 mysqld_safe --skip-grant-tables --skip-networking &
#1.update修改密码
update mysql.user set password=PASSWORD('123') where user='root' and host='localhost';
#初始化
mysql> flush privileges;
#2.set
mysql> set password=PASSWORD('1');
#3.grant
mysql> grant all on *.* to root@'localhost' identified by '2';
#4.mysqladmin
[root@db01 ~]# mysqladmin -uroot -p2 password '123'
#5.alter
- 2.用户管理及权限管理_
1)创建用户
mysql> create user oldboy@'10.0.0.%' identified by '123';
2)查看用户
mysql> select user,host from mysql.user;
3)删除用户
mysql> drop user oldboy@‘10.0.0.%’;
4)修改密码
mysql> set password
mysql> update user set password=PASSWORD('oldboy123') where user='root' and host='localhost';
mysql> grant all privileges on *.* to oldboy@’10.0.0.%’ identified by ‘123’;
5)用户权限介绍
MySQL的权限定义:
作用对象:库、表
权限
INSERT,SELECT, UPDATE, DELETE, CREATE, DROP, RELOAD, SHUTDOWN, PROCESS, FILE, REFERENCES, INDEX, ALTER, SHOW DATABASES, SUPER, CREATE TEMPORARY TABLES, LOCK TABLES, EXECUTE, REPLICATION SLAVE, REPLICATION CLIENT, CREATE VIEW, SHOW VIEW, CREATE ROUTINE, ALTER ROUTINE, CREATE USER, EVENT, TRIGGER, CREATE TABLESPACE
给开发开权限
grant INSERT,SELECT, UPDATE, DELETE on *.* to dev@'xxx';
权限最小化,最小级别不是表级别,是列级别(很重要)
grant select on mysql.user.user to dev@'10.0.0.5%' identified by '123';
主机域:10.0.0.5% 可以连接:10.0.0.50-59 10.0.0.5
脱敏:脱离敏感信息
grant select(user,host) on wzry.user to no_vip@'%' identified by '123';
数据库集群,10.0.0.51 52 53 54
grant all privileges on *.* to oldboy@’10.0.0.%’ identified by ‘123’;
权限 作用对象 归属 密码
作用对象分解
*.* [当前MySQL实例中所有库下的所有表]
wordpress.* [当前MySQL实例中wordpress库中所有表(单库级别)]
wordpress.user [当前MySQL实例中wordpress库中的user表(单表级别)]
单列级别,是最小级别
#创建wordpress数据库
create database wordpress;
#使用wordpress库
use wordpress;
#创建t1、t2表
create table t1 (id int);
create table t2 (id int);
#创建blog库
create database blog;
#使用blog库
use blog;
#创建t1表
create table tb1 (id int);
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| blog |
| wordpress |
+--------------------+
mysql> show tables from mysql;
+---------------------------+
| Tables_in_wordpress |
+---------------------------+
| t1 |
| t2 |
+---------------------------+
mysql> show tables from blog;
+----------------+
| Tables_in_blog |
+----------------+
| tb1 |
+----------------+
1、grant select on *.* to wordpress@’10.0.0.5%’ identified by ‘123’;
针对wordpress@'10.0.0.5%' 授权 所有库所有表 查询权限 密码是 123
2、grant insert,delete,update on wordpress.* to wordpress@’10.0.0.5%’ identified by ‘123’;
针对wordpress@'10.0.0.5%' 授权 插入、删除、修改 wordpress库中的所有表 密码是 123
3、grant all on wordpress.t1 to wordpress@’10.0.0.5%’ identified by ‘123’;
针对wordpress@'10.0.0.5%' 授权所有权限 wordpress库中的t1表 密码是123
一个客户端程序使用wordpress用户登陆到10.0.0.51的MySQL后
[root@db02 ~]# mysql -uwordpress -p123 -h10.0.0.51
问:
一个客户端程序使用wordpress用户登陆到10.0.0.51的MySQL后,
- 1、对t1表的管理能力?
- 2、对t2表的管理能力?
- 3、对tb1表的管理能力?
解:
- 1、同时满足1,2,3,最终权限是1+2+3
- 2、同时满足了1和2两个授权,最终权限是1+2
- 3、只满足1授权,所以只能select
结论:
**1、如果在不同级别都包含某个表的管理能力时,权限是相加关系。 **
**2、但是我们不推荐在多级别定义重复权限。 **
*3、最常用的权限设定方式是单库级别授权,即:wordpress. 【单库级别】 **
3.企业中权限的设定
开发人员说:请给我开一个用户
沟通:
- 1、权限是什么? insert , delete , update
- 2、你需要对哪些库、表,哪些列进行操作 ?
- 3、你从哪里连接过来
- 4、用户名、密码有没有要求
- 5、发邮件,走流程(非常重要)
#一般给开发创建用户权限
grant select,update,delete,insert on *.* to oldboy@’10.0.0.%’ identified by ‘123’;
三.MySQL连接管理
1.连接工具
1)MySQL自带的连接工具
mysql 常见的特定于客户机的连接选项:
-u:指定用户
-p:指定密码
-h:指定主机
-P:指定端口
-S:指定sock
-e:指定SQL
--protocol=name:指定连接方式
2)第三方的连接工具
sqlyog、navicat
应用程序连接MySQL
注意:需要加载对应语言程序的API
2.连接方式
- socket连接
mysql -uroot -poldboy123 -S/application/mysql/tmp/mysql.sock
mysql -uroot -poldboy123
- TCP/IP
mysql -uroot -poldboy123 -h10.0.0.51 -P3306
- 问题:你怎么判断你的MySQL数据库可以对外提供服务?
四.MySQL启动关闭流程
启动
/etc/init.d/mysqld start ------> mysqld_safe ------> mysqld
service mysqld start
systemctl start mysqld
mysqld_safe --defaults-file=/etc/my.cnf &
关闭
/etc/init.d/mysqld stop
service mysqld stop
systemctl stop mysqld
mysqladmin -uroot -poldboy123 shutdown
#虽然可以关闭,但是不可用。 会损坏文件,可能导致丢失,无法恢复
(kill -9 pid ? killall mysqld ? pkill mysqld ?)
出现问题:
- 1、如果在业务繁忙的情况下,数据库不会释放pid和sock文件
- 2、号称可以达到和Oracle一样的安全性,但是并不能100%达到
- 3、在业务繁忙的情况下,丢数据(补救措施,高可用)
五.MySQL实例初始化配置
1.初始化配置文件的作用
场景:我要启动实例
问题:
1)程序在哪?
2)将来启动后去哪找数据库?
3)将来我启动的时候启动信息和错误信息放在哪?
4)启动的时候sock文件pid文件放在哪?
5)给了多少内存?
...
- 1)预编译:cmake去指定,硬编码到程序当中去
- 2)在命令行设定启动初始化配置
--skip-grant-tables
--skip-networking
--datadir=/application/mysql/data
--basedir=/application/mysql
--defaults-file=/etc/my,cnf
--pid-file=/application/mysql/data/db01.pid
--socket=/application/mysql/data/mysql.sock
--user=mysql
--port=3306
--log-error=/application/mysql/data/db01.err
- 3)初始化配置文件(/etc/my.cnf)
配置文件读取顺序:
/etc/my.cnf server_id=1
/etc/mysql/my.cnf server_id=2
/application/mysql/my.cnf server_id=3
~/.my.cnf server_id=4
[root@db02 ~]# mysql -uroot -p123 -e "show variables like 'server_id'" Warning: Using a password on the command line interface can be insecure.
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| server_id | 4 |
+---------------+-------+
--defaults-file:默认配置文件
如果使用./bin/mysqld_safe 守护进程启动mysql数据库时,使用了 --defaults-file=<配置文件的绝对路径>参数,这时只会使用这个参数指定的配置文件。
思考:
#cmake:
socket=/application/mysql/tmp/mysql.sock
#命令行:
--socket=/tmp/mysql.sock
#配置文件:
/etc/my.cnf中[mysqld]标签下:socket=/opt/mysql.sock
#default参数:
--defaults-file=/tmp/a.txt配置文件中[mysqld]标签下:socket=/tmp/test.sock
socket文件会生成在哪???文件名叫什么??? /tmp/mysql.sock
优先级结论:
**1.命令行优先级最高 **
**2.--defaults-file **
**3.配置文件读取顺序反着来 **
**4.cmake优先级最低 **
2.初始化配置文件的使用
初始化配置文件功能
1)影响实例的启动(mysqld)
2)影响到客户端
- mysql
- mysqldump
- mysqladmin
如何配置初始化配置文件
1)配置标签分类
[client]所有客户端程序
mysql
mysqldump
...
[server]所有服务器程序
mysqld
mysqld_safe
...
六.MySQL多实例配置
**什么是实例? **
一个进程+多个线程+预分配的内存结构
**什么是多实例? **
多个进程+多个线程+多个预分配内存结构
1)多套后台进程+线程+内存结构
2)多个配置文件
a. 多个端口
b. 多个socket文件
c. 多个日志文件
d. 多个server_id
3)多套数据
- 2.多实例实战
#创建数据目录
[root@db01 ~]# mkdir -p /data/330{7..9}
#创建配置文件
[root@db01 ~]# touch /data/330{7..9}/my.cnf
#编辑3307配置文件
[root@db01 ~]# vim /data/3307/my.cnf
[mysqld]
basedir=/application/mysql
datadir=/data/3307/data
socket=/data/3307/mysql.sock
log_error=/data/3307/data/3307.err
log-bin=/data/3307/mysql-bin
pid_file=/data/3307/data/3307.pid
server_id=7
port=3307
[client]
socket=/data/3307/mysql.sock
#编辑3308配置文件
[root@db01 ~]# vim /data/3308/my.cnf
[mysqld]
basedir=/application/mysql
datadir=/data/3308/data
socket=/data/3308/mysql.sock
log_error=/data/3308/data/3308.err
log-bin=/data/3308/mysql-bin
pid_file=/data/3307/data/3308.pid
server_id=8
port=3308
[client]
socket=/data/3308/mysql.sock
#编辑3309配置文件
[root@db01 ~]# vim /data/3309/my.cnf
[mysqld]
basedir=/application/mysql
datadir=/data/3309/data
socket=/data/3309/mysql.sock
log_error=/data/3309/data/3309.err
log-bin=/data/3309/mysql-bin
pid_file=/data/3307/data/3309.pid
server_id=9
port=3309
[client]
socket=/data/3309/mysql.sock
[root@db02 ~]# tree /data
├── 3307
│ └── my.cnf
├── 3308
│ └── my.cnf
└── 3309
└── my.cnf
2.初始化多个datadir
[root@db02 ~]# cd /application/mysql/scripts/ #初始化3307的数据目录
[root@db02 scripts]# ./mysql_install_db --defaults-file=/data/3307/my.cnf --user=mysql -- basedir=/application/mysql --datadir=/data/3307/data
#3308
[root@db02 scripts]# ./mysql_install_db --defaults-file=/data/3308/my.cnf --user=mysql -- basedir=/application/mysql --datadir=/data/3308/data
#3309
[root@db02 scripts]# ./mysql_install_db --defaults-file=/data/3309/my.cnf --user=mysql -- basedir=/application/mysql --datadir=/data/3309/data
[root@db02 scripts]#
[root@db02 bin]# tree -L 2 /data
/data
├── 3307
│ ├── data
│ └── my.cnf
├── 3308
│ ├── data
│ └── my.cnf
└── 3309
├── data
└── my.cnf
3.启动多实例
mysqld_safe --defaults-file=/data/3307/my.cnf &
mysqld_safe --defaults-file=/data/3308/my.cnf &
mysqld_safe --defaults-file=/data/3309/my.cnf &
#检查端口
[root@db02 bin]# netstat -lntup
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 6724/sshd
tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 6869/master
tcp6 0 0 :::3306 :::* LISTEN 18090/mysqld
tcp6 0 0 :::3307 :::* LISTEN 20554/mysqld
tcp6 0 0 :::3308 :::* LISTEN 20384/mysqld
tcp6 0 0 :::3309 :::* LISTEN 20724/mysqld
tcp6 0 0 :::22 :::* LISTEN 6724/sshd
tcp6 0 0 ::1:25 :::* LISTEN 6869/master
#查看server_id
[root@db01]# mysql -S /data/3307/mysql.sock -e "show variables like 'server_id'"
[root@db01]# mysql -S /data/3308/mysql.sock -e "show variables like 'server_id'"
[root@db01]# mysql -S /data/3309/mysql.sock -e "show variables like 'server_id'"
4.设置密码
[root@db02 scripts]# mysqladmin -uroot -p -S/data/3307/mysql.sock password '3307'
[root@db02 scripts]# mysqladmin -uroot -p -S/data/3308/mysql.sock password '3308'
[root@db02 scripts]# mysqladmin -uroot -p -S/data/3309/mysql.sock password '3309'
5.连接MySQLroot
[root@db02 scripts]# mysql -uroot -p3307 -S /data/3307/mysql.sock
[root@db02 scripts]# mysql -uroot -p3308 -S /data/3308/mysql.sock
[root@db02 scripts]# mysql -uroot -p3309 -S /data/3309/mysql.sock
#小技巧
[root@db02 bin]# vim mysql3309
mysql -uroot -p3309 -S /data/3309/mysql.sock
[root@db02 bin]# chmod +x mysql3309
MySQL04-- 版本区别及管理的更多相关文章
- 第三章·MySQL版本区别及管理
一.MySQL5.6与MySQL5.7安装的区别 1.cmake的时候加入了bostorg 2.初始化时 使用mysqld --initialize 替代mysql_install_db,其它参数没有 ...
- Windows8 各种版本区别对比详解
微软的 Windows8 操作系统提供了4个不同的版本,分别是 Windows RT.Windows 8 标准版.Windows 8 Pro 专业版 以及 Windows 8 Enterprise 企 ...
- java的版本区别、下载、配置
参考:http://blog.csdn.net/liujun13579/article/details/7684604 java的版本区别 常用的 java 程序分为 Java SE.Java EE ...
- .NET Framework 各版本区别
.NET Framework 各版本区别 .NET Framework 1.1 自1.0版本以来的改进:自带了对mobile asp .net控件的支持.这在1.0版本是以附加功能方式实现的,现在已经 ...
- [转帖]windows10,business版和consumer版本区别
windows10,business版和consumer版本区别 时间:2018-07-08 10:50来源:原创 作者:5分享 点击: 7113 次 windows10系统(1803)busines ...
- [转帖]Windows10七大版本区别在哪?
Windows10七大版本区别在哪? http://os.51cto.com/art/201804/570132.htm 一.Windows10家庭版 对于绝大多数用户来说,最后可能获得的应该就是Wi ...
- [Django框架之路由层匹配、有名 无名分组、反向解析、路由分发、名称空间、伪静态、本地虚拟环境、django版本区别]
[Django框架之路由层匹配.有名 无名分组.反向解析.路由分发.名称空间.伪静态.本地虚拟环境.django版本区别] 路由层 路由即请求地址与视图函数的映射关系,如果把网站比喻成一本书,那路由就 ...
- 基 vue-element-admin升级的Vue3 +TS +Element-Plus 版本的后端管理前端解决方案 vue3-element-admin 正式对外发布,有来开源组织又一精心力作,毫无保留开放从0到1构建过程
项目简介 vue3-element-admin 是基于 vue-element-admin 升级的 Vue3 + Element Plus 版本的后台管理前端解决方案,是 有来技术团队 继 youla ...
- .NET 版本区别,以及与 Windows 的关系
老是记不住各 Windows 版本中的 .NET 版本号,下面汇总一下: .NET Framework各版本汇总以及之间的关系 Mailbag: What version of the .NET Fr ...
随机推荐
- MySQL数据库5事务、视图、触发器、函数、数据库的备份
目录 一.事务(important) 1.1什么是事务? 1.2解决办法 1.2.1事务的语法 1.2.2使用事务解决转账问题代码演示 1.2.3rollback 1.3事务的特性(important ...
- Linux学习-MySQL的主从复制高可用性解决方案MHA
一.MHA简介 1.MHA Master High Availability,对主节点进行监控,可实现自动故障转移至其它从节点:通过提升某一从节点为新的主节点,基于主从复制实现,还需要客户端配合实现, ...
- springboot整合 thymeleaf 案例
1.运行环境 开发工具:intellij idea JDK版本:1.8 项目管理工具:Maven 4.0.0 2.GITHUB地址 https://github.com/nbfujx/springBo ...
- 2017 ICPC HongKong B:Black and White(扫描线+线段树)
题目描述 Consider a square map with N × N cells. We indicate the coordinate of a cell by (i, j), where 1 ...
- B/S选择文件夹上传
1 背景 用户本地有一份txt或者csv文件,无论是从业务数据库导出.还是其他途径获取,当需要使用蚂蚁的大数据分析工具进行数据加工.挖掘和共创应用的时候,首先要将本地文件上传至ODPS,普通的小文件通 ...
- WEB开发:Java与Php对比
比较PHP和JSP这两个Web开发技术,在目前的情况是其实是比较PHP和Java的Web开发.以下是我就几个主要方面进行比较: 一. 语言比较 PHP是解释执行的服务器脚本语言,首先php有简单容易上 ...
- eval方法遇到的问题
工作中有这样的场景,一个表达式比如 2*2,计算结果是number,这样的为true,如果输入错误 2*@,这样的情况需要匹配为false. 这里使用的eval方法, type of (eval('2 ...
- Linux 内核剖析
https://www.ibm.com/developerworks/cn/linux/l-linux-kernel/ 由于本文的目标是对 Linux 内核进行介绍并探索其体系结构和主要组件,因此首先 ...
- 20190816 On Java8 第六章 初始化和清理
第六章 初始化和清理 利用构造器保证初始化 在 Java 中,类的设计者通过构造器保证每个对象的初始化. 构造器名称与类名相同. 在 Java 中,对象的创建与初始化是统一的概念,二者不可分割. 方法 ...
- python的包
1. 无论是import形式还是from...import形式,凡是在导入语句中(而不是在使用时)遇到带点的,都要第一时间提高警觉:这是关于包才有的导入语法 2. 包是目录级的(文件夹级),文件夹是用 ...