c语言tcp心跳程序,c语言多进程tcp服务器示例

#include "server.h"

/*

* Create a TCP Server

* Return socketfd

*/

int create_tcpsvr(char *ip,int port)

{

int sockfd;

struct sockaddr_in addr;

if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == EOF){

perror("create_tcpsvr(),socket()");

exit(EXIT_FAILURE);

}

fill_sockaddr(&addr,ip,port);

if (bind(sockfd, (struct sockaddr *)&addr, sizeof(addr)) == EOF){

perror("create_tcpsvr(),bind()");

exit(EXIT_FAILURE);

}

if (listen(sockfd,LISTENTQ) == EOF) {

perror("create_tcpsvr(),bind()");

exit(EXIT_FAILURE);

}

return sockfd;

}

/**

* Set TCP server's address

*/

void fill_sockaddr(struct sockaddr_in *addr, char *ip, int port)

{

assert(addr);

addr -> sin_family = AF_INET;

addr -> sin_port = htons(port?port:DEF_PORT);

if (ip == NULL) {

addr -> sin_addr.s_addr = htonl(INADDR_ANY);

} else if((addr -> sin_addr.s_addr = inet_addr(ip)) == EOF) {

perror("fill_sockaddr(),inet_addr()");

exit(EXIT_FAILURE);

}

}

/*

* Communicate to client

*/

void comm_to_clt(int listenfd)

{

printf("TCP SERVER IS WAITING!\n");

struct epoll_event events[MAX_EPOLL_SIZE];

int fd_num;

int epollfd = init_epoll(listenfd);

while (1) {

fd_num = epoll_wait(epollfd,events,MAX_EPOLL_SIZE,-1);

if (fd_num == EOF) {

perror("comm_to_clt(),epoll_wait()");

continue;

}

while (--fd_num >= 0) {

epoll_business(epollfd, listenfd, events[fd_num]);

}

}

}

/*

* Initlization epoll

*/

int init_epoll(int listenfd)

{

struct epoll_event ev;

int epollfd;

if((epollfd = epoll_create(MAX_EPOLL_SIZE)) == EOF) {

perror("init_epoll(),epoll_create()");

exit(EXIT_FAILURE);

}

ev.events = EPOLLIN;

ev.data.fd = listenfd;

if (epoll_ctl(epollfd, EPOLL_CTL_ADD,listenfd, &ev)) {

perror("init_epoll(),epoll_ctl()");

exit(EXIT_FAILURE);

}

return epollfd;

}

/*

* Respond for io change

*/

void epoll_business(int epollfd, int listenfd, struct epoll_event ev)

{

struct epoll_event ev_n;

if (ev.data.fd == listenfd) {

int clt_fd = accept(listenfd, 0, 0);

if (clt_fd == EOF) {

perror("epoll_business(), accept()");

return;

}

fcntl(clt_fd, F_SETFL, O_NONBLOCK);

ev_n.events = EPOLLIN|EPOLLET;

ev_n.data.fd = clt_fd;

if (epoll_ctl(epollfd,EPOLL_CTL_ADD, clt_fd, &ev_n) == EOF) {

perror("epoll_business(), epoll_ctl()");

return;

}

}else {

main_service(ev.data.fd);

if (epoll_ctl(epollfd,EPOLL_CTL_DEL, ev.data.fd, &ev) == EOF) {

perror("epoll_business(), epoll_ctl()");

}

close(ev.data.fd);

}

}

/*

* Create some process

*/

void create_process(int sockfd, int i)

{

/*

* Avoid zombie process

*/

signal(SIGCHLD,SIG_IGN);

while (i--) {

if (fork() == 0) {

comm_to_clt(sockfd);

}

}

while(1){

sleep(100);

}

}

int main(int argc, char *argv[])

{

int sockfd = create_tcpsvr(0, 0);

create_process(sockfd,DEF_PROCESS_NUM);

exit(EXIT_SUCCESS);

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的TCP多进程创建代码示例: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #define PORT 8888 int main(void) { int sockfd, newsockfd, pid; struct sockaddr_in addr; socklen_t addrlen = sizeof(addr); char buffer[256]; sockfd = socket(AF_INET, SOCK_STREAM, 0); if (sockfd < 0) { perror("ERROR opening socket"); exit(1); } memset(&addr, 0, sizeof(addr)); addr.sin_family = AF_INET; addr.sin_addr.s_addr = INADDR_ANY; addr.sin_port = htons(PORT); if (bind(sockfd, (struct sockaddr *) &addr, sizeof(addr)) < 0) { perror("ERROR on binding"); exit(1); } listen(sockfd, 5); while (1) { newsockfd = accept(sockfd, (struct sockaddr *) &addr, &addrlen); if (newsockfd < 0) { perror("ERROR on accept"); exit(1); } pid = fork(); if (pid < 0) { perror("ERROR on fork"); exit(1); } if (pid == 0) { close(sockfd); memset(buffer, 0, sizeof(buffer)); if (read(newsockfd, buffer, sizeof(buffer)) < 0) { perror("ERROR reading from socket"); exit(1); } printf("Here is the message: %s\n", buffer); if (write(newsockfd, "I got your message", 18) < 0) { perror("ERROR writing to socket"); exit(1); } exit(0); } else { close(newsockfd); } } close(sockfd); return 0; } ``` 该代码创建了一个TCP服务器,通过多进程实现并发处理多个客户端请求。主进程负责监听客户端连接请求,并通过fork()函数创建一个子进程来处理客户端请求。子进程负责与客户端通信,读取客户端发送的消息并回复一个固定的消息。 在主循环中,每当有新的客户端连接请求被接受,就会创建一个子进程来处理该请求。子进程通过关闭sockfd来避免竞争条件,并在处理完请求后通过exit(0)退出。父进程则关闭newsockfd,继续监听新的客户端连接请求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值