Linux高性能服务器编程——ch1笔记

2023-10-19 04:01

本文主要是介绍Linux高性能服务器编程——ch1笔记,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第1章 TCP/IP 协议族

1.1 TCP/IP 协议族体系结构以及主要协议

image.png
数据链路层
网卡接口的网络驱动程序,以处理数据在物理媒介(比如以太网、令牌环等)上的传输。
协议:ARP、RARP,实现IP地址和机器物理地址之间的转换。
网络层
数据包的选路和转发。WAN使用路由器(中间节点)连接分散的主机或LAN。
协议:IP,逐跳确定通信路径;ICMP,补充,检测网络连接,如ping。
传输层
为两台主机上的应用程序提供端到端的通信。image.png
数据链路层(驱动程序)封装了物理网络的电气细节;网络层封装了网络连接的细节;传输层则为应用程序封装了一条端到端的逻辑通信链路,它负责数据的收发、链路的超时重连等。
协议:TCP,为应用层提供可靠的(超时重传、数据确认)、面向连接(TCP连接,内核数据结构)的和基于流(没有边界、长度限制)的服务;UDP,为应用层提供不可靠、无连接(发送时指定IP地址等信息)和基于数据报(以指定长度为最小单位截断读出)的服务;SCTP,传输电话信号而设计。
应用层
处理应用程序的逻辑。
协议:telnet,远程登录协议,在本地完成远程任务;OSPF,动态路由更新协议,路由间通信;DNS,机器域名到IP地址的转换。

1.2 封装

封装实现上层协议使用下层协议提供的服务。
image.png
image.png
帧(以太网帧、令牌环帧)的最大传输单元(MTU)限制数据报分片传输。

1.3 分用

当帧到达目的主机时,将沿着协议栈自底向上依次传递。各层协议依次处理帧中本层负责的头部数据,以获取所需的信息,并最终将处理后的帧交给目标应用程序。依靠头部信息中的类型字段实现。
image.png

1.4 测试网络

image.png
LAN网络IP地址。

1.5 ARP协议工作原理

网络层地址(IP地址)至任意物理地址(MAC地址)的转换。
工作原理:主机向自己所在的网络广播一个ARP请求( 00:16:d3:5c:b9:e3 > ff:ff:ff:ff:ff:ff),该请求包含目标机器的网络地址。此网络上的其他机器都将收到这个请求,但只有被请求的目标机器会回应一个ARP应答( 08:00:27:53:10:67 > 00:16:d3:5c:b9:e3),其中包含自己的物理地址。
image.png
在构建ARP应答时填充目的端以太网地址,并将发送端和目的端交换,并修改操作字段。
arp [-a] [-d] [-s]命令:ARP维护一个高速缓存,保存经常访问的映射。
tcpdump命令:抓取机器之间交换的以太网帧。
image.png
ARP 请求和应答是从以太网驱动程序发出的。
路由器也将接收到以太网帧 1, 因为该帧是一个广播帧。

1.6 DNS工作原理

分布式域名服务系统,存放动态更新的机器名和IP地址的映射。
image.png
保存DNS服务器IP地址:/etc/resolv.conf
访问DNS服务器:host [-t]

1.7 socket 和 TCP/IP 协议族的关系

数据链路层、网络层、传输层协议是在内核中实现的,因此操作系统需要实现一组系统调用,使得应用程序能够访问这些协议提供的服务。实现这组系统调用的 API主要有两套:socket 和 XTI。
socket功能:一是将应用程序数据从用户缓冲区中复制到 TCP/UDP 内核发送缓冲区,或者是从内核 TCP/UDP 接收缓冲区中复制数据到用户缓冲区,以读取数据;二是应用程序可以通过它们来修改内核中各层协议的某些头部信息或其他数据结构,从而精细地控制底层通信的行为。比如可以通过 setsockopt 函数来设置 IP 数据报在网络上的存活时间。

这篇关于Linux高性能服务器编程——ch1笔记的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/237171

相关文章

linux如何复制文件夹并重命名

《linux如何复制文件夹并重命名》在Linux系统中,复制文件夹并重命名可以通过使用“cp”和“mv”命令来实现,使用“cp-r”命令可以递归复制整个文件夹及其子文件夹和文件,而使用“mv”命令可以... 目录linux复制文件夹并重命名我们需要使用“cp”命令来复制文件夹我们还可以结合使用“mv”命令总

Linux使用cut进行文本提取的操作方法

《Linux使用cut进行文本提取的操作方法》Linux中的cut命令是一个命令行实用程序,用于从文件或标准输入中提取文本行的部分,本文给大家介绍了Linux使用cut进行文本提取的操作方法,文中有详... 目录简介基础语法常用选项范围选择示例用法-f:字段选择-d:分隔符-c:字符选择-b:字节选择--c

MySQL 中的服务器配置和状态详解(MySQL Server Configuration and Status)

《MySQL中的服务器配置和状态详解(MySQLServerConfigurationandStatus)》MySQL服务器配置和状态设置包括服务器选项、系统变量和状态变量三个方面,可以通过... 目录mysql 之服务器配置和状态1 MySQL 架构和性能优化1.1 服务器配置和状态1.1.1 服务器选项

Linux使用nload监控网络流量的方法

《Linux使用nload监控网络流量的方法》Linux中的nload命令是一个用于实时监控网络流量的工具,它提供了传入和传出流量的可视化表示,帮助用户一目了然地了解网络活动,本文给大家介绍了Linu... 目录简介安装示例用法基础用法指定网络接口限制显示特定流量类型指定刷新率设置流量速率的显示单位监控多个

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

Linux流媒体服务器部署流程

《Linux流媒体服务器部署流程》文章详细介绍了流媒体服务器的部署步骤,包括更新系统、安装依赖组件、编译安装Nginx和RTMP模块、配置Nginx和FFmpeg,以及测试流媒体服务器的搭建... 目录流媒体服务器部署部署安装1.更新系统2.安装依赖组件3.解压4.编译安装(添加RTMP和openssl模块

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏