mirror of https://github.com/F-Stack/f-stack.git
Example: keep run when accept failed.
This commit is contained in:
parent
f17ba62bb6
commit
c7fe235229
|
@ -1,6 +1,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
#include <string.h>
|
||||||
#include <strings.h>
|
#include <strings.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
#include <sys/socket.h>
|
#include <sys/socket.h>
|
||||||
|
@ -72,8 +73,10 @@ int loop(void *arg)
|
||||||
//printf("A client has left the server...,fd:%d\n", clientfd);
|
//printf("A client has left the server...,fd:%d\n", clientfd);
|
||||||
} else if (clientfd == sockfd) {
|
} else if (clientfd == sockfd) {
|
||||||
int nclientfd = ff_accept(sockfd, NULL, NULL);
|
int nclientfd = ff_accept(sockfd, NULL, NULL);
|
||||||
|
if (nclientfd < 0) {
|
||||||
assert(nclientfd > 0);
|
printf("ff_accept failed:%d, %s\n", errno, strerror(errno));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* Add to event list */
|
/* Add to event list */
|
||||||
kevSet.data = 0;
|
kevSet.data = 0;
|
||||||
|
@ -145,5 +148,3 @@ int main(int argc, char * argv[])
|
||||||
ff_run(loop, NULL);
|
ff_run(loop, NULL);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -62,35 +62,39 @@ int loop(void *arg)
|
||||||
int nevents = ff_epoll_wait(epfd, events, MAX_EVENTS, 0);
|
int nevents = ff_epoll_wait(epfd, events, MAX_EVENTS, 0);
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < nevents; ++i) {
|
for (i = 0; i < nevents; ++i) {
|
||||||
/* Handle new connect */
|
/* Handle new connect */
|
||||||
if (events[i].data.fd == sockfd) {
|
if (events[i].data.fd == sockfd) {
|
||||||
int nclientfd = ff_accept(sockfd, NULL, NULL);
|
int nclientfd = ff_accept(sockfd, NULL, NULL);
|
||||||
assert(nclientfd > 0);
|
if (nclientfd < 0) {
|
||||||
|
printf("ff_accept failed:%d, %s\n", errno, strerror(errno));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
/* Add to event list */
|
/* Add to event list */
|
||||||
ev.data.fd = nclientfd;
|
ev.data.fd = nclientfd;
|
||||||
ev.events = EPOLLIN;
|
ev.events = EPOLLIN;
|
||||||
assert(ff_epoll_ctl(epfd, EPOLL_CTL_ADD, nclientfd, &ev) == 0);
|
assert(ff_epoll_ctl(epfd, EPOLL_CTL_ADD, nclientfd, &ev) == 0);
|
||||||
//fprintf(stderr, "A new client connected to the server..., fd:%d\n", nclientfd);
|
//printf("A new client connected to the server..., fd:%d\n", nclientfd);
|
||||||
} else {
|
} else {
|
||||||
if (events[i].events & EPOLLERR ) {
|
if (events[i].events & EPOLLERR ) {
|
||||||
/* Simply close socket */
|
/* Simply close socket */
|
||||||
ff_epoll_ctl(epfd, EPOLL_CTL_DEL, events[i].data.fd, NULL);
|
ff_epoll_ctl(epfd, EPOLL_CTL_DEL, events[i].data.fd, NULL);
|
||||||
ff_close(events[i].data.fd);
|
ff_close(events[i].data.fd);
|
||||||
//fprintf(stderr, "A client has left the server...,fd:%d\n", events[i].data.fd);
|
//printf("A client has left the server...,fd:%d\n", events[i].data.fd);
|
||||||
} else if (events[i].events & EPOLLIN) {
|
} else if (events[i].events & EPOLLIN) {
|
||||||
char buf[256];
|
char buf[256];
|
||||||
size_t readlen = ff_read( events[i].data.fd, buf, sizeof(buf));
|
size_t readlen = ff_read( events[i].data.fd, buf, sizeof(buf));
|
||||||
//fprintf(stderr, "bytes are available to read..., readlen:%d, fd:%d\n", readlen, events[i].data.fd);
|
//printf("bytes are available to read..., readlen:%d, fd:%d\n", readlen, events[i].data.fd);
|
||||||
if(readlen > 0){
|
if(readlen > 0) {
|
||||||
ff_write( events[i].data.fd, html, sizeof(html));
|
ff_write( events[i].data.fd, html, sizeof(html));
|
||||||
} else {
|
} else {
|
||||||
ff_epoll_ctl(epfd, EPOLL_CTL_DEL, events[i].data.fd, NULL);
|
ff_epoll_ctl(epfd, EPOLL_CTL_DEL, events[i].data.fd, NULL);
|
||||||
ff_close( events[i].data.fd);
|
ff_close( events[i].data.fd);
|
||||||
//fprintf(stderr, "A client has left the server...,fd:%d\n", events[i].data.fd);
|
//printf("A client has left the server...,fd:%d\n", events[i].data.fd);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "unknown event: %8.8X\n", events[i].events);
|
printf("unknown event: %8.8X\n", events[i].events);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -127,7 +131,7 @@ int main(int argc, char * argv[])
|
||||||
printf("ff_listen failed\n");
|
printf("ff_listen failed\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
assert((epfd = ff_epoll_create(0)) > 0);
|
assert((epfd = ff_epoll_create(0)) > 0);
|
||||||
ev.data.fd = sockfd;
|
ev.data.fd = sockfd;
|
||||||
ev.events = EPOLLIN;
|
ev.events = EPOLLIN;
|
||||||
|
@ -135,5 +139,3 @@ int main(int argc, char * argv[])
|
||||||
ff_run(loop, NULL);
|
ff_run(loop, NULL);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue