@514labs/moose-lib 0.6.267-ci-18-gee943af4 → 0.6.267-ci-2-g633afb84

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -501,6 +501,7 @@ async function getTemporalClient(temporalUrl, namespace, clientCert, clientKey,
501
501
 
502
502
  // src/consumption-apis/runner.ts
503
503
  var import_http2 = __toESM(require("http"));
504
+ var import_node_cluster2 = __toESM(require("cluster"));
504
505
  init_commons();
505
506
  var jose = __toESM(require("jose"));
506
507
 
@@ -993,6 +994,10 @@ var runApis = async (config) => {
993
994
  console.log("Importing JWT public key...");
994
995
  publicKey = await jose.importSPKI(config.jwtConfig.secret, "RS256");
995
996
  }
997
+ const port = config.proxyPort !== void 0 ? config.proxyPort : 4001;
998
+ console.log(
999
+ `[DEBUG] Worker ${import_node_cluster2.default.worker?.id} about to create server on port ${port}`
1000
+ );
996
1001
  const server = import_http2.default.createServer(
997
1002
  await createMainRouter(
998
1003
  publicKey,
@@ -1004,11 +1009,38 @@ var runApis = async (config) => {
1004
1009
  config.jwtConfig
1005
1010
  )
1006
1011
  );
1007
- const port = config.proxyPort !== void 0 ? config.proxyPort : 4001;
1008
- server.listen(port, "localhost", () => {
1009
- console.log(`Server running on port ${port}`);
1012
+ console.log(
1013
+ `[DEBUG] Worker ${import_node_cluster2.default.worker?.id} server created, about to listen on port ${port}`
1014
+ );
1015
+ server.on("error", (err) => {
1016
+ console.error(
1017
+ `[ERROR] Worker ${import_node_cluster2.default.worker?.id} server error on port ${port}:`,
1018
+ err
1019
+ );
1020
+ if (err.code === "EADDRINUSE") {
1021
+ console.error(`[ERROR] Port ${port} is already in use`);
1022
+ }
1023
+ });
1024
+ return new Promise((resolve2, reject) => {
1025
+ server.listen(port, "localhost", () => {
1026
+ console.log(
1027
+ `[SUCCESS] Worker ${import_node_cluster2.default.worker?.id} server running on port ${port}`
1028
+ );
1029
+ resolve2(server);
1030
+ });
1031
+ const timeout = setTimeout(() => {
1032
+ console.error(
1033
+ `[ERROR] Worker ${import_node_cluster2.default.worker?.id} listen timeout after 10s on port ${port}`
1034
+ );
1035
+ reject(new Error(`Listen timeout on port ${port}`));
1036
+ }, 1e4);
1037
+ server.once("listening", () => {
1038
+ clearTimeout(timeout);
1039
+ console.log(
1040
+ `[DEBUG] Worker ${import_node_cluster2.default.worker?.id} 'listening' event fired for port ${port}`
1041
+ );
1042
+ });
1010
1043
  });
1011
- return server;
1012
1044
  },
1013
1045
  workerStop: async (server) => {
1014
1046
  return new Promise((resolve2) => {
@@ -2323,7 +2355,7 @@ var runStreamingFunctions = async (args) => {
2323
2355
  validateTopicConfig(args.targetTopic);
2324
2356
  }
2325
2357
  const streamingFuncId = `flow-${args.sourceTopic.name}-${args.targetTopic?.name || ""}`;
2326
- const cluster2 = new Cluster({
2358
+ const cluster3 = new Cluster({
2327
2359
  maxCpuUsageRatio: 0.5,
2328
2360
  maxWorkerCount: args.maxSubscriberCount,
2329
2361
  workerStart: async (worker, parallelism) => {
@@ -2406,7 +2438,7 @@ var runStreamingFunctions = async (args) => {
2406
2438
  logger2.log("Graceful shutdown completed");
2407
2439
  }
2408
2440
  });
2409
- cluster2.start();
2441
+ cluster3.start();
2410
2442
  };
2411
2443
 
2412
2444
  // src/moduleExportSerializer.ts