为了执行网络I/O操作.进程必须做的第一件事情就是调用Socket函数.指定期待的通信协议

  1. #include<sys/socket.h>
  2. int socket(int family,int type,int protocol);

family表示协议族,比如AF_INET,type表示套接字类型, protocol一般设置为0
family: AF_INET ipv4协议
type: SOCK_STREAM 字节流套接字 SOCK_DGRAM 数据报套接字 SOCK_RAW 原始套接字
protocol:一般是设置为0

connect函数
  1. #include<sys/socket.h>
  2. int connect(int sockfd,const struct sockaddr*servaddr,socklen_t addrlen);
该套接字结构必须含有服务器的ip地址.客户端在调用connect之前不用bind.因为一般不需要知道客户端的ip跟端口.因此不调用bind直接connect.内核会指定一个本地地址跟一个临时端口

TCP中connect函数将激发tcp三次握手过程.只有建立成功或者出错时才会返回,其中出错的返回有以下3种情况
(1)客户端木有收到syn发送出去后服务端返回的ack.一般无响应会再次发送.一旦还没收到.就会返回etimedout错误.表示超时
(2).对客户端的SYN响应是RST.客户端一旦收到马上返回ECONNREFUSED错误
(3)客户端发出的syn在中间的某个路由器引发了一个"destination unreachable(目标无法到达)ICMP错误.客户主机将保存该信息,并按第一种情况间隔一段时间继续发送SYN.如果在某个规定的时间依然没有收到响应.就把保存的信息作为ehostunreach错误返回给进程.以下两种情况也有可能:按照本地系统转发表,没有到达远程系统的路径.connect调用根本不等待就返回

bind函数
bind把一个本地协议地址(ipv4 or ipv6)跟端口(2者非必须)绑定到一个套接字中.
  1. #include<sys/socket.h>
  2. int bind(int sockfd,const struct sockaddr*myaddr,socklen_t addrlen);
  3. //成功返回0.出错返回-1


LIsten函数
(1)listen函数只由tcp服务端调用
当socket创建一个套接字的时候.被假设为一个主动套接子.listen则把一个为未连接的套接字转为一个被动套接字.指示内核应该接受该套接字的连接请求
(2)此函数第2个参数规定了内核应该为相应套接字排队的最大连接个数
  1. #include<sys/socket.h>
  2. int listen(int sockfd,int backlog);
  3. 返回:成功返回0.失败返回-1
内核为任何一个给定的监听套接字维护2个队列
(1) 未完成连接队列(syn_recd)(2).已完成队列(处于established)
二者连接之和不超过backlog
在三路握手正常完成的前提下.未完成连接队列中的任何一项在其中停留时间为RTT
一个客户SYN到达时,如果这些队列是满的,tcp就会忽略该分节,也就不是不会发送RST,客户端TCP将会重发SYN,期待不就将来可以在这些队列找到可用队列



accept函数
由tcp服务器调用,用于从已完成连接队列队头返回下一个已完成连接,如果连接队列为空,进程将被休眠
  1. #include<sys/socket.h>
  2. int accept(int sockfd,struct sockaddr*cliaddr,socklen_t *addrlen);
  3. 返回:若成功返回非负描述符,若出错则为-1

 close函数
把一个tcp套接字标记为已关闭.返回到调用进程.该套接字描述符不能再由调用进程使用.
不过如果父进程fork了一个子进程.即使子进程close套接字描述符,子进程不能再读写该套接字描述符.
但父进程依旧可以读写该被子进程关闭的套接字,原因:文件表的引用计数.

以上是基于TCP/IP的套接字函数调用过程


getsockname跟getpeername函数
前一个番号跟某个套接字关联的本地套接字结构.后一个番号跟某个套接字的对端套接字结构














 

unix网络编程第四章----基于TCP套接字编程的更多相关文章

  1. 【UNIX网络编程(四)】TCP套接字编程具体分析

    引言: 套接字编程事实上跟进程间通信有一定的相似性,可能也正由于此.stevens这位大神才会将套接字编程与进程间的通信都归为"网络编程",并分别写成了两本书<UNP1> ...

  2. UNP学习笔记(第四章 基本TCP套接字编程)

    本章讲解编写一个完整的TCP客户/服务器程序所需要的基本套接字函数. socket函数 #include <sys/socket.h> int socket(int family,int ...

  3. 第四章 基本TCP套接字编程 第五章 TCP客户/服务器程序实例

    TCP客户与服务器进程之间发生的重大事件时间表 TCP服务器 socket() --- bind() --- listen() --- accept() --- read() --- write -- ...

  4. UNP——第四章,TCP套接字编程

    1.socket 函数 首先被调用的函数,用于选择通信协议. socket调用成功后,得到的套接字为主动套接字CLOSED状态. PF 和 AF 的关系 PF的是协议族,AF是地址族,理论上一个PF包 ...

  5. UNIX网络编程 第4章 基本TCP套接字编程

    本章的几个函数在很大程度上展示了面向对象与面向过程的不同之处.

  6. 套接字编程相关函数(2:TCP套接字编程相关函数)

    本文摘录自<UNIX网络编程 卷1>. 基本套接字函数 socket函数 为了执行网络I/O,一个进程必须做的第一件事就是调用socket函数,指定期望的通信协议类型.其定义如下: #in ...

  7. UNIX网络编程 第8章 基本UDP套接字编程

    UDP是无连接的,不需要accept,TCP通过accept API来接受连接,并且将连接客户端的信息写入到accept将返回的新socket中,该新socket中有服务端和客户端的IP地址和端口,因 ...

  8. TCP套接字编程模型及实例

    摘要:     本文讲述了TCP套接字编程模块,包括服务器端的创建套接字.绑定.监听.接受.读/写.终止连接,客户端的创建套接字.连接.读/写.终止连接.先给出实例,进而结合代码分析. PS:本文权当 ...

  9. UNP学习笔记1——基本TCP套接字编程

    1 套接字地址结构 大多数套接字函数都需要一个指向套接字地址结构的指针作为参数.每个协议族都定义了自己的套接字结构.这些套接字的结构以sockaddr_开头,以每个协议族唯一的后缀名结尾. 1.1 I ...

随机推荐

  1. Java微信公众号开发----定时获取access_token并保存到redis中

    本人原本是想做微信公众号菜单的创建修改删除等操作的,但是发现需要access_token,通过阅读文档,发现文档要求有以下几点: 1.access_token 获取后有效期是2小时 2.access_ ...

  2. 对O(logN)复杂度的推导

    之前一直对O(logN)这个复杂度如何推导出的存在疑问,这段时间看了一些算法相关的内容,正好看到这个问题,大略研究了一下算是基本解答了我的疑惑:现记录如下 假设有一棵高为H的满二叉树,则它的节点共有N ...

  3. Ubuntu下kaldi安装

    该文章为博主原创,如若转载请注明出处:https://www.cnblogs.com/fengleixue/p/9482202.html 因公司业务需要需使用kaldi语音识别工具,现将kaldi环境 ...

  4. 【Kafka】搭建和测试等问题

    1.安装启动kafka #跳转到下载目录cd /opt/setup # 下载安装包 wget http://mirror.bit.edu.cn/apache/kafka/0.10.2.0/kafka_ ...

  5. 【markdown】图片的处理

    1st: ![tip](link) 2ed: ![tip][id] [id]:base64string 本地图片 先把本地图片文件转换成base64位编码 然后把 link 替换成生成的base64编 ...

  6. 一键生成属于自己的QQ历史报告,看看你对自己的QQ了解程度有多深?

    目录 一键生成属于自己的QQ历史报告,看看你对自己的QQ了解程度有多深? 简介 功能截图 如何运行 编写思路 main.py模块 qq_bot模块 tkinter_gui模块 static_data模 ...

  7. 【HIHOCODER 1142】 三分·三分求极值

    描述 这一次我们就简单一点了,题目在此: 在直角坐标系中有一条抛物线y=ax^2+bx+c和一个点P(x,y),求点P到抛物线的最短距离d. 输入 第1行:5个整数a,b,c,x,y.前三个数构成抛物 ...

  8. CodeForces:148D-D.Bag of mice

    Bag of mice time limit per test 2 seconds memory limit per test 256 megabytes Program Description Th ...

  9. debian卸载vmware

    原因: 由于vagrant默认支持virtualbox,而要支持vmware需要一个商用付费的插件.所以卸载vmware,使用virtualbox 具体操作: $ sudo vmware-instal ...

  10. Linux系统监视工具

    转自      http://bbs.51cto.com/thread-971896-1.html # 1: top – 查看活动进程的命令TOP工具能够实时显示系统中各个进程的资源占用状况.默认情况 ...