linux socket 连接步骤
a、int socket(int domain, //协议族,协议族决定了socket的地址类型(格式)
int type, //socket类型
int protocol //通信协议(TCP/IP,UDP等)
)
注意: ①并不是上面的type和protocol可以随意组合的,如SOCK_STREAM不可以跟IPPROTO_UDP组合。
当protocol为0时,会自动选择type类型对应的默认协议。
②socket()用于创建一个socket描述符(socket descriptor),它唯一标识一个socket。
这个socket描述字跟文件描述字一样,后续的操作都有用到它,把它作为参数
b、int bind(int sockfd, //sockfd:即socket描述字,它是通过socket()函数创建了,唯一标识一个socket
const struct sockaddr *addr, //指向要绑定给sockfd的协议地址。这个地址结构根据地址创建socket时的地址协议族的不同而不同
socklen_t addrlen //对应的是地址的长度
)——服务端的socket描述字
注意: ①作为客户端,不用调用此函数。有系统自动分配一个端口号和自身的ip地址组合。
这就是为什么通常服务器端在listen之前会调用bind(),而客户端就不会调用,
而是在connect()时由系统随机生成一个。
c、listen()——服务端的socket描述字
connect()——客户端的socket描述字
int listen(int sockfd, int backlog);
int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
listen函数的第一个参数即为要监听的socket描述字,第二个参数为相应socket可以排队的最大连接个数。
socket()函数创建的socket默认是一个主动类型的,listen函数将socket变为被动类型的,
等待客户的连接请求。
connect函数的第一个参数即为客户端的socket描述字,第二参数为服务器的socket地址,
第三个参数为socket地址的长度。客户端通过调用connect函数来建立与TCP服务器的连接。
d、int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
——服务端的socket描述字
注意: ①TCP服务器端依次调用socket()、bind()、listen()之后,就会监听指定的socket地址了。
TCP客户端依次调用socket()、connect()之后就想TCP服务器发送了一个连接请求。
TCP服务器监听到这个请求之后,就会调用accept()函数取接收请求,这样连接就建立好了。
之后就可以开始网络I/O操作了,即类同于普通文件的读写I/O操作。
②accept函数的第一个参数为服务器的socket描述字,
第二个参数为指向struct sockaddr *的指针,用于返回客户端的协议地址,
第三个参数为协议地址的长度。如果accpet成功,那么其返回值是由内核自动生成的一个全新的描述字,
代表与返回客户的TCP连接。
③accept的第一个参数为服务器的socket描述字,是服务器开始调用socket()函数生成的,
称为监听socket描述字;而accept函数返回的是已连接的socket描述字。
一个服务器通常通常仅仅只创建一个监听socket描述字,它在该服务器的生命周期内一直存在。
内核为每个由服务器进程接受的客户连接创建了一个已连接socket描述字,
当服务器完成了对某个客户的服务,相应的已连接socket描述字就被关闭。
e、read()、write()等函数
ssize_t read(int fd, void *buf, size_t count);
ssize_t write(int fd, const void *buf, size_t count);
read函数是负责从fd中读取内容.当读成功时,read返回实际所读的字节数,
如果返回的值是0表示已经读到文件的结束了,小于0表示出现了错误。
如果错误为EINTR说明读是由中断引起的,如果是ECONNREST表示网络连接出了问题。
write函数将buf中的nbytes字节内容写入文件描述符fd.成功时返回写的字节数。
失败时返回-1,并设置errno变量。 在网络程序中,当我们向套接字文件描述符写时有俩种可能。
1)write的返回值大于0,表示写了部分或者是全部的数据。
2)返回的值小于0,此时出现了错误。我们要根据错误类型来处理。
如果错误为EINTR表示在写的时候出现了中断错误。
如果为EPIPE表示网络连接出现了问题(对方已经关闭了连接)。
f、close()
int close(int fd);
close一个TCP socket的缺省行为时把该socket标记为以关闭,然后立即返回到调用进程。
该描述字不能再由调用进程使用,也就是说不能再作为read或write的第一个参数。
注意:close操作只是使相应socket描述字的引用计数-1,只有当引用计数为0的时候,
才会触发TCP客户端向服务器发送终止连接请求。
(参考吴秦相关技术文章)
分享到:
相关推荐
实战Linux Socket编程,主要讲述Linux系统下socket通信编程过程以及相关实践
实战Linux Socket编程_2-1 Socket编程新手使用
实战 linux socket 编程 pdf格式
实战Linux Socket 编程-示例源码,加深你对Linux-socket编程的理解!
资源名称:实战Linux Socket编程资源截图: 资源太大,传百度网盘了,链接在附件中,有需要的同学自取。
实战Linux Socket 编程.rar linux网络编程
Linux socket编程 PDF 清晰文字版 非扫描 清晰中文版本(附录一 简明SOCKET编程指南.[pdf)
实战Linux Socket编程及书内源代码
Linuxsocket编程入门[参照].pdf
实战Linux socket编程Linux Socket Programming By Example完整配套源代码,网上尚无完整的源代码。都已通过调试,特与大家分享!!!
实战Linux Socket 编程源代码 可以作为学习Socket编程的样例 11章为多客户端。
详细讲述TCP的server端和client端socket
Linux socket编程原理 有详细的原型 一个通用的网络程序接口,它向上层提供几个简单的函数,程序设计者只要使用 这几个函数就可以完成绝大多数情况下的网络数据传输。这些函数将 socket 编程和上层隔离开来,它 使用...
实战Linux+Socket编程.pdf
本人学习《实战 Linux Socket编程》练习的代码
由于前段时间在网上买了本实战Linux Socket 编程 突然发现网上很多人都没有这个例子代码 希望能分享这些例子代码
writing linux net programming!