Linux_ 多进程并发服务TCP
来源:互联网 发布:js断点调试debugger 编辑:程序博客网 时间:2024/05/22 13:21
client1.c
#include <sys/types.h>#include <sys/socket.h>#include <sys/stat.h>#include <sys/un.h>#include <netinet/in.h>#include <arpa/inet.h>#include <fcntl.h>#include <stdlib.h>#include <stdio.h>#include <errno.h>#include <signal.h>#define BUFF_SIZE 1024int main(void){ int sockfd; struct sockaddr_in server_addr, client_addr; int ret; int pd; char buff[BUFF_SIZE]; sockfd = socket (AF_INET, SOCK_STREAM, 0); server_addr.sin_addr.s_addr = inet_addr("10.10.0.9"); server_addr.sin_family = AF_INET; server_addr.sin_port = htons(9000); ret = connect(sockfd, (struct sockaddr*)&server_addr, sizeof(server_addr)); if (ret == -1) { perror("connect"); exit(errno); } sprintf(buff, "process(%u) send msg", getpid()); ret = write(sockfd, buff, strlen(buff)+1); if (ret == -1) { perror("client write"); exit(errno); } ret = read(sockfd, buff, sizeof(buff)); if (ret == -1) { perror("client read"); exit(errno); } printf("received: %s\n", buff); exit(0);}
server1.c
#include <sys/types.h>#include <sys/socket.h>#include <sys/stat.h>#include <sys/un.h>#include <netinet/in.h>#include <arpa/inet.h>#include <fcntl.h>#include <stdlib.h>#include <stdio.h>#include <errno.h>#include <signal.h>#define BUFF_SIZE 1024void handle_sigchld(int sig){ printf("catch a sig(%d)\n", sig); wait(NULL);}static void str2up(char *p){ while (*p) { if (*p >= 'a' && *p <= 'z') { *p = *p - 'a' + 'A'; } p++; }}int main(void){ int sockfd, clientfd; struct sockaddr_in server_addr, client_addr; int ret; int pd; char buff[BUFF_SIZE]; //socklen_t len = sizeof(struct sockaddr_in); socklen_t len= sizeof(struct sockaddr); sockfd = socket (AF_INET, SOCK_STREAM, 0); server_addr.sin_addr.s_addr = htons(INADDR_ANY); server_addr.sin_family = AF_INET; server_addr.sin_port = htons(9000); ret = bind(sockfd, (struct sockaddr*)&server_addr, sizeof(server_addr)); if (ret == -1) { perror("bind"); exit(errno); } ret = listen(sockfd, 5); if (ret == -1) { perror("listen"); exit(errno); } signal(SIGCHLD, handle_sigchld); while (1) { clientfd = accept(sockfd, (struct sockaddr*)&server_addr, &len); if (clientfd == -1) { perror("accept"); exit(errno); } printf("clientfd=%d\n", clientfd); pd = fork(); if (pd == -1) { perror("fork"); exit(errno); } else if (pd == 0) { close(sockfd); ret = read(clientfd, buff, sizeof(buff)); printf("Process(%d),ret=%d, received: %s\n", getpid(), ret, buff); str2up(buff); ret = write(clientfd, buff, strlen(buff)+1); printf("ret=%d\n", ret); close(clientfd); exit(0); } } exit(0);}
0 0
- Linux_ 多进程并发服务TCP
- TCP多进程并发编程-回射服务/客户程序
- tcp多进程并发服务器
- TCP多进程并发服务器
- linux_服务
- linux_进程
- Linux TCP多进程并发服务器
- 9.3tcp多进程并发模板和多线程并发模板
- 9.3tcp多进程并发模板和多线程并发模板
- linux多进程并发服务模型
- Linux_入门之进程和系统服务的控制
- TCP并发服务器之进程
- 实现TCP并发服务器之一(多进程)
- Linux_系统服务
- linux_守护进程
- Linux_系统进程管理
- linux_进程线程通信
- Linux_ fork 进程操作
- LeetCode 121, 122, 123. Best Time to Buy and Sell Stock i, ii, iii
- 【设计模式】中介者模式
- 挨踢职场求生法则-----我在IT职场打滚超过15年了,从小小的程序员做到常务副总
- 比较无线技术:Zigbee/蓝牙/WI-FI
- Photon Server的使用(一)
- Linux_ 多进程并发服务TCP
- 1042. 字符统计(20)
- javascript----Array之Sort()
- 【设计模式】观察者模式
- 详解Harris角点检测及代码实现
- 倒序访问list
- 正则表达式 初探
- 针对于HttpComponet的功能资料
- 楼梯有n阶台阶,上楼可以一步上1阶,2阶,3阶,编程序计算共有多少种不同的走法?