麒麟v10 上部署 TiDB v5.1.2 生产环境优化实践
706
2023-12-13
一篇搞懂tcp,http,socket,socket连接池之间的关系1、创建Socket连接时,可以指定使用的传输层协议,Socket可以支持不同的传输层协议(TCP或UDP),当使用TCP协议进行连接时,该Socket连接就是一个TCP连接。
socket则是对TCP/IP协议的封装和应用(程序员层面上)2、实际上,传输层的TCP是基于网路层的IP协议的,而应用层的HTTP协议又是基于传输层的TCP协议的,而Socket本身不算是协议,就像上面所说,它只是提供了一个针对TCP或者UDP程式设计的介面。
3、创建Socket连接时,可以指定使用的传输层协议,Socket可以支持不同的传输层协议(TCP或UDP),当使用TCP协议进行连接时,该Socket连接就是一个TCP连接 socket则是对TCP/IP协议的封装和应用(程序员层面上)。
4、TCP 和 UDP 是高速公路上的 “卡车” ,它们携带的货物就是像 HTTP ,文件传输协议 FTP 这样的协议等5、会话层、表示层、应用层TCP/IP不是OSI模型中的,它属于DOD模型,是融合了ISO七层中网络层和传输层。
HTTP是OSI模型中的应用程协议,是在最高层的UDP协议是OSI传输层的协议,在第四层6、一个socket需要包括以下的基本信息——发送端地址,接收端地址,传输过程使用的协议(可以是TCP也可以不是)。
在操作系统里面,socket是系统和网络堆栈之间的接口,数据从各种应用先送到socket,再从这里进入网络堆栈
Golang中mc有类似redis和mysql的连接池的处理吗1、在创建连接池之后,起一个 go routine,每隔一段 idleTime 发送一个 PING 到 Redis server其中,idleTime 略小于 Redis server 的 timeout 配置。
2、这样处理,主要是实时读写redis,而mysql数据则通过队列异步处理,缓解mysql压力,不过这种方法应用场景主要基于高并发,而且redis的高可用集群架构相对更复杂,一般不是很推荐3、释放连接方法 连接池的实现有很多方法,在database/sql包中使用的是chan阻塞 使用map记录等待列表,等到有连接释放的时候再把连接传入等待列表中的chan 不在阻塞返回连接。
4、当发生这种情况时,sql.DB会优雅地处理它坏连接将自动重试两次,然后放弃,此时Go将该连接从连接池中删除,并创建一个新的连接golang配制高性能sql.DB有很多教程是关于Go的sql.DB类型和如何使用它来执行SQL数据库查询的。
整体架构 kingshard采用Go开发,充分地利用了Go语言的并发特性Go语言在并发方面,做了很好的封装,这大大简化了kingshard的开发工作DB对象 获取方法 释放连接方法 连接池的实现有很多方法,在database/sql包中使用的是chan阻塞 使用map记录等待列表,等到有连接释放的时候再把连接传入等待列表中的chan 不在阻塞返回连接。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。