标签:10.0 SQL MYSQL 用户 wordpress user mysql 第二章 体系结构
一、体系结构
MySQL C/S模型
Server : mysqld
Client :
- socket:仅本地连接使用
- tcp/ip:应用连接使用(远程和本地)
#TCP/IP方式(远程、本地) mysql -uroot -p123456 -h 10.0.0.51 -P3306 #socket方式(仅本地) mysql -uroot -p123456 -S /tmp/mysql.sock
实例介绍
实例=mysqld --- > master thread ---> 干活的线程 + 预分配的内存结构
公司=boss 经理 员工 办公室
实例=mysqld+master thread + N thread + 内存区域
mysqld程序运行原理
mysqld程序结构
(
SQL语句的执行个过程
连接层
(1)提供连接协议:TCP/IP 、SOCKET
(2)提供验证:user、password,IP,SOCKET
(3)提供专用连接线程:接收用户SQL,返回结果
通过以下语句可以查看到连接线程基本情况mysql> show processlist;
SQL层
(1)接收上层传送的SQL语句
(2)语法验证模块:验证语句语法,是否满足SQL_MODE
(3)语义检查:判断SQL语句的类型
(4)权限检查:用户对库表有没有权限
(5)解析器:对语句执行前,进行预处理,生成解析树(执行计划),说白了就是生成多种执行方案.
(6)优化器:根据解析器得出的多种执行计划,进行判断,选择最优的执行计划(7)执行器:根据最优执行计划,执行SQL语句,产生执行结果
存储引擎层(简单介绍)
负责根据SQL层执行的结果,从磁盘上拿数据。
将16进制的磁盘数据,交由SQL结构化化成表,
连接层的专用线程返回给用户。
MySQL的逻辑结构基本构成
- 库(DATABASE,SCHEMA)
- 表(TABLE.SEGMENT)
- 用户(PRIVILEGES)
- OTHER
MySQL基础物理结构
库:物理存储,相当于linux中的目录
表:元数据(表名,表属性,表列)
MyISAM(一种引擎)的表:
.MYI 索性相关信息
.MYD 存储数据行
.frm 列的信息
-rw-r----- 1 mysql mysql 10816 Apr 18 11:37 user.frm
-rw-r----- 1 mysql mysql 396 Apr 18 12:20 user.MYD
-rw-r----- 1 mysql mysql 4096 Apr 18 14:48 user.MYI
InnoDB(默认的存储引擎)的表:
.frm: 存储列相关信息
.ibd: 数据行+索引(IOT)
-rw-r----- 1 mysql mysql 8636 Apr 18 11:37 time_zone.frm
-rw-r----- 1 mysql mysql 98304 Apr 18 11:37 time_zone.ibd
INNODB表底层存储结构引入
段:一个非分区表就是一个段(segment)
区:大小为1M,默认是连续的64个page(extent)
页:MySQL最小的IO单元,默认为16kb(page)
MySQL基础管理
用户
用户的作用:登录mysql,管理MySQL的逻辑对象
用户的定义方式
用户的定义:用户名,白名单(主机列表)
wordpress@'localhost'
wordpress@'10.0.0.1'
wordpress@'10.0.0.%' ##
wordpress@'10.0.0.5%'
wordpress@'10.0.0.0/255.255.254.0'
wordpress@'oldguo.com'
wordpress@'db01'
wordpress@'%'
用户的管理操作
#创建用户
create user username@'10.0.0.%';
#删除用户
drop user username@'10.0.0.%';
#查看用户
select user,host from mysql.user;
#设置用户密码
alter user username@'10.0.0.%' identified by '123456';
#创建用户同时创建密码
create user username@'10.0.0.%' identified by '123456';
8.0版本以前,grant 可以创建用户并授权。8.0版本以后必须先创建用户在授权
权限
权限的作用:开启用户管理对象的能力
权限的定义
grant all on wordpress.* to wordpress@'10.0.0.%' identified by '123';
授权范围
*.* 全库级别,一般为管理员
wordpress.* 单库级别,应用或开发
wordpress.t1 单表级别,很少使用
生产环境用中授权
应用用户一般给
select,insert,update,delete
中小公司,开发人员leader
SELECT,INSERT, UPDATE, DELETE,CREATE,ALTER,CREATE VIEW,SHOW VIEW,CREATE ROUTINE,
ALTER ROUTINE,EVENT, TRIGGER
mysql找回本地管理员用户密码
关闭数据库
/etc/init.d/mysqld stop
将数据库启动到无验证模式
mysqld_safe --skip-grant-tables --skip-networking &
#参数说明
--skip-grant-tables //跳过授权表
--skip-networking //禁用TCP/IP连接方式
修改管理员密码
flush privileges;
alter user root@'localhost' identified by '123456';
quit
重启数据库为正常模式
/etc/init.d/mysqld restart
测试是否修改成功
mysql -uroot -p123456
MySQL连接方式
本地 -- 使用socket
本地登录的用户,需要提前授权localhost相关用户
mysql -uroot -p123 -S /tmp/mysql.sock
远程 -- TPC/IP
mysql -uoldguo -p -h10.0.0.51 -P3306
mysql 自带命令
命令:mysql
参数
-u 登录用户
-p 登录密码
-h 连接的IP
-P 端口号
-S socket文件
-e 非交互式登录
-V 查看版本信息
< 导入数据库
标签:10.0,SQL,MYSQL,用户,wordpress,user,mysql,第二章,体系结构 来源: https://www.cnblogs.com/lpcsf/p/12023599.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。