关注
一、四层模型分层
TCP/IP四层模型包括以下层次:
1. **应用层**:处理特定应用程序的细节,例如HTTP、FTP等协议都在此层工作。
2. **传输层**:为两台主机上的应用程序提供端到端的通信。主要协议有TCP(传输控制协议)和UDP(用户数据报协议)。
3. **网络层**:负责数据包的路由和转发,通过IP协议实现。
4. **网络接口层**:也称为数据链路层和物理层,处理物理层上的比特流的接收和发送。
二、HTTP和HTTPS的区别
1. **安全性**:
- HTTPS比HTTP更安全,因为它在传输数据前***L/TLS握手进行加密,防止数据被窃取或篡改。HTTP则以明文形式传输数据,安全性较低。
2. **连接方式**:
- HTTP是无状态、明文传输的协议,连接较简单。
- HTTPS在TCP三次握手后,还需进行SSL/TLS握手以建立安全连接,过程更复杂且耗时。
3. **端口号**:
- HTTP默认使用80端口。
- HTTPS默认使用443端口。
4. **证书要求**:
- HTTPS需要数字证书验证服务器身份,确保连接到正确的服务器。HTTP则不需要证书。
三、TCP头部
TCP头部通常为20字节,包含以下主要字段:
1. **源端口和目的端口**:各16位,标识发送和接收方的应用程序端口号。
2. **序列号**:32位,标识TCP报文段中数据字节流的顺序。
3. **确认号**:32位,期望收到对方下一个报文段的第一个数据字节的序号。
4. **数据偏移**:4位,指示TCP报文段数据起始处与TCP报文段起始处的距离。
5. **保留**:6位,保留供未来使用,当前应设为0。
6. **控制位**:6位,包括URG(紧急指针有效)、ACK(确认号有效)、PSH(尽快将报文段交给应用层)、RST(重置连接)、SYN(发起连接同步序号)、FIN(发送端完成发送任务)。
7. **窗口大小**:16位,用于流量控制,表示接收方愿意接收的字节数。
8. **校验和**:16位,检查TCP报文段在传输过程中是否出错。
9. **紧急指针**:16位,仅在URG标志置1时有效,指出报文段中紧急数据的最后一个字节的序号。
四、InnoDB的索引
InnoDB是MySQL数据库的一种存储引擎,支持多种索引类型:
1. **聚簇索引**:即主键索引,数据行的物理存储顺序与索引顺序一致。InnoDB会自动为主键创建聚簇索引,若无主键则选择唯一非空索引代替,若无此类索引则隐式定义主键作为聚簇索引。
2. **二级索引**:即非聚簇索引,叶子节点存储索引值及对应的主键值。通过二级索引查找数据时,先在二级索引中找到主键值,再通过主键值在聚簇索引中查找具体数据行。
3. **联合索引**:由多个列组成的索引。使用联合索引查询时,需根据最左匹配原则,即查询条件必须包含联合索引的最左列,才能利用该联合索引优化查询。
查看原帖
点赞 评论
相关推荐
牛客热帖
更多
正在热议
更多
# 你的实习产出是真实的还是包装的? #
36371次浏览 434人参与
# 网申一定要掌握的小技巧 #
20491次浏览 86人参与
# 厦门银行科技岗值不值得投 #
15966次浏览 359人参与
# 一人一道大厂面试题 #
125004次浏览 1302人参与
# 学历VS实习,哪个更重要? #
2866次浏览 70人参与
# 面试紧张时你会有什么表现? #
34531次浏览 218人参与
# 你的实习什么时候入职 #
367210次浏览 2361人参与
# uu们,春招你还来吗? #
65055次浏览 794人参与
# 面试中,你被问过哪些奇葩问题? #
97236次浏览 1314人参与
# 发工资后,你做的第一件事是什么 #
99715次浏览 319人参与
# 牛油的搬砖plog #
188532次浏览 1253人参与
# 面试被问到不会的问题,你怎么应对? #
27244次浏览 695人参与
# 你都用vibe coding做过什么? #
23430次浏览 884人参与
# 90后北漂现状 #
36126次浏览 213人参与
# 工作上你捅过哪些篓子? #
68540次浏览 317人参与
# 分享一个让你热爱工作的瞬间 #
67320次浏览 500人参与
# 关于春招你都做了哪些准备? #
145101次浏览 767人参与
# 你觉得大几开始实习最合适? #
31449次浏览 338人参与
# 你见过哪些招聘隐形歧视? #
26671次浏览 217人参与
# 哔哩哔哩笔试 #
35263次浏览 143人参与
# 一人分享一道面试手撕题 #
111176次浏览 2617人参与
