LINUX--TCP_server端的编写

1. 解释套接字

套接字:socket = 主机IP + 主机上的进程(端口号)
标识网络中的唯一一个进程
Socket:非常类似于电话插座。以一个国家级电话网为例,电话的通话双方相当于相互通信的2个进程,区号是它的网络地址;区内一个单位的交换机相当于一台主机,主机分配给每个用户的局内号码相当于Socket号。任何用户在通话之前,首先要占有一部电话机,相当于申请一个Socket;同时要知道对方的号码,相当于对方有一个固定的Socket。然后向对方拨号呼叫,相当于发出连接请求(假如对方不在同一区内,还要拨对方区号,相当于给出网络地址)

PS:socket实际上是一个文件描述符,只不过文本描述符走的是io,而socket走的是网络;

2. TCP: 是建立连接的可靠性传输协议

因为TCP需要建立连接,所以在编程时,需要设置套接字为监听,并同时需要多个socket,用于多个用户同时与client端进行通信。而UDP是不需要建立连接,所以不用设置监听,client发来数据直接接收。

3. TCP_server端的监听socket编写

  1. 创建套接字
    int socket(int domain, int type, int protocol)
    返回 :文件描述符
  2. 套接字绑定
    int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen)
  3. 设置为监听套接字
    int listen(int sockfd, int backlog);
  4. 连接确认,创建新的socket用于与用户通信
    int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
struct sockaddr_in{
    sa_family_t  sin_family; //类型,AF_INET
    _be16  sin_port;  //端口号
    struct in_addr sin_addr; //
}
struct sin_addr{
    _be32  s_addr; //IP
}

监听socket的建立:
这里写图片描述

4. TCP_server端在与客户端建立连接:

int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen)
返回一个新的套接字,new_sock用于数据交互;
这里写图片描述

该程序实现简单的客户访问服务器,服务器给客户反馈信息;但只能同时有一个客户端的访问。

5. 可多个用户同时访问的服务器,

要实现多用户可同时访问服务器,可以简单的可以利用进程或线程实现,监听套接字设置没有改变。
1. 多进程下的TCP_server:

当有新链接建立时(accept返回新的sockfd),创建新的子进程,但父进程要等待子进程,所以子进程在关闭了listen_sock后,创建新的子进程就强制退出,子子进程就会变成孤儿进程,在完成通信后系统会处理。
这里写图片描述
这里写图片描述

2. 多线线程下的TCP_server:

当server,client成功建立连接,返回new_sock时,创建新的线程并将new_sock传过去,新线程与进程分离,在客户端退出后,关闭文件描述符(new_sock)。而进程继续等待其他客户的访问。
这里写图片描述
这里写图片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章