Mysql进阶(一)Mysql执行流程与架构

news2024/11/18 15:48:06

文章目录

  • 一句查询语句是如何执行的?
    • 通信协议
    • 通信方式
    • 查询缓存
    • 词法语法解析和预处理(解析器、预处理器)
    • 查询优化器与查询执行计划
      • 什么是优化器
      • 优化器可以做什么
      • 优化器执行结果
    • 存储引擎
      • 基本介绍
      • 存储引擎比较
      • 如何选择存储引擎
  • 一条更新SQL是如何执行的?
    • 缓冲池
    • InnoDB内存结构和磁盘结构
    • Binlog

一句查询语句是如何执行的?

select id from student;

​ 如上很简单的查询语句,从student表中查询id。那么Mysql是如何将这个条语句翻译成它所需要的指令从而去拿到数据返回给客户端?这里先放一张大致的流程图

image-20220713165549179

​ 首先数据是存储在Mysql服务器端的。应用程序或者工具都是客户端,客户端要去读取数据库,第一步就要跟数据库建立连接通信,那么客户端与服务器端又是如何通信的呢?

通信协议

​ Mysql支持多种通信协议,包括TCP/IP协议、Unix Socket协议、Share Memory协议、Named Pipes协议,可以使用同步/异步的方式,支持长连接/短链接

通信类型:同步或者异步

同步

1. 同步通信依赖于被调用方,受限于被调用方的性能,也就是是说,应用操作数据库,线程会阻塞,等待数据返回
2. 一般只能做到一对一,很难做到一对多的通信

异步

  1. 异步可以避免应用阻塞等待,但不能计算sql执行时间。
  2. 如果异步存在并发,每一个sql的执行都要单独建立一个链接,避免数据混乱,但是这样会给服务端带来巨大的压力(一个连接就是一个线程,线程切换占用大量cpu资源),另外异步通信还带来了编码的复杂度(ps:最近已经被公司Node.js项目搞得头大(异步io)),所以,一般不建议。如果使用异步,必须使用连接池,排队从连接池中获取连接而不是创建连接

一般来说我们链接数据库都是采用同步连接

连接方式:长连接或者短连接

Mysql既支持长连接也支持短连接,一般来说都是长连接,而且会把这个长连接放到客户端的连接池中

在服务器端可以通过show status命令查看Mysql当前有多少个连接

show global status like 'Thread%'

image-20220713172916527

每产生一个连接或者一个会话,在服务器端都会创建一个线程来处理。

字段含义
Threads_cached缓存中的线程连接数
Threads_connected当前打开的连接数
Threads_created为处理连接创建的线程数
Threads_running非睡眠状态的连接数,通常指并发连接数

保持长连接会消耗内存,长时间不活动的连接,Mysql服务器会自动断开,默认时间为8小时,28800秒

show global variables like 'wait_timeout' --非交互式超时时间,如JDBC程序
show global variables like 'interactive_timeout' --交互式超时时间,如数据库工具navicat

image-20220713174022203

Mysql服务允许的最大连接数默认是15个,最大的可以设置成10000。

show variables like 'max_connections'

image-20220713183251988

**参数级别说明:**Mysql中的参数分为session和global级别,分别是在当前会话中生效和全局生效,但并不是每个参数都有两个级别,比如max_connections就只有全局级别。当没有带参数的时候,默认就是session级别,包括查询和修改,比如修改了一个参数后,在本窗口查询已经生效,但在其他窗口不生效,常见的修改事务提交方式就是如此

show variables like 'autocommit';
set autocommit = on; --默认为session级别,只在当前窗口有效

通信协议

  1. TCP/IP协议

通常我们通过这个协议来连接MySQL,各种主要编程语言都是根据这个协议实现了连接模块,mysql -h xx.xx.xx.xx -u root -p

  1. Unix Socket协议

通常我们登入MySQL服务器中使用这个协议,因为要使用这个协议连接MySQL需要一个物理文件,文件的存放位置在配置文件中有定义,默认地址是/var/lib/mysql/mysql.sock,值得一提的是,这是所有协议中最高效的一个.

  1. Share Memory协议

这个协议一般人不知道,肯定也没用过,因为这个只有windows可以使用,使用这个协议需要在配置文件中在启动的时候使用–shared-memory参数,注意的是,使用此协议,一个host上只能有一个server,所以这个东西一般没啥用的,除非你怀疑其他协议不能正常工作,实际上微软的SQL Sever也支持这个协议

  1. Named Pipes协议

这个协议也是只有windows才可以用,同shared memory一样,使用此协议,一个host上依然只能有一个server,即使是使用不同的端口也不行,Named Pipes 是为局域网而开发的协议。内存的一部分被某个进程用来向另一个进程传递信息,因此一个进程的输出就是另一个进程的输入。第二个进程可以是本地的(与第一个进程位于同一台计算机上),也可以是远程的(位于联网的计算机上)。正因为如此,假如你的环境中没有或者禁用TCP/IP环境,而且是windows服务器,那么好歹你的数据库还能工作。使用这个协议需要在启动的时候添加–enable-named-pipe选项

通信方式

  • **单工:**在两台计算机通行的时候,数据的传输是单向的,类比于遥控器
  • **半双工:**在两台计算之间,数据传输是双向的,你可以给我发送,我也可以给你发送,但是在这个通讯连接里面,同一时间只能由一台服务器在发送数据,即数据不能同时发送,我给你发送数据需要等你给我发的数据发完了之后才可以继续发送,类比生活中的对讲机
  • **全双工:**数据的传输是双向的,并且可以同时传输,类比手机通话

Mysql采用半双工的通信方式,在一个连接中,要么是客户端向服务器端发送数据,要么是服务器端向客户端发送数据,这两个动作不能同时发生,所以客户端发送sql语句给服务端的时候,(在一次连接里面)数据是不能分成小块传输的,不管sql语句有多大,都是一次性发送。若一次查询中,语句过长则查询过程可能会产生问题,这个时候必须调整Mysql服务器配置max_allowed_packet参数的值,把它调大否则就会报错。

image-20220816152100900

另一方面,对于服务器来说,也是一次性发送所有的数据,不能因为你已经取到了想要的数据就中断操作,这个时候会对网络和内存产生大量消耗。所以在程序里面要避免不带limit的这种操作,比如一次把所有满足条件的数据全部查出来,一定要先count一下,如果数据量大的话可以分批查询。

查询缓存

mysql8.0 中已被移除,不建议使用,缓存建议交给独立的缓存服务器操作。

词法语法解析和预处理(解析器、预处理器)

mysql查询输入一些错误的的查询语句的时候,服务器会报1064错误,那么,mysql是如何知道输入的内容是错误的?这主要是靠Mysql的Parser 解析器Preprocessor预处理模块完成

image-20220816153102331

例如一个简单的查询语句 select name from user where id = 1 会被拆分为 8个符号,包括“=”。随后语法分析会对SQL语句做一些语法检查比如引号有没有闭合等,词法与语法解析完成后,Mysql会根据定义的语法规则,将SQL语句解析成一个新的数据结构,这个数据结构我们把它叫做解析树(select_lex)

image-20220829162352256

如果一个词法语法都正确的SQL,但是表名或者字段名不存在,解析SQL语句时,预处理器会检查生成的解析树,解决解析器无法解析的语义,比如,它会检查表和列名是否存在,检查名字和别名,保证没有歧义

查询优化器与查询执行计划

什么是优化器

解析树是一个可以被执行器认识的数据结构,一条SQL语句是不是只有一种执行方式?或者说数据库最终执行的SQL是不是就是发送的SQL?答案是否定的,一条SQL语句是可以有多种执行方式的,最终返回相同的结果,他们是等价的。但是如果有这么多种执行方式,这些执行方式怎么得到的?最终选择哪一种去执行?又是根据什么判断标准去选择?

这个就是MYSQL的查询优化器的模块(Optimizer)。

查询优化器的目的就是根据解析树生成不同的执行计划(Execution Plan),然后选择一种最优的执行计划,MySQL里面使用的是基于开销(cost)的优化器,哪种执行计划开销最小,就使用哪一种。

-- 可以使用这个命令查看查询的开销
show status like "Last_query_cost"

优化器可以做什么

MySQL的优化器能够处理哪些优化类型呢?举两个简单的例子:

  1. 当我们对多张表进行关联查询的时候,以哪个表的数据作为基准表(先访问哪张表)。
  2. 有多个索引可以使用的时候,选择哪个索引。
  3. 对于查询条件的优化,比如移除1=1之类的恒等式,移除不必要的括号,表达式的计算,子查询和连接查询的优化。

那么经过优化器处理后,得到的结果是啥,MySQL又是如何去处理?

优化器执行结果

优化器最终会把解析树变成一个执行计划(execution_plans),执行计划也是一个数据结构,当然,这个执行计划并不一定是最优的执行计划,因为MySQL也有可能覆盖不到所有的执行计划。我们可以通过在SQL语句前面加上EXPLAIN,就可以查看执行计划的信息。其中key为使用的索引,如果要得到详细的信息,还可以使用FORMAT = JSON

 explain select name from user_innodb where id = 1;
 explain format = json select name from user_innodb where id = 1;

image-20220830163130696

存储引擎

基本介绍

表载存储数据的同时,还要组织数据的存储结构,这个存储结构就是由我们的存储引擎所决定的。在MySQL里面,我们创建的每一张表都可以指定它的存储引擎,而不是一个数据库只能使用一个存储引擎,存储引擎的使用是以表为单位的,我们也可以把存储引擎叫做表类型,而且创建之后还可以修改存储引擎。

查看数据库中的存在的表的存储引擎

show table status from <db>

image-20220830172318269

默认情况下,每个数据库有一个文件夹,任何一个存储引擎都有一个 frm 文件,这个是表结构定义文件,不同的存储引擎存放数据的方式不一样,产生的文件也不一样。innodb存储引擎是一个以ibd结尾的文件,memory存储引擎没有,myisam存储引擎包含两个文件,一个以MYD结尾,一个以MYI结尾。

数据库数据文件目录

 show variables like 'datadir';
-- 默认目录为/var/lib/mysql

存储引擎比较

我们可以通过这个命令查看数据库对存储引擎的支持情况

show engines;

image-20220830180723914

其中有存储引擎的描述和对事务、XA协议和Savepoints的支持。XA协议用来实现分布式事务(分为本地资源管理器,事务管理器)。Savepoints用来实现子事务(嵌套事务)。创建了一个Savepoints之后,事务就可以回滚到这个点,不会影响到创建Savepoints之前的操作

  • MyISAM

    MySQL自带的存储引擎,由ISAM升级而来。官网文档https://dev.mysql.com/doc/refman/8.0/en/myisam-storage-engine.html,应用范围比较小,表级锁定限制了读/写的性能,因此在Web和数据仓库配置中,它通常用于只读或以读为主的工作

  • InnoDB

    MySQL 5.7之后默认的存储引擎,适合经常更新的表,存在并发读写或者有事务处理的业务系统,InnoDB是一个事务安全(与ACID兼容)的MySQL存储引擎,它具有提交、回滚和崩溃恢复功能来保护用户数据,InnoDB行级别锁(不升级为更粗粒度的锁)和Oracle 风格的一致性读取提高了多用户并发性和性能;InnoDB表在磁盘上排列数据以优化基于主键的查询,每个InnoDB表都有一个称为聚集索引的主键索引,它组织数据以最小化主键查找的 I/O;为了保证数据的完整性,InnoDB支持 FOREIGN KEY 约束,使用外键检查插入、更新和删除以确保它们不会导致相关表之间的不一致。官网文档https://dev.mysql.com/doc/refman/8.0/en/innodb-storage-engine.html

    特点

    1. 支持事务,支持外键,因此数据的完整性、一致性更高。
    2. 支持行级别的锁和表级别的锁。
    3. 支持读写并发,写不阻塞读(MVCC)。
    4. 特殊的索引存放方式,可以减少IO,提升查询效率。
  • Memory

    将所有数据存储在RAM中,以便在需要快速查找非关键数据的环境中快速访问,把数据放在内存里面,读写的速度很快,但是数据库重启或者崩溃,数据会全部消失,只适合做临时表,将表中的数据存储到内存中,默认使用哈希索引。

  • CSV (3个文件)

    它的表实际上是带有逗号分隔值的文本文件,CSV表允许以CSV格式导入或转储数据,以便与读写相同格式的脚本和应用程序交换数据,因为CSV表没有索引,所以通常在正常操作期间将数据保存在Innodb表中,并且只在导入或导出阶段使用CSV表。

    特点: 不允许空行,不支持索引。格式通用,可以直接编辑,适合在不同数据库之间导入导出

  • Archive(2个文件)

    这些紧凑的未索引的表用于存储和检索大量很少引用的历史,存档或安全审计信息。

    **特点:**不支持索引,不支持update delete。

不同的存储引擎提供的特性都不一样,它们有不同的存储机制,索引方式,锁定水平等功能。

我们在不同的业务场景中随数据库的要求不同,就可以选择不同的存储引擎来满足我们的需求,这个就是mysql支持这么多存储引擎的原因。

如何选择存储引擎

如果对数据一致性要求比较高,需要支持事务,可以选择InnoDB。

如果数据查询多更新少,对查询性能要求比较高,可以选择MyISAM。

如果需要一个用于查询的临时表,可以选择Memory。

如果所有存储引擎都不能满足要求,可以官网内部手册开发一个存储引擎

一条更新SQL是如何执行的?

更新流程和查询流程有什么不同呢?基本流程是一致的,也就是说,它也要经过解析器,优化器的处理,最后交给执行器。区别就在于拿到符合条件的数据之后的操作

缓冲池

首先, 对于Innodb来说,数据都是放在磁盘上的,存储引擎要操作数据,必须先把磁盘里面的数据加载到内存里面才可以操作.

这里就有一个问题,我们一次从磁盘中的加载多少数据到内存中呢,是不是需要多少就拿多少?磁盘的I/O操作相对与内存操作来说是相当耗时的,如果我们需要的数据分布在磁盘不同的地方,那就意味着会产生很多此的I/O操作.

所以,无论是操作系统还是存储引擎,都有一个预读取的概念,当磁盘的一块数据被读取的时候,很有可能它附近的位置也会马上被读取到,这个就叫做局部性原理.那么这样,我们干脆每次读取的时候多读取一些数据,而不是用多少读多少.

InnoDB设定了一个从磁盘读取数据到内存的最小的单位,叫做页,同操作系统的页类似.操作系统的页大小一般为4K,而在InnoDB中,页的大小为16Kb,他是一个逻辑单位,如果需要修改这个值的大小,需要修改源码重新编译安装.

设想一下,对于数据页的操作,每次都直接操作磁盘,从磁盘中加载到内存,这样会不会很慢,能不能把这些页缓存起来,加快数据的加载速度.

InnoDB使用了一种缓冲池的技术,也就是把磁盘读到的页放到一块内存区域里面,下一次读取相同的页,先判断是不是在这个内存区域里面,如果是,就直接读取,然后操作,不用再次从磁盘中加载,这个内存区域就叫做Buffer Pool

修改数据的时候,先修改内存缓冲池里面的页,内存的数据页和磁盘数据不一致的时候,我们把它叫做脏页,那脏页什么时候同步到磁盘呢?

InnoDB里面有专门的后台把Buffer Pool的数据写入到磁盘,每隔一段时间就一次性的把多个修改写入磁盘,这个动作就叫做刷脏

InnoDB内存结构和磁盘结构

image-20230506170646449

内存结构里面主要是Buffer Pool,Change Buffer,Log Buffer AHI.

  1. Buffer Pool

    Buffer Pool里面缓存的是page页面信息,默认大小是128M,可以修改调整

  2. (redo)Log Buffer

    ​ 因为刷脏不是实时的,如果BufferPool里面的脏页还没有刷入磁盘时,数据库宕机或者重启,这些数据就会丢失.内存的数据必须要有一个持久化的措施,为了避免这个问题,InnoDB把所有对页面的修改操作专门写入一个日志文件.如果有未同步到磁盘的数据,数据库在启动的时候,会从这个日志文件进行恢复操作(实现 crash-safe).我们说的事务的ACID里面的D(持久性),就是用它来实现的.

    ​ 这个日志文件就是磁盘的redo log (叫做重做日志),对应于/var/lib/mysql/ 目录下的ib_logfile0和ib_logfile1,默认两个文件,每个48M.show variables like 'innodb_log'

    1. 同样是写磁盘,为什么不直接写到db file中去,而是先写日志在写磁盘?写日志文件和写到数据文件有什么区别?

      数据都是分散在不同的扇区的,写到db file 中去需要进行刷盘操作,是随机I/O,而记录日志是顺序I/O(连续写的),顺序I/O效率更高,因此把修改写入日志文件,在保证了内存数据的安全性的情况下,可以延迟刷盘时机,进而提升系统吞吐.

    特点:

    1. redo log 是InnoDB存储引擎实现的,并不是所有存储引擎都有,支持崩溃恢复是InnoDB的一个特性.
    2. redo log是物理日志,记录的是"在某个数据页做了什么修改"
    3. redo log的大小是固定的,前面的内容会被覆盖,一旦写满,就会触发buffer pool到磁盘的同步,以便腾出空间记录后面的修改
  3. undo log tablespace

    undo log(撤销日志或回滚日志)记录了事务发生之前的数据状态(不包括select).如果修改数据时出现异常,可以使用undo log来实现回滚操作(保持原子性).

    在执行undo的时候,仅仅是将数据从逻辑上恢复至事务之前的状态,而不是从物理页面上操作实现的,属于逻辑格式的日志,undo log 的数据默认在系统表空间Ibdata1文件中,因为共享表弓箭不会自动收缩,也可以单独创建一个undo表空间.

有了这些日志之后,我们来总结一下一个更新操作的流程 例如 update user set name = 'telangpu' where name = "baideng";

  1. 事务开始,内存(buffer pool)或磁盘(data file)取到这条数据,返回给Server的执行器;
  2. Server的执行器修改这一行数据的值为telangpu;
  3. 记录name=baideng到undo log;
  4. 记录name=telangpu到redo log
  5. 调用存储引擎接口,在内存Buffer pool中的将数据修改
  6. 事务提交

后台线程工作,刷新内存池中的数据把修改的数据刷新到磁盘.

Binlog

处理Innodb架构的日志文件,Mysql的Server层也有一个日志文件,叫做binlog,它可以被所有的存储引擎使用.

Binlog以事件的形式记录了所有的DDL和DML语句,它记录的是操作而不是数据.binlog可以用来做主从复制和数据恢复.跟redo log日志不一样,binlog日志的文件是可以追加的,没有固定的大小限制.

在开启binlog功能的情况下,我们可以把binlog导出成sql语句,把所有的操作重新执行一遍,来实现数据的(归档)恢复

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/496279.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java语法(一)基本概念、数据类型、字符串类、集合

文章目录 java程序运行流程JDK、JRE、JVM的关系 java数据类型基本数据类型基本数据类型之间的转换 引用数据类型数组类Java Bean重写 equals和hashcode 接口接口与类之间的关系 内置包装类装箱和拆箱包装类的应用Object类toString()equals()方法getClass() 方法接收任意引用类型…

【蓝桥杯选拔赛真题56】Scratch画笔涂色 少儿编程scratch图形化编程 蓝桥杯选拔赛真题讲解

目录 scratch画笔涂色 一、题目要求 编程实现 二、案例分析 1、角色分析

STM32 匿名助手提升电机控制调试效率(下位机代码和上位机操作演示)

目录 前言 通信协议选择 上位机配置实现 下位机代码实现 通信效果演示 总结 前言 前面介绍了通过VOFA上传变量并显示成波形方便调试的方法&#xff0c;VOFA上传的是浮点&#xff0c;一个浮点需要4个byte才能够表示&#xff0c;这对本就不是很快的串口带来说有不小负担&am…

Django框架之模型自定义管理器

类属性 objects 是manager类的一个对象&#xff0c;作用是与数据库进行交互。 当定义模型类没有指定管理器&#xff0c;django会为模型创建objects管理器。 表结构与数据 CREATE TABLE myapp_grades (id int(11) NOT NULL AUTO_INCREMENT,name varchar(20) NOT NULL,boy_num…

疫情红利出清后如何破局?华大智造的三场突围战

作者&#xff5c;严睿 华大智造&#xff08;688114.SH&#xff09;上市后的首份年报&#xff0c;亮点颇多。 比如2022年公司营收再创新高&#xff0c;达到42.31亿元&#xff0c;净利润同比增长3倍余&#xff1b;比如2022年度华大智造基因测序仪全球装机量达到600&#xff0c;…

处理日期和时间的 chrono 库

C11 中提供了日期和时间相关的库 chrono&#xff0c;通过 chrono 库可以很方便地处理日期和时间&#xff0c;为程序的开发提供了便利。chrono 库主要包含三种类型的类&#xff1a;时间间隔duration、时钟clocks、时间点time point。 1. Ratio 时间精度(节拍) std::chrono::ra…

helm和chart

Helm helm是Kubernetes 应用的包管理工具&#xff0c;主要用来管理 Charts&#xff0c;类似Linux系统的yum。Helm Chart 是用来封装 Kubernetes 原生应用程序的一系列 YAML 文件。可以在你部署应用的时候自定义应用程序的一些 Metadata&#xff0c;以便于应用程序的分发。 he…

Linux驱动编程(总线设备驱动模型)

一、驱动编写的3种方法 1、传统写法 使用哪个引脚&#xff0c;怎么操作引脚&#xff0c;都写死在代码中。最简单&#xff0c;不考虑扩展性&#xff0c;可以快速实现功能。修改引脚时&#xff0c;需要重新编译。 2、总线设备驱动模型 引入 platform_device/platform_driver&am…

【.NET基础加强第八课--委托】

.NET基础加强第八课--委托 委托&#xff08;Delegate&#xff09;委托操作顺序实例多播委托—委托链实例实例委托传值 委托&#xff08;Delegate&#xff09; 委托&#xff08;Delegate&#xff09; 是存有对某个方法的引用的一种引用类型变量 委托操作顺序 1,定义一个委托类…

SpringCloud------Eureka修改实例显示信息、服务发现Discovery、自我保护(六)

SpringCloud------Eureka修改实例显示信息、服务发现Discovery、自我保护&#xff08;六&#xff09; 1.actuator微服务信息完善 2.服务发现Discovery 3.Eureka自我保护 actuator微服务信息完善 web和actuator依赖用于图形化监控 1.主机名称&#xff1a;服务名称修改 新增…

新库上线 | CnOpenData缺陷产品召回数据

缺陷产品召回数据 一、数据简介 缺陷产品召回&#xff0c;是指缺陷产品的生产商、销售商、进口商在得知其生产、销售或进口的产品存在可能引发消费者健康、安全问题的缺陷时&#xff0c;依法向职能部门报告&#xff0c;及时通知消费者&#xff0c;设法从市场上、消费者手中收回…

快速跑通环信IM Android Demo

1、以Android 4.0.0 Demo为例 https://www.easemob.com/download/demo &#xff08;下载别的版本的demo 可以修改版本号直接下载就就可以&#xff09; https://downloadsdk.easemob.com/downloads/easemob-sdk-4.0.0.zip 运行时遇到以下报错在项目build.gradle中添加运行时遇…

SAXS测试在材料结构表征中的应用与优势

SAXS测试在材料结构表征中的应用与优势 SAXS是指小角X射线散射&#xff0c;是一种用于研究物质结构的重要技术。SAXS技术可以用于表征各种材料的结构&#xff0c;如聚合物、胶体、纳米粒子等。本文将介绍SAXS测试在材料测试表征中的应用&#xff0c;包括SAXS曲线、比表面积、粒…

MySQL基础(四)运算符

1. 算术运算符 算术运算符主要用于数学运算&#xff0c;其可以连接运算符前后的两个数值或表达式&#xff0c;对数值或表达式进行加&#xff08;&#xff09;、减&#xff08;-&#xff09;、乘&#xff08;*&#xff09;、除&#xff08;/&#xff09;和取模&#xff08;%&am…

选对信息化管理系统,企业运营效率大幅提升!

随着信息化的发展&#xff0c;企业信息化管理系统已经成为企业独立商业活动和发展的重要基础设施之一。然而&#xff0c;在众多的信息化管理系统中&#xff0c;选择一款适合企业的信息化管理系统并不是一件易事&#xff0c;本文将从选型的角度&#xff0c;为企业提供一些选对合…

第二章 图像基本运算及变换

文章目录 前言一、图像运算1. 加减乘除2. 位运算 二、翻转与旋转1.翻转2.旋转 三、仿射变换1. 介绍2. 变换的数学表达2.1 平移2.2 缩放2.3 旋转 3. 变换矩阵4. 变换叠加5. 变换矩阵的逆推6.OpenCV实现以及手动实现6.1 手动实现6.2OpenCV实现 7.向量空间----补充 四、透视变换1.…

人脉变现小程序裂变定制开发

人脉变现小程序裂变定制开发可以提供以下服务&#xff1a; 需求分析&#xff1a;了解客户的业务需求和目标&#xff0c;并为其量身定制开发方案&#xff0c;提供专业的建议和意见。 UI/UX设计&#xff1a;根据客户的品牌形象和用户体验要求&#xff0c;设计出符合客户需…

简单实现基于UDP与TCP的回显服务器

目录 前言UDP 版的回显服务器需要用到的 api服务端客户端UDP 版本的字典客户端和字典服务器 TCP 版的回显服务器需要用到的 api服务器客户端对服务器进行改进(使用线程池)TCP 版本的字典客户端和字典服务器 前言 我们写网络程序, 主要编写的是应用层代码. 真正要发送这个数据,…

浅谈联网汽车安全漏洞

​“智能网联汽车存在内生共性问题&#xff0c;即软硬件的漏洞后门&#xff0c;基于此进行的网络攻击可以直接带来勒索、盗窃、大规模车辆恶意操控风险&#xff0c;还有数据泄露等网络安全事件。如果内生的漏洞后门问题不解决&#xff0c;系统自身难保&#xff0c;很难谈系统安…

浙大数据结构第四周之二叉搜索树与平衡二叉搜索树(AVL)

题目详情&#xff1a;04-树4 是否同一棵二叉搜索树 给定一个插入序列就可以唯一确定一棵二叉搜索树。然而&#xff0c;一棵给定的二叉搜索树却可以由多种不同的插入序列得到。例如分别按照序列{2, 1, 3}和{2, 3, 1}插入初始为空的二叉搜索树&#xff0c;都得到一样的结果。于是…