计算机网络知识等汇总补充

news2025/1/21 21:58:17

在这里插入图片描述


计算机网络知识汇总补充

  • 一、四次挥手
    • 1、为什么TCP要等待2MSL
    • 2、如果说一个系统中,有大量的time_wait和close_wait,会是什么原因?
  • 二、你是怎么解决粘包问题?
  • 三、你觉得哪些场景适合redis
  • 四、redis的持久化策略
  • 五、你会怎么保证mysql 和Redis的一致性
  • 六、事务隔离级别和MVCC控制的理解?
  • 七、对称加密非对称加密
  • 八、堆和栈的不同
  • 九、如果A服务调B服务出现失败:下游服务调用失败,或者无法响应请求了,怎么优化
  • 十、redo log,bin log, undo log

一、四次挥手

在这里插入图片描述

1、刚开始客户端和服务端都处于连接状态,假如客户端发起关闭请求
2、第一次挥手:客户端向服务器发送FIN报文,发完进入FIN_WAIT_1状态,即主动关闭TCP连接,不再发送数据,但是可以接收服务器发来的报文,等待服务器回复。;
3、第二次挥手:服务器接到FIN报文,返回一个ACK报文,表名自己接收到此报文,服务器进入CLOSE_WAIT等待关闭状态,此时客户端就知道服务端接收到自己的断开连接的请求,进入FIN_WAIT_2状态,TCP处于半关闭状态,但是服务器可能还有数据要传输。
4、第三次挥手:服务器关闭客户端连接,发送FIN报文给客户端数据传输完毕,等待客户端回应。
5、第四次握手:客户端收到FIN报文后,发送一个ACK给服务端做为应答,此时客户端处于TIME_WAIT状态,这个状态是为了等待足够的时间以确保TCP接收到连接中断请求的确认

1、为什么TCP要等待2MSL

注意:这时服务器到客户端的TCP连接并未被释放,客户端需要经过等待2MSL(MSL表示一个报文的来回时间)后才会进入CLOSED状态,这样做的目的是确保服务器收到自己的ACK报文,如果在规定时间没有收到客户端发的ACK,那么服务器会重发FIN,客户端再次收到FIN报文,就知道自己的ACK丢了,然后会重发ACK给服务器。服务器收到ACK后,就会关闭连接,处于CLOSE状态了。

2、如果说一个系统中,有大量的time_wait和close_wait,会是什么原因?

未正确关闭连接
处理连接过程中出错
网络延迟或故障

二、你是怎么解决粘包问题?

1、粘包定义:粘包指的是数据和数据之间没有明确的分界线导致不能正确读取数据。
2、这意味着UDP根本不会粘包,但是会丢数据,不可靠。意味着: TCP传输数据是可靠的,但是会粘包。
所谓粘包问题主要还是因为:
1、接收方不知道消息之间的界限,不知道一个消息要提取多少字节的数据所造成的。 (服务器端出现黏包)
2、tcp在发送数据少且间隔时间短的数据时,会将几条和并一起发送。(客户端出现黏包)

3、黏包的解决办法:
为字节流加上一个报头,告诉发送的字节流总大小,然后接收端来一个死循环接收完所有数据。用struck将序列化后的数据长度打包成4个字节(4个字节完全够用)。
客户端把数据长度封装成一个固定大小的数据, 这时服务端就可以指定读取固定大小的内容,不会读取数据的内容,服务端只要根据数据长度再来接收数据内容就好了,所以客户端连续两次发数据(文件) , 不会粘包,因为服务器端每次接收都只接收了本次该接收的数据。

4.你使用TCP的时候会出现,那么UDP会出现吗
- 不会出现

三、你觉得哪些场景适合redis

  • String(字符串):缓存、计数器限流
  • Hash(哈希):存储对象数据、统计类数据
  • List(列表):文章列表
  • Set(无序集合):标签、点赞、签单
  • Zset(有序集合):排行榜

redis你使用的场景
string异步执行任务,消息队列

四、redis的持久化策略

  • RDB持久化:RDB持久化会在指定的时间间隔内生成一个快照文件(Snapshot),将数据集的内容写入一个压缩的二进制文件中。RDB持久化方式适合数据集较大,但不要求数据丢失太多的场景。可以通过配置文件设置快照生成的条件和时间间隔。

  • AOF持久化:AOF持久化是以日志的方式记录每个写操作的命令,在Redis重启时重新执行这些命令来恢复数据。AOF持久化方式保证了每个写操作的数据一致性和持久性,但相比RDB会更占用磁盘空间和对性能有一定影响。

五、你会怎么保证mysql 和Redis的一致性

  • 淘汰缓存:在更新 MySQL 数据后,异步地更新 Redis 中的数据。这种方式可以降低对数据库写入性能的影响,但可能会导致短暂的数据不一致。
  • 更新缓冲:在系统中同时写入 MySQL 和 Redis,确保两者的数据保持一致。这种方式可以保证每次写入操作都同时更新 MySQL 和 Redis,但会增加系统的写入负载。
  • 消息队列:使用消息队列来实现 MySQL 和 Redis 数据的同步。在数据库更新后发送消息到队列,消费者将消息同步到 Redis 中,确保数据的一致性。
  • 监控和报警:实时监控 MySQL 和 Redis 的数据一致性,一旦发现数据不一致情况,及时进行报警并修复。

六、事务隔离级别和MVCC控制的理解?

  • 用于处理并发事务的一致性和隔离性

  • MVCC是一种并发控制机制,常用于数据库管理系统中,用于解决并发访问数据库时的数据一致性问题。MVCC通过在每个数据项上维护多个版本来实现并发控制。

    • MVCC的核心思想是在读操作和写操作之间创建一个快照,使得读操作不会被写操作所阻塞,从而提高并发性能。具体实现方式如下:
    1. 版本号:每个数据项都会有一个版本号,用于标识该数据项的版本。当一个事务开始时,它会获得一个全局的事务ID,并将该ID作为版本号。

    2. 读操作:当一个事务执行读操作时,它会读取最新的符合条件的版本。如果存在比当前事务ID更大的版本号,则说明该数据项已被其他事务修改,当前事务需要等待。

    3. 写操作:当一个事务执行写操作时,它会创建一个新的版本,并将新版本的数据写入数据库。同时,该事务会更新所有已读取该数据项的事务的版本号,使得它们无法再读取旧版本。

    4. 回滚:如果一个事务执行过程中发生了错误或者被取消,它可以通过回滚操作将数据库恢复到事务开始之前的状态。回滚操作会撤销该事务对数据库的所有修改。

    • MVCC的优点是提高了并发性能和并发控制的粒度,减少了锁的使用,从而减少了事务之间的冲突。但也存在一些缺点,如增加了存储空间的开销和读操作的复杂性。

七、对称加密非对称加密

对称加密

  • 对称加密使用相同的密钥(称为私钥)来加密和解密数据。
  • 加密和解密过程使用同一个密钥,因此对称加密算法在加密和解密速度上通常比较快。
  • 常见的对称加密算法包括AES(高级加密标准)等。

非对称加密

  • 非对称加密使用一对密钥(公钥和私钥)来加密和解密数据。
  • 公钥用于加密数据,私钥用于解密数据,这两个密钥是相关联的,但不相同。
  • 非对称加密算法能够实现数据的安全传输和身份认证,但由于涉及复杂的数学运算,其加密和解密速度较慢。
  • 常见的非对称加密算法包括 RSA等。

八、堆和栈的不同

九、如果A服务调B服务出现失败:下游服务调用失败,或者无法响应请求了,怎么优化

  1. 实现重试机制

    • 在A服务发现调用B服务失败时,可以实现简单的重试机制,尝试重新调用B服务一定次数,以确保请求能够成功响应。
    • 重试机制可以设置一定的重试间隔和次数,避免过多的请求导致负担增加。
  2. 实现服务降级

    • 当B服务无法响应或出现异常时,A服务可以实现服务降级策略,返回默认值或者缓存数据,保证用户体验。
    • 服务降级可以在一定程度上减少对下游服务的依赖,提高系统的可用性。
  3. 设置超时时间

    • 为A服务调用B服务设置合理的超时时间,以避免长时间等待响应导致的性能问题。
    • 当超过设定的超时时间后,可以及时进行异常处理或重试操作。

十、redo log,bin log, undo log

  • binlog:主节点 binlog,主从复制的基础是主库记录数据库的所有变更记录到 binlog。binlog是数据库服务器启动的那一刻起,保存所有修改数据库结构或内容的一个文件。
  • undo log记录事务提交前的状态,更新前的值,用于事务回滚;
  • redo log记录事务提交后的状态,更新后的值,用于数据恢复,持久化

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

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

相关文章

视频基础学习六——视频编码基础三(h264框架配合图文+具体抓包分析 万字)

系列文章目录 视频基础学习一——色立体、三原色以及像素 视频基础学习二——图像深度与格式(RGB与YUV) 视频基础学习三——视频帧率、码率与分辨率 视频基础学习四——视频编码基础一(冗余信息) 视频基础学习五——视频编码基础…

WinRAR再爆0 day漏洞,0 day漏洞该如何有效预防

WinRAR再爆0 day漏洞,已被利用超过4个月。 Winrar是一款免费的主流压缩文件解压软件,支持绝大部分压缩文件格式的解压,全球用户量超过5亿。Group-IB研究人员在分析DarkMe恶意软件时发现WinRAR在处理ZIP文件格式时的一个漏洞,漏洞…

基于Springboot的笔记记录分享网站(有报告)。Javaee项目,springboot项目。

演示视频: 基于Springboot的笔记记录分享网站(有报告)。Javaee项目,springboot项目。 项目介绍: 采用M(model)V(view)C(controller)三层体系结构…

牛客 NC36 在两个长度相等的排序数组中找到上中位数【中等 模拟 Java,Go,PHP】

题目 题目链接: https://www.nowcoder.com/practice/6fbe70f3a51d44fa9395cfc49694404f 思路 直接模拟2个数组有顺序放到一个数组中,然后返回中间的数参考答案java import java.util.Scanner;// 注意类名必须为 Main, 不要有任何 package xxx 信息 pu…

使用htmlentities()和nl2br()将文本数据正确显示到前台

问题&#xff1a; 在后台textarea里编辑了有一串字符串&#xff0c;虽然在textarea里编辑是有换行效果的&#xff0c;但是数据获取到就只是\n&#xff0c;前端是不认识这个的&#xff0c;正确输出到前台的换行只能是<br/>。 $str "ABCDEFGHIJKLMNOPQ"; echo…

Multisim仿真二极管、晶体管和场效应管学习笔记

Multisim仿真二极管、晶体管和场效应管 &#xff08;note&#xff1a;使用Multisim14.0版本进行仿真&#xff09; 文章目录 Multisim仿真二极管、晶体管和场效应管二极管的I-V特性晶体管的I-V特性场效应管的I-V特性 二极管的I-V特性 插入I-V analyzer 原理图绘制 改变仿真…

【MCU开发规范】:MCU的性能测试

MCU的性能测试 前序性能评判方法MIPSCoreMark EEMBC其他参考 前序 我们平时做MCU开发时&#xff0c;前期硬件选型&#xff08;选那颗MCU&#xff09;基本由硬件工程师和架构决定&#xff0c;到软件开发时只是被动的开发一些具体功能&#xff0c;因此很少参与MCU的选型。 大部分…

面试经典算法系列之二叉树1 -- 从前序与中序遍历序列构造二叉树

面试经典算法16 - 从前序与中序遍历序列构造二叉树 LeetCode.105 公众号&#xff1a;阿Q技术站 问题描述 给定两个整数数组 preorder 和 inorder &#xff0c;其中 preorder 是二叉树的先序遍历&#xff0c; inorder 是同一棵树的中序遍历&#xff0c;请构造二叉树并返回其根…

02 - Git 之命令 +

1 Git相关概念 1.1 以下所谈三个区&#xff0c;文件并不只是简单地在三个区转移&#xff0c;而是以复制副本的方式转移 使用 Git 管理的项目&#xff0c;拥有三个区域&#xff0c;分别是 Working area工作区&#xff08;亦称为 工作树Working Tree&#xff09;、stage area …

学习JavaEE的日子 Day33 File类,IO流

Day33 1.File类 File是文件和目录路径名的抽象表示 File类的对象可以表示文件&#xff1a;C:\Users\Desktop\hhy.txt File类的对象可以表示目录路径名&#xff1a;C:\Users\Desktop File只关注文件本身的信息&#xff08;文件名、是否可读、是否可写…&#xff09;&#xff0c…

简单了解JVM

一.JVM简介 jvm及Java virtual machineJava虚拟机&#xff0c;它是一个虚构出来的计算机&#xff0c;一种规范。其实抛开这么专业的句子不说&#xff0c;就知道 JVM 其实就类似于一台小电脑运行在 windows 或者 linux 这些操作系统环境下即可。它直接和操作系统进行交互&#…

无人新零售引领的创新浪潮

无人新零售引领的创新浪潮 在数字化时代加速演进的背景下&#xff0c;无人新零售作为商业领域的一股新兴力量&#xff0c;正以其独特的高效性和便捷性重塑着传统的购物模式&#xff0c;开辟了一条充满创新潜力的发展道路。 依托人脸识别、物联网等尖端技术&#xff0c;无人新…

中位数和众数-第12届蓝桥杯选拔赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第49讲。 中位数和众数&…

初识 QT

初始QT 什么是QTQT发展史QT支持的平台QT的优点QT的应用场景搭建QT开发环境QT的开发工具概述QT下载安装 使用QT创建项目QT 实现Hello World程序使用按钮控件来实现使用标签控件来实现 项目文件解析widget.hmain.cppwidget.cppwidget.ui.pro文件 对象树QT 窗口坐标体系 什么是QT …

《战神4》和《战神5》有什么联系吗 苹果电脑如何运行《战神4》苹果电脑玩战神 Mac玩游戏 战神5攻略 crossover激活码

《战神4》&#xff08;God of War 2018&#xff09;和《战神5》&#xff08;God of War: Ragnark&#xff09;是一对引人注目的游戏作品&#xff0c;它们不仅在游戏界引起了广泛的关注&#xff0c;也给玩家带来了深入探索北欧神话世界的机会。这两部游戏之间的联系不仅体现在剧…

hbase基础shell用法

HBase中用create命令创建表&#xff0c;具体如下&#xff1a; create student,Sname,Ssex,Sage,Sdept,course 此时&#xff0c;即创建了一个“student”表&#xff0c;属性有&#xff1a;Sname,Ssex,Sage,Sdept,course。因为HBase的表中会有一个系统默认的属性作为行键&#x…

移远通信:立足5G RedCap新质生产力,全力推动智能电网创新发展

随着全球能源结构的转型和电力需求的持续增长&#xff0c;智能电网产业迎来了新的发展机遇。而物联网、大数据等前沿技术的创新和应用&#xff0c;正在为电力行业的发展注入强劲的新质生产力。 4月9日&#xff0c;第四十八届中国电工仪器仪表产业发展技术研讨及展会在杭州拉开帷…

debian安装和基本使用

debian安装和基本使用 文章目录 debian安装和基本使用1. 为什么选择debian2. 如何下载Debian2.1 小型安装镜像2.2 完整安装镜像 3. Debian操作系统安装3.1 创建Debian虚拟机3.2 安装操作系统 4. Debian系统的初始设置4.1 桌面环境的配置4.2 配置网络4.3 生效网络配置4.4 配置de…

【ubuntu20.04】安装GeographicLib

下载地址 GeographicLib: Installing GeographicLib 我们是ubuntu20.04 &#xff0c;所以下载第一个 GeographicLib-2.3.tar.gz 接着跟着官方步骤安装&#xff0c;会出错&#xff01;&#xff01;&#xff01;&#xff01;马的 官方错误示例&#xff1a;tar xfpz Geographi…

React + three.js 3D模型骨骼绑定

系列文章目录 React 使用 three.js 加载 gltf 3D模型 | three.js 入门React three.js 3D模型骨骼绑定React three.js 3D模型面部表情控制 项目代码(github)&#xff1a;https://github.com/couchette/simple-react-three-skeleton-demo 项目代码(gitcode)&#xff1a;https:…