multi-acceptor-processes.c 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /*
  2. *
  3. * @build make examples
  4. * @server bin/multi-acceptor-processes 1234
  5. * @client bin/nc 127.0.0.1 1234
  6. * nc 127.0.0.1 1234
  7. * telnet 127.0.0.1 1234
  8. */
  9. #include "hloop.h"
  10. #include "hsocket.h"
  11. #include "hthread.h"
  12. #include "hproc.h"
  13. static const char* host = "0.0.0.0";
  14. static int port = 1234;
  15. static int process_num = 4;
  16. static void on_close(hio_t* io) {
  17. printf("on_close fd=%d error=%d\n", hio_fd(io), hio_error(io));
  18. }
  19. static void on_recv(hio_t* io, void* buf, int readbytes) {
  20. // echo
  21. hio_write(io, buf, readbytes);
  22. }
  23. static void on_accept(hio_t* io) {
  24. char localaddrstr[SOCKADDR_STRLEN] = {0};
  25. char peeraddrstr[SOCKADDR_STRLEN] = {0};
  26. printf("pid=%ld connfd=%d [%s] <= [%s]\n",
  27. (long)hv_getpid(),
  28. (int)hio_fd(io),
  29. SOCKADDR_STR(hio_localaddr(io), localaddrstr),
  30. SOCKADDR_STR(hio_peeraddr(io), peeraddrstr));
  31. hio_setcb_close(io, on_close);
  32. hio_setcb_read(io, on_recv);
  33. hio_read(io);
  34. }
  35. static void loop_proc(void* userdata) {
  36. int listenfd = (int)(intptr_t)(userdata);
  37. hloop_t* loop = hloop_new(HLOOP_FLAG_AUTO_FREE);
  38. haccept(loop, listenfd, on_accept);
  39. hloop_run(loop);
  40. }
  41. int main(int argc, char** argv) {
  42. if (argc < 2) {
  43. printf("Usage: cmd port\n");
  44. return -10;
  45. }
  46. port = atoi(argv[1]);
  47. int listenfd = Listen(port, host);
  48. if (listenfd < 0) {
  49. exit(1);
  50. }
  51. proc_ctx_t ctx;
  52. memset(&ctx, 0, sizeof(ctx));
  53. ctx.proc = loop_proc;
  54. ctx.proc_userdata = (void*)(intptr_t)listenfd;
  55. for (int i = 0; i < process_num; ++i) {
  56. hproc_spawn(&ctx);
  57. }
  58. while(1) hv_sleep(1);
  59. return 0;
  60. }