CSAPP:第十一章 网络编程

11.1 客户端服务器模型11.2 全球IP因特网11.3 套接字接口

11.1 客户端服务器模型

  每个网络应用都是基于客户端-服务器模型。采用这个模型,一个应用是由一个服务器进程和一个或者多个客户端进程组成。
  客户端-服务器模型的基本操作是事务。一个客户端-服务器事务由以下四步组成。

  • 当一个客户端需要服务时,它向服务器发送一个请求,发起一个事务。
  • 服务器收到请求后,解释它,并以适当的方式操作它的资源。
  • 服务器给客户端发送一个响应,并等待下一个请求。
  • 客户端收到响应并处理它。

11.2 全球IP因特网

  客户端和服务器通常运行在不同的主机上,并且通过计算机网络的硬件和软件资源来通信。
  全球IP因特网是最著名和最成功的互联网网络实现。每台因特网主机都运行实现TCP/IP协议的软件,几乎每个现代计算机系统都支持这个协议。因特网的客户端和服务器混合使用套接字接口函数和unix I/O函数来进行通信。

11.3 套接字接口

  套接字接口是一组函数,它们和Unix I/O函数结合起来,用以创建网络应用。


11.3.1 套接字的地址结构
  因特网的套接字地址存放在类型sockaddr_in的16字节结构中。对于因特网的应用,sin_family成员是AF_INET,sin_port成员是一个16位的端口号,sin_addr成员就是一个32位IP地址。IP地址和端口号总是以网络字序(大端模式)存放的。

 1/* IP socket address structure */
2struct sockaddr_in {
3    uint16_t       sin_family;     /* Protocol family (always AF_INET)*/
4    uint16_t       sin_port;       /* Port number in network byte order */
5    struct in_addr sin_addr;       /* IP address in network byte order */
6    unsigned char  sin_zero[8];    /* Pad to sizeof(struct sockaddr) */
7};
8
9/* Generic socket address structure for(connect,bind and accept)*/
10struct sockaddr{
11    uint16_t sa_family;   /* Protocol family */
12    char     sa_data[14]; /* address data */
13};

11.3.2 socket函数
  客户端和服务器使用socket函数来创建一个套接字描述符。

1#include <sys/types.h>          /* See NOTES */
2#include <sys/socket.h>
3
4int socket(int domain, int type, int protocol);//若成功,返回套接字描述符;失败返回-1

11.3.3 connect函数
  客户端通过调用connect函数来建立和服务器的连接。connect函数试图与套接字地址为addr的服务器建立一个因特网连接,其中addrlen是sizeof(sockaddr_in)。connect函数会阻塞,一直到连接成功建立或者发生错误。

1#include <sys/types.h>          /* See NOTES */
2#include <sys/socket.h>
3
4int connect(int sockfd, const struct sockaddr *addr,socklen_t addrlen);

11.3.4 bind函数
  剩下的套接字函数--bind,listen和accept,服务器用它们来和客户端建立连接。

1#include <sys/types.h>          /* See NOTES */
2#include <sys/socket.h>
3
4int bind(int sockfd, const struct sockaddr *addr,socklen_t addrlen);

  bind函数告诉内核 addr中的服务器套接字地址和套接字描述符sockfd联系起来
11.3.5 listen函数
  客户端是发生连接请求的主动实体。服务器是等待客户端的连接请求的被动实体。默认情况下,内核会认为socket函数创建的描述符对应于主动套接字,它存在于一个连接的客户端。服务器调用listen函数告诉内核,描述符是被服务器使用而不是客户端。

1#include <sys/types.h>          /* See NOTES */
2#include <sys/socket.h>
3
4int listen(int sockfd, int backlog);

  listen函数将sockfd从一个主动套接字转化为一个监听套接字,该套接字可以接受来自客户端的连接请求.backlog参数暗示了内核在开始拒绝连接请求前,队列中要排队的未完成的连接请求的数量。
11.3.6 accept函数
  服务器通过调用accept函数来等待来自客户端的连接请求。

1#include <sys/types.h>          /* See NOTES */
2#include <sys/socket.h>
3
4int accept(int listenfd, struct sockaddr *addr, socklen_t *addrlen);

  accept函数等待来自客户端的连接请求到达侦听描述符listenfd,然后在addr中填写客户端的套接字地址,并返回一个已连接描述符,这个描述符可以被用来利用Unix I/O函数与客户端通信。

CSAPP:第十一章 网络编程的更多相关文章

  1. [CSAPP笔记][第十一章网络编程]

    第十一章 网络编程 我们需要理解基本的客户端-服务端编程模型,以及如何编写使用因特网提供的服务的客户端-服务端程序. 最后,我们将把所有这些概念结合起来,开发一个小的但功能齐全的Web服务器,能够为真 ...

  2. 深入理解计算机系统 第十一章 网络编程 part1 第二遍

    客户端-服务器编程模型 每个网络应用都是基于客户端-服务器模型的.采用这个模型,一个应用是由一个服务器进程和一个或者多个客户端进程组成.服务器管理某种资源,并且通过操作这种资源来为它的客户端提供某种服 ...

  3. 深入理解计算机系统 第十一章 网络编程 part2 第二遍

    客户端和服务器通过因特网这个全球网络来通信.从程序员的观点来看,我们可以把因特网看成是一个全球范围的主机集合,具有以下几个属性: 1.每个因特网主机都有一个唯一的 32 为名字,称为它的 IP 地址 ...

  4. 《深入浅出Node.js》第7章 网络编程

    @by Ruth92(转载请注明出处) 第7章 网络编程 Node 只需要几行代码即可构建服务器,无需额外的容器. Node 提供了以下4个模块(适用于服务器端和客户端): net -> TCP ...

  5. Python第十三章-网络编程

    网络编程 一.网络编程基础 python 的网络编程模块主要支持两种Internet协议: TCP 和 UDP. 1.1通信协议 通信协议也叫网络传输协议或简称为传送协议(Communications ...

  6. Java高级程序设计笔记 • 【第4章 网络编程】

    全部章节   >>>> 本章目录 4.1 网络基础知识 4.1.1 IP地址 4.1.2 端口号 4.1.3 使用InetAddress 4.1.4 InetAddress 类 ...

  7. Linux Linux程序练习十一(网络编程大文件发送UDP版)

    //网络编程发送端--大文件传输(UDP) #include <stdio.h> #include <stdlib.h> #include <string.h> # ...

  8. 《python核心编程》读书笔记--第16章 网络编程

    在进行网络编程之前,先对网络以及互联网协议做一个了解. 推荐阮一峰的博客:(感谢) http://www.ruanyifeng.com/blog/2012/05/internet_protocol_s ...

  9. 第六章|网络编程-socket开发

    1.计算机基础 作为应用开发程序员,我们开发的软件都是应用软件,而应用软件必须运行于操作系统之上,操作系统则运行于硬件之上,应用软件是无法直接操作硬件的,应用软件对硬件的操作必须调用操作系统的接口,由 ...

随机推荐

  1. python3 变量理解 解释器理解 常量理解 用户交互理解 逻辑运算

    先来条NLP再说...... 九,每人都已经具备使自己快乐的资源 每一个人都有过成功快乐的体验,也即是说有使自己快乐的能力. 人类只用了大脑能力极少部分,提升大脑的运用,很多新的突破便会出现. 运用大 ...

  2. centos7 ambari2.6.1.5+hdp2.6.4.0 大数据集群安装部署

    前言 本文是讲如何在centos7(64位) 安装ambari+hdp,如果在装有原生hadoop等集群的机器上安装,需要先将集群服务停掉,然后将不需要的环境变量注释掉即可,如果不注释掉,后面虽然可以 ...

  3. 如何使用SignTool签署应用程序包

    备注 有关签署UWP应用程序包的信息,请参阅使用SignTool签署应用程序包. 了解如何使用SignTool对Windows应用商店应用包进行签名,以便部署它们.SignTool是Windows软件 ...

  4. java虚拟机内存区域

    java虚拟机运行时数据 程序计数器 是一块较小的内存空间,属于线程私有的内存. 用来记录正在执行的虚拟机字节码指令的地址. 每个线程都需要一个独立的程序计数器,各个线程间的计数器互不影响,独立存储. ...

  5. iFace Chain [ 爱妃链 ] 或将凭借人脸密钥技术成为安全领域最大的赢家

    前段时间iFace Chain [ 中文音译名称: 爱妃链 ] 安全专家揭密了区块链领域,数字资产存放于无信用钱包中的一些风险,并为区块链玩家解密如何安全保护资产私钥,我们再来回顾分析一下目前跑路钱包 ...

  6. 开源图像标注工具labelme的安装使用及汉化

    一 LabelMe简介 labelme是麻省理工(MIT)的计算机科学和人工智能实验室(CSAIL)研发的图像标注工具,人们可以使用该工具创建定制化标注任务或执行图像标注,项目源代码已经开源. 项目开 ...

  7. TensorFlow使用GPU

    查看机器 GPU 的信息: nvidia-smi 持续更新查看: nvidia-smi -l 其他方式如下: import os # 使用GPU0 和 GPU1 os.environ['CUDA_VI ...

  8. 文本离散表示(二):新闻语料的one-hot编码

    上一篇博客介绍了文本离散表示的one-hot.TF-IDF和n-gram方法,在这篇文章里,我做了一个对新闻文本进行one-hot编码的小实践. 文本的one-hot相对而言比较简单,我用了两种方法, ...

  9. ASP.NET Core中使用GraphQL - 第三章 依赖注入

    ASP.NET Core中使用GraphQL ASP.NET Core中使用GraphQL - 第一章 Hello World ASP.NET Core中使用GraphQL - 第二章 中间件 SOL ...

  10. DotNetCore跨平台~认识环境和环境变量

    回到目录 环境 环境,对于开发来说就是部署的一种场景,你可以是调试场景,测试场景,生产场景,当然还可以有很多其它的场景,只要你的项目需要就可以自定义,微软帮我们定义了三种标准的环境变量,下面来说一下. ...