百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

MySQL版本区别及管理(mysql版本介绍)

itomcoil 2025-07-24 18:42 7 浏览

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

相关推荐

Python高效数据处理——从基础方法到性能优化

数据处理是数据分析的核心环节,高效的数据处理方法能显著提升代码性能。本文将深入介绍Pandas中的各种数据处理技术,并分析它们的性能特点。使用apply方法应用自定义函数apply是Pandas中最灵...

正态分布-置信区间计算(正态90%置信区间)

统计学有两大主要分支,分别是描述性统计学和推断统计学。描述性统计学用于描述和概括数据的特征以及绘制各类统计图表。总体数据,往往因为数据量太大而难以被获取,所以就有了通过较小的样本数据推测总体特性的推断...

一篇文章搞定人工智能之深度学习创建训练数据集的方法

基础数据准备训练所需要的数据集合都存储在数据库中,还有部分文本文件首先对数据进行分类结构化存储[因为涉及到的是多分类问题]整理并存储原始数据集使用numpy将所有需要数据读取出来splitlines(...

向量搜索之 k-means 算法(annoy向量检索)

一直好奇向量数据库的索引是如何实现的,我们可以推断向量搜索的简单实现:把数据存入向量数据库时,会计算每个分段文档的向量(文档向量),然后把分段文档和文档向量同时存入向量数据库。从向量数据库中搜索文档时...

融合贝叶斯生存模型与Transformer注意力的客户重参与策略优化

本文提出了一个集成三种核心技术的下一代智能优惠券分发系统:基于贝叶斯生存模型的重购概率预测、采用注意力机制的Transformer利润预测模型,以及用于策略持续优化的Dyna-Q强化学习代理。该系统构...

用Deepseek编写代码计算今天大乐透开奖号码

以下是一个基于Python的示例代码,用于分析大乐透历史数据并生成可能的号码组合。请务必注意:这仅是统计学模拟,无法真正预测开奖结果,所有结果均为随机性参考。代码实现步骤1.数据准备(模拟数据)假设...

拆解特斯拉L2家用充电桩:技术细节太多了

本文是对第三代特斯拉家用充电桩(L2级)的拆解分析报告。深入探究该充电桩的内部结构、设计特点、性能参数等内容。产品概述设备为第三代特斯拉家用充电桩,属于Level2充电器,是特斯拉推出的家用充电设备...

《光环5》2月更新“战锤风暴”正式推送“枪林弹雨”模式即将到来

今天(2月25日)微软和343工作室正式向Xboxone玩家推送了《光环5》的2月更新补丁“战锤风暴HammerStorm”。本次更新包括了1张全新Arena竞技场地图Torque;3个全新游戏模式...

Spring Boot(十一)Redis集成从Docker安装到分布式Session共享

一、简介Redis是一个开源的使用ANSIC语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API,Redis也是技术领域使用最为广泛的存储中间件,它是「...

Mac 基于HTTP方式访问下载共享文件,配置共享服务器

方法一:使用Python的SimpleHTTPServer进行局域网文件共享Mac自带Python,所以不需要安装其他软件,一条命令即可1):进入需要共享的文件夹,如Public文件夹cd/Us...

移动端性能专项测试之 CPU(移动端cpu天梯图2020百度贴吧)

指标背景很多场景下我们去使用App,可能会碰到手机会出现发热发烫的现象。这是因为CPU使用率过高、CPU过于繁忙,会使得整个系统无法响应用户,整体性能降低,用户体验变得相当差,也容易引起AN...

如何三天学会Phyton?这篇文章教你快速编程入门

Phyton作为一门常用的语言在很多领域都有很应用,很多人都想学习这门语言,那么我们就开始从头学习这门语言吧!首先你需要在官网下载你的Phyton的编程工具,也就是下载你的解释器!登录Phyton官网...

学习Python第一天 ---Hello World

引言人生苦短,请用Python(3.+)越来越多的情况下使用Python语言进行"代码粘合"和"数据分析"变得非常方便,而且Python在"爬虫"...

mysql的MVCC多版本并发控制机制(mysql并发情况下怎么解决)

认识MVCCMVCC是英文Multi-VersionConcurrencyControl多版本并发控制的首字母简拼。在上文MYSQL事务隔离级别中,我们已经知道,在可重复读的级别下,不管其他事...

爆炸,MySQL9.0大版本发布,我严重怀疑,它是不...

MySQL在本月发布了9.0大版本,作为MySQL的忠实粉丝,简单说下这次大版本更新。1.企业版,支持JS存储程序(JavaScriptstoredprograms)了。例如,可以像这样定一个函...