1. Linux网络模型

① OSI七层模型和Linux四层模型

② 各种协议之间的关系及在Linux模型中的位置

③ 协议封装:各种协议处于一种层层封装的关系

(1)Ethernet

(2)IP

  * IP主要有四个主要功能:数据传送,寻址,路由选择,数据报分段

  * IP的主要目的是为数据输入、输出网络提供基本算法,为高层协议提供无连接的传送服务

  * IP包由IP协议头和协议数据两部分构成

(3)TCP

  * TCP是重要的传输层协议,目的是允许数据同网络上的其他节点进行可靠的交换。他能提供端口编号的译码,以识别主机的应用程序,而完成数据的可靠传输

  * TCP协议具有严格的内装差错检验算法确保数据的完整性

  * TCP是面向字节的顺序协议,这意味着包内每个字节被分配一个顺序号,并分配给每包一个顺序号

(4)UDP

  * UDP也是传输层协议,他是无连接的不可靠的传输服务(执行速度比TCP快)

2. Linux中的网络编程由Socket实现,Socket是一种文件描述符

① Socket三种类型

(1)流式套接字(SOCK_STREAM):可以提供可靠的、面向连接的通讯,它使用TCP协议。TCP协议保证了数据传输的正确性和顺序性

(2)数据报套接字(SOCK_DGRAM):定义了一种无连接的服务,数据通过相互独立的报文进行传输,是无序的并且不保证可靠、无差错,它使用数据报协议UDP

(3)原始套接字(SOCK_RAW):允许使用IP协议,主要用于新的网络的测试

② 网络地址

(1)sockaddr:在头文件#include <sys/socket.h>中定义,缺陷是sa_data把目标地址和端口信息混在一起

struct sockaddr {
sa_family_t sin_family;//地址族
char sa_data[]; //14字节,包含套接字中的目标地址和端口信息
};

(2)sockaddr_in:在头文件#include<netinet/in.h>或#include <arpa/inet.h>中定义,该结构体解决了sockaddr的缺陷,把port和addr 分开储存在两个变量中

struct sockaddr_in {
sa_family_t sin_family; //地址族(Address Family)
uint16_t sin_port; //16位TCP/UDP端口号
struct in_addr sin_addr; //32位IP地址
char sin_zero[]; //不使用
};

(3)sockaddr和sockaddr_in长度一样,都是16个字节,即占用内存大小一致,因此可以相互转化。sockaddr_in用于socket定义和赋值;sockaddr用于函数参数

③网络字节序(Big Endian【低位先传、高位后传】)

(1)htons:把unsigned short(2byte)类型从主机序转换到网络序

(2)htonl:把unsigned long(4byte)类型从主机序转换到网络序

(3)ntohs:把unsigned short(2byte)类型从网络序转换到主机序

(4)ntohl:把unsigned long(4byte)类型从网络序转换到主机序

3. TCP网络设计

https://www.cnblogs.com/wulei0630/p/9469276.html

4. UDP网络设计

https://www.cnblogs.com/wulei0630/p/9469407.html

5. 循环服务器与并发服务器

① 循环服务器:服务器在同一时刻只能响应一个客户端的请求

② 并发服务器:服务器在同一时刻可以响应多个客户端的请求

③ 并发服务器的思想是每一个客户的请求并不由服务器直接处理,而是由服务器创建一个子进程来处理

https://www.cnblogs.com/wulei0630/p/9479138.html

6. Linux网络编程常用函数原型及参数与功能详细介绍

① int socket(int domain, int type, int protocol)

功能:用来建立一个新的socket,也就是向系统注册、通知系统建立一通信端口

domain:指定使用何种协议类型,AF_INET(Ipv4网络协议)、AF_INET6(Ipv6网络协议)

type:套接字类型,SOCK_STREAM(提供双向连接且可靠的数据流)、SOCK_DGRAM(使用不连续不可信赖的数据包连接)

protocol:用来指定socket所使用的传输协议编号,通常设为0即可

② int bind(int sockfd, const struct sockaddr* addr, socklent_t len)

功能:将IP地址端口等信息绑定到套接字

③ int connect(int sockfd, cosnt struct sockaddr* addr, socklent_t len)

功能:在请求服务的进程套接字(客户端)和提供服务的套接字(服务器)之间建立一个连接

④ int listen(int sockfd, int backlog)

功能:等待连接

⑤ int accept(int sockfd, struct sockaddr* restrict addr, socklent_t * restrict len)

功能:获得连接请求并建立连接

⑥ ssize_t send(int sockfd, const void* buf, size_t nbytes, int flag)

功能:发送数据

⑦ ssize_t recv(int sockfd, void* buf, size_t nbytes, int flag)

功能:接收数据

⑧ssize_t sendto(int sockfd, const void* buf, size_t nbytes, int flags, const struct sockaddr* destaddr, socklen_t destlen)

功能:向指定的地址发送数据

⑨ ssize_t recvfrom(int sockfd, void* restrict buf, size_t len, int flags, struct sockaddr* restrict addr, socklen_t* restrict addrlen)

功能:从指定的地址接收数据

Linux网络编程基础的更多相关文章

  1. 服务器编程入门(4)Linux网络编程基础API

      问题聚焦:     这节介绍的不仅是网络编程的几个API     更重要的是,探讨了Linux网络编程基础API与内核中TCP/IP协议族之间的关系.     这节主要介绍三个方面的内容:套接字( ...

  2. Linux 高性能服务器编程——Linux网络编程基础API

    问题聚焦:     这节介绍的不仅是网络编程的几个API     更重要的是,探讨了Linux网络编程基础API与内核中TCP/IP协议族之间的关系.     这节主要介绍三个方面的内容:套接字(so ...

  3. 第5章 Linux网络编程基础

    第5章 Linux网络编程基础 5.1 socket地址与API 一.理解字节序 主机字节序一般为小端字节序.网络字节序一般为大端字节序.当格式化的数据在两台使用了不同字节序的主机之间直接传递时,接收 ...

  4. Linux网络编程基础API

    第5章 Linux网络编程基础API 探讨Linux网络编程基础API与内核中TCP/IP协议族之间的关系,并未后续章节提供编程基础.从3个方面讨论Linux网络API. socket地址API.so ...

  5. linux高性能服务器编程 (五) --Linux网络编程基础api

    第五章 Linux网络编程基础api 1.主机字节序和网络字节序 字节序是指整数在内存中保存的顺序.字节序分为大端字节序.小端字节序. 大端字节序:一个整数的高位字节数据存放在内存的低地址处.低位字节 ...

  6. linux 网络编程 基础

    网络编程基础 套接字编程需要指定套接字地址作为参数,不同的协议族有不同的地址结构,比如以太网其结构为sockaddr_in. 通用套接字: struct sockaddr { sa_family_t ...

  7. linux网络编程基础--(转自网络)

    转自 http://www.cnblogs.com/MyLove-Summer/p/5215287.html Linux下的网络编程指的是socket套接字编程,入门比较简单. 1. socket套接 ...

  8. Linux 网络编程基础(4) -- Ping 的C代码实现

    1.背景 在进行网络编程的时候,通常使用的协议有TCP协议,UDP协议.这些协议在简历套接字之初需要制定套接字的类型,比如TCP应当设置为 SOCK_STREAM, UDP对应的套接字应当设置为SOC ...

  9. Linux 网络编程基础(1)--网络相关的数据结构及转化函数

    在Linux下进行网络编程,使用的语言一般为C.就个人感受而言,在Linux下进行网络程序的编写,重要的不是代码能力要多强,而是对Linux的网络编程思想的理解和对Linux网络数据结构的掌握.如果想 ...

随机推荐

  1. bzoj1951 组合数取模 中国剩余定理

    #include<bits/stdc++.h> using namespace std; typedef long long ll; const int a[4]={2,3,4679,35 ...

  2. JavaPersistenceWithHibernate第二版笔记-第六章-Mapping inheritance-007Inheritance of embeddable classes(@MappedSuperclass、@Embeddable、@AttributeOverrides、、)

    一.结构 二.代码 1. package org.jpwh.model.inheritance.embeddable; import javax.persistence.MappedSuperclas ...

  3. GCD 学习(八)dispatch_semaphore

    dispatch_semaphore 信号量基于计数器的一种多线程同步机制.在多个线程访问共有资源时候,会因为多线程的特性而引发数据出错的问题.     dispatch_queue_t queue ...

  4. Luogu 2737 [USACO4.1]麦香牛块Beef McNuggets

    NOIP2017 D1T1 的结论,两个数$a, b$所不能表示出的最大的数为$a * b - a - b$. 听了好几遍证明我还是不会 注意到本题中给出的数都非常小,所以最大不能表示出的数$\leq ...

  5. C++面试笔记--STL模板与容器

    1.C++ STL 之所以得到广泛的赞誉,也被很多人使用,不只是提供了像vector, string, list等方便的容器,更重要的是STL封装了许多复杂的数据结构算法和大量常用数据结构操作.vec ...

  6. 【java】小技巧和注意事项

    1.字符串反向比较  “abc”.equals(sting) 2.文档注释 /** *注释内容 */ 3.

  7. easyui textbox 设置只读不可编辑状态

    在使用easyul的时候,发现输入框内容及不容易获取与设置,用jQuery的方式大部分失效.依稀记得好像是因为easyul会在原页面的基础上,生成了一些新的独有样式,并且暂时覆盖掉使用了easyul的 ...

  8. linux源码安装apache

    apache安装之前,需要安装APR.APR-Util和PCRE依赖包 下载 Apache     下载地址: http://httpd.apache.org/download.cgi   (打开找最 ...

  9. Python3中集合的混合使用

    比较简单没什么好说的: list_1 = [1,2,3,4,6,3,2,5,7,8,2,1] list_1 = set(list_1) list_1.add(999) list_2 = set([2, ...

  10. vue_cli下开发一个简单的模块权限系统之实现登录

    因为我们需要和后端数据交互,所以我们需要安装axios,安装好以后在main.js引入 v-model是标识空间,v-on:click="doLogin"是登录事件 doLogin ...