1. 什么是TCP/IP、UDP?
2. Socket在哪里呢?
3. Socket是什么呢?
4. 有很多的框架,为什么还在从Socket开始?
5. Linux C Socket简单示例
1.什么是TCP/IP、UDP?
TCP/IP(Transmission Control Protocol/Internet Protocol)即传输控制协议/网间协议,是一个工业标准的协议集,它是为广域网(WANs)设计的。
UDP(User Data Protocol,用户数据报协议)是与TCP相对应的协议。它是属于TCP/IP协议族中的一种。
下面的图表明了这些协议的关系。
2.Socket在哪里呢?
3.Socket是什么呢?
Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来说,一组简单的接口就是全部,让Socket去组织数据,以符合指定的协议。
门面模式,用自己的话说,就是系统对外界提供单一的接口,外部不需要了解内部的实现。
4.有很多的框架,为什么还在从Socket开始?
现在的跨平台网络编程框架很多,如Java的SSH,C/C++的Boost等。
现在的分布式框架很多,如Hadoop等。
我的任务是把一个C/C++程序做成分布式,要求的不配环境,基本属于纯计算的,结果很小。所以选择了Socket。
重要的是Socket是分布式、云计算、网络编程的基础,对Socket的学习有利于对其他框架的理解。
下图是Socket编程的基本流程:
5.Linux C Socket简单实例与详细注释
程序为简单的“回射”,客户端将控制台输入的信息发送给服务器端,服务器原样返回信息。
服务器端:
1 #include <sys/types.h>
2 #include <sys/socket.h>
3 #include <stdio.h>
4 #include <netinet/in.h>
5 #include <arpa/inet.h>
6 #include <unistd.h>
7 #include <string.h>
8 #include <stdlib.h>
9 #include <fcntl.h>
10 #include <sys/shm.h>
11
12 #define MYPORT 8887
13 #define QUEUE 20
14 #define BUFFER_SIZE 1024
15
16 int main()
17 {
18 ///定义sockfd
19 int server_sockfd = socket(AF_INET,SOCK_STREAM, 0);
20
21 ///定义sockaddr_in
22 struct sockaddr_in server_sockaddr;
23 server_sockaddr.sin_family = AF_INET;
24 server_sockaddr.sin_port = htons(MYPORT);
25 server_sockaddr.sin_addr.s_addr = htonl(INADDR_ANY);
26
27 ///bind,成功返回0,出错返回-1
28 if(bind(server_sockfd,(struct sockaddr *)&server_sockaddr,sizeof(server_sockaddr))==-1)
29 {
30 perror("bind");
31 exit(1);
32 }
33
34 ///listen,成功返回0,出错返回-1
35 if(listen(server_sockfd,QUEUE) == -1)
36 {
37 perror("listen");
38 exit(1);
39 }
40
41 ///客户端套接字
42 char buffer[BUFFER_SIZE];
43 struct sockaddr_in client_addr;
44 socklen_t length = sizeof(client_addr);
45
46 ///成功返回非负描述字,出错返回-1
47 int conn = accept(server_sockfd, (struct sockaddr*)&client_addr, &length);
48 if(conn<0)
49 {
50 perror("connect");
51 exit(1);
52 }
53
54 while(1)
55 {
56 memset(buffer,0,sizeof(buffer));
57 int len = recv(conn, buffer, sizeof(buffer),0);
58 if(strcmp(buffer,"exit\n")==0)
59 break;
60 fputs(buffer, stdout);
61 send(conn, buffer, len, 0);
62 }
63 close(conn);
64 close(server_sockfd);
65 return 0;
66 }
客户端:
1 #include <sys/types.h>
2 #include <sys/socket.h>
3 #include <stdio.h>
4 #include <netinet/in.h>
5 #include <arpa/inet.h>
6 #include <unistd.h>
7 #include <string.h>
8 #include <stdlib.h>
9 #include <fcntl.h>
10 #include <sys/shm.h>
11
12 #define MYPORT 8887
13 #define BUFFER_SIZE 1024
14
15 int main()
16 {
17 ///定义sockfd
18 int sock_cli = socket(AF_INET,SOCK_STREAM, 0);
19
20 ///定义sockaddr_in
21 struct sockaddr_in servaddr;
22 memset(&servaddr, 0, sizeof(servaddr));
23 servaddr.sin_family = AF_INET;
24 servaddr.sin_port = htons(MYPORT); ///服务器端口
25 servaddr.sin_addr.s_addr = inet_addr("127.0.0.1"); ///服务器ip
26
27 ///连接服务器,成功返回0,错误返回-1
28 if (connect(sock_cli, (struct sockaddr *)&servaddr, sizeof(servaddr)) < 0)
29 {
30 perror("connect");
31 exit(1);
32 }
33
34 char sendbuf[BUFFER_SIZE];
35 char recvbuf[BUFFER_SIZE];
36 while (fgets(sendbuf, sizeof(sendbuf), stdin) != NULL)
37 {
38 send(sock_cli, sendbuf, strlen(sendbuf),0); ///发送
39 if(strcmp(sendbuf,"exit\n")==0)
40 break;
41 recv(sock_cli, recvbuf, sizeof(recvbuf),0); ///接收
42 fputs(recvbuf, stdout);
43
44 memset(sendbuf, 0, sizeof(sendbuf));
45 memset(recvbuf, 0, sizeof(recvbuf));
46 }
47
48 close(sock_cli);
49 return 0;
50 }
执行:
客户端
服务器端