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

2023-10-19 03:44

本文主要是介绍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/237074

相关文章

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Linux之软件包管理器yum详解

《Linux之软件包管理器yum详解》文章介绍了现代类Unix操作系统中软件包管理和包存储库的工作原理,以及如何使用包管理器如yum来安装、更新和卸载软件,文章还介绍了如何配置yum源,更新系统软件包... 目录软件包yumyum语法yum常用命令yum源配置文件介绍更新yum源查看已经安装软件的方法总结软

linux报错INFO:task xxxxxx:634 blocked for more than 120 seconds.三种解决方式

《linux报错INFO:taskxxxxxx:634blockedformorethan120seconds.三种解决方式》文章描述了一个Linux最小系统运行时出现的“hung_ta... 目录1.问题描述2.解决办法2.1 缩小文件系统缓存大小2.2 修改系统IO调度策略2.3 取消120秒时间限制3

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Linux:alias如何设置永久生效

《Linux:alias如何设置永久生效》在Linux中设置别名永久生效的步骤包括:在/root/.bashrc文件中配置别名,保存并退出,然后使用source命令(或点命令)使配置立即生效,这样,别... 目录linux:alias设置永久生效步骤保存退出后功能总结Linux:alias设置永久生效步骤

Window Server创建2台服务器的故障转移群集的图文教程

《WindowServer创建2台服务器的故障转移群集的图文教程》本文主要介绍了在WindowsServer系统上创建一个包含两台成员服务器的故障转移群集,文中通过图文示例介绍的非常详细,对大家的... 目录一、 准备条件二、在ServerB安装故障转移群集三、在ServerC安装故障转移群集,操作与Ser

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用