cluster.js 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. import cluster from "cluster";
  2. import os from "os";
  3. import { setupMaster, setupWorker } from "@socket.io/sticky";
  4. import { createAdapter, setupPrimary } from "@socket.io/cluster-adapter";
  5. import { io } from "./io.js";
  6. import http from "http";
  7. import { Server } from "socket.io";
  8. import { controller } from "../controller/index.js";
  9. import { logger } from "../core/logger.js";
  10. const numCPUs = os.cpus().length;
  11. export class CoreCluster {
  12. constructor(port) {
  13. this.port = port;
  14. this.attachThead();
  15. }
  16. attachThead() {
  17. if (cluster.isMaster) {
  18. logger.debug("Total Number of Cores:", numCPUs);
  19. logger.debug(`Master ${process.pid} is running`);
  20. // setup sticky sessions
  21. const httpServer = http.createServer();
  22. setupMaster(httpServer, {
  23. loadBalancingMethod: "least-connection",
  24. });
  25. setupPrimary();
  26. cluster.setupPrimary({
  27. serialization: "advanced",
  28. });
  29. httpServer.listen(this.port);
  30. logger.debug(`server is running on port ${this.port}`);
  31. for (let i = 0; i < numCPUs; i++) {
  32. cluster.fork();
  33. }
  34. cluster.on("exit", (worker) => {
  35. logger.debug(`Worker ${worker.process.pid} died`);
  36. cluster.fork();
  37. });
  38. cluster.on("online", (worker) => {
  39. logger.debug("Worker %o is listening", worker.process.pid);
  40. });
  41. } else {
  42. logger.debug(`Worker ${process.pid} started`);
  43. // use the cluster adapter
  44. io.adapter(createAdapter());
  45. io.ready().then(()=>{
  46. controller.run();
  47. // setupWorker(io);
  48. })
  49. setupWorker(io);
  50. // controller.run();
  51. // setup connection with the primary process
  52. }
  53. }
  54. }