MySQL学习【第四篇mysql体系结构管理】
一.客户端与服务端模型
1.mysql是一个典型的c/s服务结构
1.mysql自带的客户端程序(/application/mysql/bin)
mysql mysqladmin mysqldump
2.市面上大部分的开发语言都需要一个客户端连接程序连接mysql的服务端

2.mysql是一个守护进程,是一个二进制的程序

mysql.server是一个启动脚本,mysqld_safe是一个启动命令,mysqld则是一个守护进程
3.连接客户端方式
1.TCP/IP
mysql -uroot -p123 -h127.0.0.
2.socket(套接式连接)
mysql -uroot -p123 -S /tmp/mysql.sock
mysql -uroot -p123
mysql -uroot -p123 -hlocalhost
3.查看连接方式

1.并不是所有-h都是tcp/ip连接,所有远程连接都是tcp/ip连接
2.MySQL的默认连接时socket连接
3.socket连接速度十分快速,由于不需要建立tcp三次握手
4.实例
mysql的后台进程+线程+预分配的内存结构
5.mysql服务器的构成

1.连接层
1)验证用户的合法性(ip,端口,用户名,密码,防火墙)
2)提供两种连接方式(tcp/ip,socket)
3)提供与sql层互相交互的专用线程
4)查看文件是否拥有权限,执行某条sql语句
2.sql层
1)接受连接层传来的sql语句
2)检查语法能否执行
3)检查语义(DDL,DML,DQL,DCL)
4)解析器,解析sql语句,生成多种执行计划
5)优化器,根据多种执行计划,选择最优的一种
6)执行器,执行最优的执行计划
提供跟存储引擎层交互的线程
接受返回的数据返回给连接层
7)将数据存入缓存
8)记录binlog日志
3.存储引擎层
1)接受sql层传下来的sql语句
2)去磁盘空间寻找所要查找的数据
3)提供一个与sql层交互的线程,将数据结构化成表的形式传给sql层
6.mysql的逻辑结构
1.库: show databases;
2.表: 元数据+真实数据行 show tables;
3.元数据: 列+其他属性(行数row+占用空间大小+权限)
4.列: 列名+数据类型+其他约束(非空,唯一键,主键,默认值,自增长,非负数等等)
7.mysql的物理结构
1.mysql最底层的物理结构是数据文件
2.存储引擎,存储引擎分很多种,mysql常用到的是InnoDB,MyISAM
3.段区块:
1( 段:一个表一个段,多个区构成
2( 区:多个页构成
3( 页:最小数据存储单元。默认16k
4( 分区表:一个分区是一个段
MySQL学习【第四篇mysql体系结构管理】的更多相关文章
- 我的MYSQL学习心得(十三) 权限管理
我的MYSQL学习心得(十三) 权限管理 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) ...
- 数据库MySQL学习笔记高级篇
数据库MySQL学习笔记高级篇 写在前面 学习链接:数据库 MySQL 视频教程全集 1. mysql的架构介绍 mysql简介 概述 高级Mysql 完整的mysql优化需要很深的功底,大公司甚至有 ...
- MySql学习笔记四
MySql学习笔记四 5.3.数据类型 数值型 整型 小数 定点数 浮点数 字符型 较短的文本:char, varchar 较长的文本:text, blob(较长的二进制数据) 日期型 原则:所选择类 ...
- openresty 学习笔记四:连接mysql和进行相关操作
openresty 学习笔记四:连接mysql和进行相关操作 毕竟redis是作为缓存,供程序的快速读写,虽然reidis也可以做持久化保存,但还是需要一个做数据存储的数据库.比如首次查询数据在red ...
- “MVC+Nhibernate+Jquery-EasyUI” 信息发布系统 第四篇(用户管理功能的实现)
“MVC+Nhibernate+Jquery-EasyUI” 信息发布系统 第四篇(用户管理功能的实现) 一.前三篇的内容是否对您有帮助呢?如果有的话,请您继续关注这篇吧,这篇主要是实现”用户管理“的 ...
- MySQL学习(一)——Java连接MySql数据库
MySQL学习(一)——Java连接MySql数据库 API详解: 获得语句执行 String sql = "Insert into category(cid, cname) values( ...
- MySQL学习笔记Windows篇<一> Welcome to MySQL
MySQL安装完毕后没有图形化操作界面,图形化管理界面需要另行安装,个人比较喜欢Navicat,界面更像SQLserver: 此篇学习笔记所有操作均使用命令行中完成: 1.开启/停止服务 使用MySQ ...
- MySQL学习【第二篇安装】
一.Mysql安装方式 1.安装方式 1.rpm,yum安装 安装方便,安装速度快,但无法定制 2.二进制安装 不需要安装,解压即用,不能定制功能 3.编译安装 可定制,安装很慢,安装分为四个步骤 1 ...
- MySQL学习【第九篇存储引擎】
一.存储引擎介绍 1.我们知道mysql程序构成由连接层,sql层,存储引擎层.存储引擎层和磁盘进行交互,由其去取数据,而我们取得数据是表的形式展现出来,谁做的呢?就是存储引擎结构化成表的形式返回给用 ...
随机推荐
- TileStache生成切片
1.tilestache.cfg { "cache": { "name": "Disk", "path": " ...
- Scala安装时的坑
重新安装了Scala(2.11.12版本)到d:\Program Files下,查看版本时,报如下异常: 百度了一下,竟然是不允许空格,太low了. 装到d:\Scala后问题解决
- oracle 用户对象权限
drop user test cascade;create user test identified by test;grant create session to test;grant create ...
- apache ftp server的简单入门(数据库验证)
apache的简单校验分为两种,一直是前面提到的properties的校验,具体参考:apache ftp server的简单入门(properties验证) 今天来说一种数据库的校验,这种方式在项目 ...
- Oracle数据库日期格式转换操作
1. 日期转化为字符串 (以2016年10月20日为例) select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss') strDateTime from dual; ...
- 1.Junit test使用
1.导入maven依赖 <dependency> <groupId>junit</groupId> <artifactId>junit</arti ...
- 对JDBC的轻量级封装,Hibernate框架
IDEA是真的好用... 用脑子下jar包..http://mvnrepository.com/
- ansible 一键部署
start install: rpm -Uvh https://mirrors.aliyun.com/epel/epel-release-latest-7.noarch.rpm yum in ...
- JS 触发不同ifram控件,实现刷新,关闭标签(H+框架)
例: //前台页面事件处理模块var EventOperation = { Refresh: function (data_id) { var a = (window.top); var ele = ...
- 关于sys CPU usage 100%问题的分析
最近一个客户抱怨他的核心EBS数据库出现性能问题.这是一个10.2.0.3的数据库,运行在Red Hat Enterprise Linux Server release 5.5 (Linux x86- ...