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层,存储引擎层.存储引擎层和磁盘进行交互,由其去取数据,而我们取得数据是表的形式展现出来,谁做的呢?就是存储引擎结构化成表的形式返回给用 ...
随机推荐
- Navicat Premium 连接MySQL数据库出现Authentication plugin 'caching_sha2_password' cannot be loaded的解决方案
1. 管理员权限运行命令提示符,登陆MySQL mysql -u root -p root 2. 修改账户密码加密规则并更新用户密码 ALTER USER 'root'@'localhost' ID ...
- 需要警惕的linux命令
Linux shell/terminal命令非常强大,即使一个简单的命令就可能导致文件夹.文件或者路径文件夹等被删除.为了避免这样的事情发生,我们应该时刻注意PHP代码&命令,今天为大家带来9 ...
- 用C#自定义一个简单的集合
闲来无聊来自己做了一个简单的'集合',用来加深自己对集合的理解 class listNode { private object value; public listNode(object _value ...
- sql面试
1.用一条SQL语句 查询出每门课都大于80分的学生姓名 name kecheng fenshu 张三 语文 81张三 数学 75李四 语文 ...
- 产生渐变色的view
产生渐变色的view 效果 源码 https://github.com/YouXianMing/UI-Component-Collection // // GradientColorView.h // ...
- 企业级NFS网络文件共享服务_【all】
1.1. 什么是NFS(1台机器提供服务) Network File System(网络文件系统)通过局域网让不同的主机系统之间共享文件或目录. NFS客户端可以通过挂载的方式将NFS服务器端共享的数 ...
- python_web应用雏型
python_web应用雏型 Web应用程序顾名思义,就是一种可以通过Web访问的应用程序, Web应用的最大特点是用户只需要有网络和浏览器,不需要再安装其他软件就可顺利通过web访问到程序. WEB ...
- web应用配置文件详解(web.xml)
转载链接地址:http://blog.csdn.net/guihaijinfen/article/details/8363839 <?xml version="1.0" en ...
- September 27th 2017 Week 39th Wednesday
We both look up at the same stars, yet we see such different things. 我们仰望同一片星空,却看见了不同的事物. Looking up ...
- 'Table is Marked as crashed and should be repaired Error'.Mysql表损坏解决方案
问题表现:由于服务器崩溃导致表损坏无法打开或者能打开但是无法写入数据(提示主键重复但实际没有该主键且该主键值在最大值范围内). 本文提供两种检查修复方式:mysqlcheck 和 myisamchk ...