mysql 丢包_MySQL Transaction--网络丢包导致长时间未提交事务

TCP三次握手(Three-Way Handshake)

建立一个TCP连接时,需要客户端和服务端总共发送3个包以确认连接的建立。

f697b6af12781e767fd796aeb4019c2e.png

TCP三次握手:

第一次握手:Client将标志位SYN置为1,随机产生一个值seq=J,并将该数据包发送给Server,Client进入SYN_SENT状态,等待Server确认。

第二次握手:Server收到数据包后由标志位SYN=1知道Client请求建立连接,Server将标志位SYN和ACK都置为1,ack=J+1,随机产生一个值seq=K,并将该数据包发送给Client以确认连接请求,Server进入SYN_RCVD状态。

第三次握手:Client收到确认后,检查ack是否为J+1,ACK是否为1,如果正确则将标志位ACK置为1,ack=K+1,并将该数据包发送给Server,Server检查ack是否为K+1,ACK是否为1,如果正确则连接建立成功,Client和Server进入ESTABLISHED状态,完成三次握手,随后Client与Server之间可以开始传输数据了。

TCP四次挥手(Four-Way Wavehand)

断开一个TCP连接时,需要客户端和服务端总共发送4个包以确认连接的断开。

004bafb46157fc9a6f9db72c91721737.png

TCP四次挥手:

第一次挥手:Client发送一个FIN,用来关闭Client到Server的数据传送,Client进入FIN_WAIT_1状态。

第二次挥手:Server收到FIN后,发送一个ACK给Client,确认序号为收到序号+1(与SYN相同,一个FIN占用一个序号),Server进入CLOSE_WAIT状态。

第三次挥手:Server发送一个FIN,用来关闭Server到Client的数据传送,Server进入LAST_ACK状态。

第四次挥手:Client收到FIN后,Client进入TIME_WAIT状态,接着发送一个ACK给Server,确认序号为收到序号+1,Server进入CLOSED状态,完成四次挥手。

当客户端与MySQL数据库建立连接并开启事务后,MySQL数据库未正常收到连接断开导致长期未提交事务场景有:

1、应用服务器异常宕机

2、应用程序异常中止或线程异常关闭

3、网络发生抖动或网卡故障

对于上述连接异常断开导致的未提交事务,触发事务回滚的方式有:

1、数据库级别连接等待超时,由MySQL参数wait_timeout控制,默认8小时。

2、操作系统级别TCP连接超时,有下面TCP参数控制:

/proc/sys/net/ipv4/tcp_keepalive_time = 7200(等待空闲时间)/proc/sys/net/ipv4/tcp_keepalive_intvl = 75(等待探测间歇时间)/proc/sys/net/ipv4/tcp_keepalive_probes = 9(等待探测间歇次数)

3、手动或自动KILL连接

参考:

1、https://blog.csdn.net/sssnmnmjmf/article/details/68486261

2、有赞DBA在DTCC2019 上技术分享

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值