@effect/cluster 0.37.1 → 0.38.0

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.
Files changed (142) hide show
  1. package/ClusterCron/package.json +6 -0
  2. package/dist/cjs/ClusterCron.js +86 -0
  3. package/dist/cjs/ClusterCron.js.map +1 -0
  4. package/dist/cjs/ClusterSchema.js +9 -1
  5. package/dist/cjs/ClusterSchema.js.map +1 -1
  6. package/dist/cjs/ClusterWorkflowEngine.js +99 -78
  7. package/dist/cjs/ClusterWorkflowEngine.js.map +1 -1
  8. package/dist/cjs/Entity.js +6 -1
  9. package/dist/cjs/Entity.js.map +1 -1
  10. package/dist/cjs/EntityAddress.js +8 -1
  11. package/dist/cjs/EntityAddress.js.map +1 -1
  12. package/dist/cjs/MessageStorage.js +6 -4
  13. package/dist/cjs/MessageStorage.js.map +1 -1
  14. package/dist/cjs/Runner.js +15 -0
  15. package/dist/cjs/Runner.js.map +1 -1
  16. package/dist/cjs/RunnerAddress.js +8 -1
  17. package/dist/cjs/RunnerAddress.js.map +1 -1
  18. package/dist/cjs/Runners.js +5 -0
  19. package/dist/cjs/Runners.js.map +1 -1
  20. package/dist/cjs/ShardId.js +75 -7
  21. package/dist/cjs/ShardId.js.map +1 -1
  22. package/dist/cjs/ShardManager.js +63 -43
  23. package/dist/cjs/ShardManager.js.map +1 -1
  24. package/dist/cjs/ShardStorage.js +45 -36
  25. package/dist/cjs/ShardStorage.js.map +1 -1
  26. package/dist/cjs/Sharding.js +45 -37
  27. package/dist/cjs/Sharding.js.map +1 -1
  28. package/dist/cjs/ShardingConfig.js +9 -2
  29. package/dist/cjs/ShardingConfig.js.map +1 -1
  30. package/dist/cjs/Singleton.js +2 -2
  31. package/dist/cjs/Singleton.js.map +1 -1
  32. package/dist/cjs/SingletonAddress.js +2 -2
  33. package/dist/cjs/SingletonAddress.js.map +1 -1
  34. package/dist/cjs/SqlMessageStorage.js +32 -27
  35. package/dist/cjs/SqlMessageStorage.js.map +1 -1
  36. package/dist/cjs/SqlShardStorage.js +14 -14
  37. package/dist/cjs/SqlShardStorage.js.map +1 -1
  38. package/dist/cjs/index.js +3 -1
  39. package/dist/cjs/internal/entityManager.js +2 -1
  40. package/dist/cjs/internal/entityManager.js.map +1 -1
  41. package/dist/cjs/internal/shardManager.js +138 -37
  42. package/dist/cjs/internal/shardManager.js.map +1 -1
  43. package/dist/dts/ClusterCron.d.ts +37 -0
  44. package/dist/dts/ClusterCron.d.ts.map +1 -0
  45. package/dist/dts/ClusterSchema.d.ts +8 -0
  46. package/dist/dts/ClusterSchema.d.ts.map +1 -1
  47. package/dist/dts/ClusterWorkflowEngine.d.ts +4 -4
  48. package/dist/dts/ClusterWorkflowEngine.d.ts.map +1 -1
  49. package/dist/dts/Entity.d.ts +10 -0
  50. package/dist/dts/Entity.d.ts.map +1 -1
  51. package/dist/dts/EntityAddress.d.ts +9 -3
  52. package/dist/dts/EntityAddress.d.ts.map +1 -1
  53. package/dist/dts/MessageStorage.d.ts +3 -3
  54. package/dist/dts/MessageStorage.d.ts.map +1 -1
  55. package/dist/dts/Runner.d.ts +15 -0
  56. package/dist/dts/Runner.d.ts.map +1 -1
  57. package/dist/dts/RunnerAddress.d.ts +5 -0
  58. package/dist/dts/RunnerAddress.d.ts.map +1 -1
  59. package/dist/dts/Runners.d.ts.map +1 -1
  60. package/dist/dts/ShardId.d.ts +60 -6
  61. package/dist/dts/ShardId.d.ts.map +1 -1
  62. package/dist/dts/ShardManager.d.ts +13 -13
  63. package/dist/dts/ShardManager.d.ts.map +1 -1
  64. package/dist/dts/ShardStorage.d.ts +11 -14
  65. package/dist/dts/ShardStorage.d.ts.map +1 -1
  66. package/dist/dts/Sharding.d.ts +4 -2
  67. package/dist/dts/Sharding.d.ts.map +1 -1
  68. package/dist/dts/ShardingConfig.d.ts +32 -6
  69. package/dist/dts/ShardingConfig.d.ts.map +1 -1
  70. package/dist/dts/Singleton.d.ts +3 -1
  71. package/dist/dts/Singleton.d.ts.map +1 -1
  72. package/dist/dts/SingletonAddress.d.ts +4 -3
  73. package/dist/dts/SingletonAddress.d.ts.map +1 -1
  74. package/dist/dts/SqlMessageStorage.d.ts +3 -2
  75. package/dist/dts/SqlMessageStorage.d.ts.map +1 -1
  76. package/dist/dts/SqlShardStorage.d.ts +1 -1
  77. package/dist/dts/index.d.ts +4 -0
  78. package/dist/dts/index.d.ts.map +1 -1
  79. package/dist/esm/ClusterCron.js +77 -0
  80. package/dist/esm/ClusterCron.js.map +1 -0
  81. package/dist/esm/ClusterSchema.js +7 -0
  82. package/dist/esm/ClusterSchema.js.map +1 -1
  83. package/dist/esm/ClusterWorkflowEngine.js +99 -78
  84. package/dist/esm/ClusterWorkflowEngine.js.map +1 -1
  85. package/dist/esm/Entity.js +6 -1
  86. package/dist/esm/Entity.js.map +1 -1
  87. package/dist/esm/EntityAddress.js +8 -1
  88. package/dist/esm/EntityAddress.js.map +1 -1
  89. package/dist/esm/MessageStorage.js +6 -4
  90. package/dist/esm/MessageStorage.js.map +1 -1
  91. package/dist/esm/Runner.js +15 -0
  92. package/dist/esm/Runner.js.map +1 -1
  93. package/dist/esm/RunnerAddress.js +8 -1
  94. package/dist/esm/RunnerAddress.js.map +1 -1
  95. package/dist/esm/Runners.js +5 -0
  96. package/dist/esm/Runners.js.map +1 -1
  97. package/dist/esm/ShardId.js +73 -6
  98. package/dist/esm/ShardId.js.map +1 -1
  99. package/dist/esm/ShardManager.js +64 -45
  100. package/dist/esm/ShardManager.js.map +1 -1
  101. package/dist/esm/ShardStorage.js +44 -36
  102. package/dist/esm/ShardStorage.js.map +1 -1
  103. package/dist/esm/Sharding.js +45 -37
  104. package/dist/esm/Sharding.js.map +1 -1
  105. package/dist/esm/ShardingConfig.js +9 -2
  106. package/dist/esm/ShardingConfig.js.map +1 -1
  107. package/dist/esm/Singleton.js +2 -2
  108. package/dist/esm/Singleton.js.map +1 -1
  109. package/dist/esm/SingletonAddress.js +2 -2
  110. package/dist/esm/SingletonAddress.js.map +1 -1
  111. package/dist/esm/SqlMessageStorage.js +32 -27
  112. package/dist/esm/SqlMessageStorage.js.map +1 -1
  113. package/dist/esm/SqlShardStorage.js +14 -14
  114. package/dist/esm/SqlShardStorage.js.map +1 -1
  115. package/dist/esm/index.js +4 -0
  116. package/dist/esm/index.js.map +1 -1
  117. package/dist/esm/internal/entityManager.js +2 -1
  118. package/dist/esm/internal/entityManager.js.map +1 -1
  119. package/dist/esm/internal/shardManager.js +136 -36
  120. package/dist/esm/internal/shardManager.js.map +1 -1
  121. package/package.json +13 -5
  122. package/src/ClusterCron.ts +129 -0
  123. package/src/ClusterSchema.ts +9 -0
  124. package/src/ClusterWorkflowEngine.ts +93 -58
  125. package/src/Entity.ts +20 -1
  126. package/src/EntityAddress.ts +11 -1
  127. package/src/MessageStorage.ts +12 -7
  128. package/src/Runner.ts +18 -0
  129. package/src/RunnerAddress.ts +9 -1
  130. package/src/Runners.ts +5 -0
  131. package/src/ShardId.ts +81 -11
  132. package/src/ShardManager.ts +74 -45
  133. package/src/ShardStorage.ts +51 -47
  134. package/src/Sharding.ts +45 -39
  135. package/src/ShardingConfig.ts +36 -7
  136. package/src/Singleton.ts +5 -2
  137. package/src/SingletonAddress.ts +2 -2
  138. package/src/SqlMessageStorage.ts +36 -30
  139. package/src/SqlShardStorage.ts +15 -15
  140. package/src/index.ts +5 -0
  141. package/src/internal/entityManager.ts +2 -1
  142. package/src/internal/shardManager.ts +158 -52
@@ -16,6 +16,7 @@ import * as HashMap from "effect/HashMap";
16
16
  import * as Iterable from "effect/Iterable";
17
17
  import * as Layer from "effect/Layer";
18
18
  import * as MutableHashMap from "effect/MutableHashMap";
19
+ import * as MutableHashSet from "effect/MutableHashSet";
19
20
  import * as MutableRef from "effect/MutableRef";
20
21
  import * as Option from "effect/Option";
21
22
  import * as Predicate from "effect/Predicate";
@@ -61,18 +62,24 @@ const make = /*#__PURE__*/Effect.gen(function* () {
61
62
  const shardStorage = yield* ShardStorage;
62
63
  const entityManagers = new Map();
63
64
  const shardAssignments = MutableHashMap.empty();
64
- const selfShards = new Set();
65
+ const selfShards = MutableHashSet.empty();
65
66
  // the active shards are the ones that we have acquired the lock for
66
- const acquiredShards = new Set();
67
+ const acquiredShards = MutableHashSet.empty();
67
68
  const activeShardsLatch = yield* Effect.makeLatch(false);
68
69
  const events = yield* PubSub.unbounded();
69
70
  const getRegistrationEvents = Stream.fromPubSub(events);
70
71
  const isLocalRunner = address => Option.isSome(config.runnerAddress) && Equal.equals(address, config.runnerAddress.value);
71
- function getShardId(entityId) {
72
- return ShardId.make(Math.abs(hashString(entityId) % config.numberOfShards) + 1);
72
+ function getShardId(entityId, group) {
73
+ const id = Math.abs(hashString(entityId) % config.shardsPerGroup) + 1;
74
+ return ShardId.make({
75
+ group,
76
+ id
77
+ }, {
78
+ disableValidation: true
79
+ });
73
80
  }
74
81
  function isEntityOnLocalShards(address) {
75
- return acquiredShards.has(address.shardId);
82
+ return MutableHashSet.has(acquiredShards, address.shardId);
76
83
  }
77
84
  // --- Shard acquisition ---
78
85
  if (Option.isSome(config.runnerAddress)) {
@@ -81,34 +88,34 @@ const make = /*#__PURE__*/Effect.gen(function* () {
81
88
  // the locks expire over time, so if this fails we ignore it
82
89
  return Effect.ignore(shardStorage.releaseAll(selfAddress));
83
90
  });
84
- const releasingShards = new Set();
91
+ const releasingShards = MutableHashSet.empty();
85
92
  yield* Effect.gen(function* () {
86
93
  while (true) {
87
94
  yield* activeShardsLatch.await;
88
95
  // if a shard is no longer assigned to this runner, we release it
89
96
  for (const shardId of acquiredShards) {
90
- if (selfShards.has(shardId)) continue;
91
- acquiredShards.delete(shardId);
92
- releasingShards.add(shardId);
97
+ if (MutableHashSet.has(selfShards, shardId)) continue;
98
+ MutableHashSet.remove(acquiredShards, shardId);
99
+ MutableHashSet.add(releasingShards, shardId);
93
100
  }
94
101
  // if a shard has been assigned to this runner, we acquire it
95
- const unacquiredShards = new Set();
102
+ const unacquiredShards = MutableHashSet.empty();
96
103
  for (const shardId of selfShards) {
97
- if (acquiredShards.has(shardId) || releasingShards.has(shardId)) continue;
98
- unacquiredShards.add(shardId);
104
+ if (MutableHashSet.has(acquiredShards, shardId) || MutableHashSet.has(releasingShards, shardId)) continue;
105
+ MutableHashSet.add(unacquiredShards, shardId);
99
106
  }
100
- if (releasingShards.size > 0) {
107
+ if (MutableHashSet.size(releasingShards) > 0) {
101
108
  yield* Effect.forkIn(syncSingletons, shardingScope);
102
109
  yield* releaseShards;
103
110
  }
104
- if (unacquiredShards.size === 0) {
111
+ if (MutableHashSet.size(unacquiredShards) === 0) {
105
112
  yield* activeShardsLatch.close;
106
113
  continue;
107
114
  }
108
115
  const acquired = yield* shardStorage.acquire(selfAddress, unacquiredShards);
109
116
  yield* Effect.ignore(storage.resetShards(acquired));
110
117
  for (const shardId of acquired) {
111
- acquiredShards.add(shardId);
118
+ MutableHashSet.add(acquiredShards, shardId);
112
119
  }
113
120
  if (acquired.length > 0) {
114
121
  yield* storageReadLatch.open;
@@ -125,12 +132,12 @@ const make = /*#__PURE__*/Effect.gen(function* () {
125
132
  // refresh the shard locks every 4s
126
133
  yield* Effect.suspend(() => shardStorage.refresh(selfAddress, [...acquiredShards, ...releasingShards])).pipe(Effect.flatMap(acquired => {
127
134
  for (const shardId of acquiredShards) {
128
- if (!acquired.includes(shardId)) {
129
- acquiredShards.delete(shardId);
130
- releasingShards.add(shardId);
135
+ if (!acquired.some(_ => _[Equal.symbol](shardId))) {
136
+ MutableHashSet.remove(acquiredShards, shardId);
137
+ MutableHashSet.add(releasingShards, shardId);
131
138
  }
132
139
  }
133
- return releasingShards.size > 0 ? Effect.andThen(Effect.forkIn(syncSingletons, shardingScope), releaseShards) : Effect.void;
140
+ return MutableHashSet.size(releasingShards) > 0 ? Effect.andThen(Effect.forkIn(syncSingletons, shardingScope), releaseShards) : Effect.void;
134
141
  }), Effect.retry({
135
142
  times: 5,
136
143
  schedule: Schedule.spaced(50)
@@ -142,23 +149,24 @@ const make = /*#__PURE__*/Effect.gen(function* () {
142
149
  }).pipe(Effect.andThen(shardStorage.release(selfAddress, shardId)), Effect.annotateLogs({
143
150
  runner: selfAddress
144
151
  }), Effect.andThen(() => {
145
- releasingShards.delete(shardId);
152
+ MutableHashSet.remove(releasingShards, shardId);
146
153
  })), {
147
154
  concurrency: "unbounded",
148
155
  discard: true
149
156
  })));
150
157
  }
151
158
  const clearSelfShards = Effect.suspend(() => {
152
- selfShards.clear();
159
+ MutableHashSet.clear(selfShards);
153
160
  return activeShardsLatch.open;
154
161
  });
155
162
  // --- Singletons ---
156
163
  const singletons = new Map();
157
164
  const singletonFibers = yield* FiberMap.make();
158
165
  const withSingletonLock = Effect.unsafeMakeSemaphore(1).withPermits(1);
159
- const registerSingleton = Effect.fnUntraced(function* (name, run) {
166
+ const registerSingleton = Effect.fnUntraced(function* (name, run, options) {
167
+ const shardGroup = options?.shardGroup ?? "default";
160
168
  const address = new SingletonAddress({
161
- shardId: getShardId(EntityId.make(name)),
169
+ shardId: getShardId(EntityId.make(name), shardGroup),
162
170
  name
163
171
  });
164
172
  let map = singletons.get(address.shardId);
@@ -176,7 +184,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
176
184
  address
177
185
  }));
178
186
  // start if we are on the right shard
179
- if (acquiredShards.has(address.shardId)) {
187
+ if (MutableHashSet.has(acquiredShards, address.shardId)) {
180
188
  yield* Effect.logDebug("Starting singleton", address);
181
189
  yield* FiberMap.run(singletonFibers, address, wrappedRun);
182
190
  }
@@ -185,7 +193,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
185
193
  for (const [shardId, map] of singletons) {
186
194
  for (const [address, run] of map) {
187
195
  const running = FiberMap.unsafeHas(singletonFibers, address);
188
- const shouldBeRunning = acquiredShards.has(shardId);
196
+ const shouldBeRunning = MutableHashSet.has(acquiredShards, shardId);
189
197
  if (running && !shouldBeRunning) {
190
198
  yield* Effect.logDebug("Stopping singleton", address);
191
199
  internalInterruptors.add(yield* Effect.fiberId);
@@ -247,7 +255,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
247
255
  currentSentRequestIds.add(message.envelope.requestId);
248
256
  }
249
257
  const address = message.envelope.address;
250
- if (!acquiredShards.has(address.shardId)) {
258
+ if (!MutableHashSet.has(acquiredShards, address.shardId)) {
251
259
  return Effect.void;
252
260
  }
253
261
  const state = entityManagers.get(address.entityType);
@@ -348,7 +356,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
348
356
  let done = false;
349
357
  while (!done) {
350
358
  // if the shard is no longer assigned to this runner, we stop
351
- if (!acquiredShards.has(address.shardId)) {
359
+ if (!MutableHashSet.has(acquiredShards, address.shardId)) {
352
360
  return;
353
361
  }
354
362
  // take a batch of unprocessed messages ids
@@ -365,7 +373,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
365
373
  }
366
374
  let index = 0;
367
375
  const sendWithRetry = Effect.catchTags(Effect.suspend(() => {
368
- if (!acquiredShards.has(address.shardId)) {
376
+ if (!MutableHashSet.has(acquiredShards, address.shardId)) {
369
377
  return Effect.fail(new EntityNotAssignedToRunner({
370
378
  address
371
379
  }));
@@ -509,7 +517,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
509
517
  yield* Effect.gen(function* () {
510
518
  yield* Effect.logDebug("Registering with shard manager");
511
519
  if (Option.isSome(config.runnerAddress)) {
512
- const machineId = yield* shardManager.register(config.runnerAddress.value);
520
+ const machineId = yield* shardManager.register(config.runnerAddress.value, config.shardGroups);
513
521
  yield* snowflakeGen.setMachineId(machineId);
514
522
  }
515
523
  yield* stopShardManagerTimeout;
@@ -534,8 +542,8 @@ const make = /*#__PURE__*/Effect.gen(function* () {
534
542
  }
535
543
  if (!MutableRef.get(isShutdown) && isLocalRunner(event.address)) {
536
544
  for (const shardId of event.shards) {
537
- if (selfShards.has(shardId)) continue;
538
- selfShards.add(shardId);
545
+ if (MutableHashSet.has(selfShards, shardId)) continue;
546
+ MutableHashSet.add(selfShards, shardId);
539
547
  }
540
548
  yield* activeShardsLatch.open;
541
549
  }
@@ -548,7 +556,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
548
556
  }
549
557
  if (isLocalRunner(event.address)) {
550
558
  for (const shard of event.shards) {
551
- selfShards.delete(shard);
559
+ MutableHashSet.remove(selfShards, shard);
552
560
  }
553
561
  yield* activeShardsLatch.open;
554
562
  }
@@ -575,18 +583,18 @@ const make = /*#__PURE__*/Effect.gen(function* () {
575
583
  for (const [shardId, runner] of assignments) {
576
584
  if (Option.isNone(runner)) {
577
585
  MutableHashMap.remove(shardAssignments, shardId);
578
- selfShards.delete(shardId);
586
+ MutableHashSet.remove(selfShards, shardId);
579
587
  continue;
580
588
  }
581
589
  MutableHashMap.set(shardAssignments, shardId, runner.value);
582
590
  if (!isLocalRunner(runner.value)) {
583
- selfShards.delete(shardId);
591
+ MutableHashSet.remove(selfShards, shardId);
584
592
  continue;
585
593
  }
586
- if (MutableRef.get(isShutdown) || selfShards.has(shardId)) {
594
+ if (MutableRef.get(isShutdown) || MutableHashSet.has(selfShards, shardId)) {
587
595
  continue;
588
596
  }
589
- selfShards.add(shardId);
597
+ MutableHashSet.add(selfShards, shardId);
590
598
  }
591
599
  yield* activeShardsLatch.open;
592
600
  });
@@ -693,7 +701,7 @@ const make = /*#__PURE__*/Effect.gen(function* () {
693
701
  return {
694
702
  ...wrappedClient,
695
703
  [currentClientAddress]: ClientAddressTag.context(EntityAddress.make({
696
- shardId: getShardId(id),
704
+ shardId: getShardId(id, entity.getShardGroup(entityId)),
697
705
  entityId: id,
698
706
  entityType: entity.type
699
707
  }))
@@ -1 +1 @@
1
- {"version":3,"file":"Sharding.js","names":["RpcClient","RequestId","Arr","Cause","Context","Deferred","Effect","Equal","Exit","Fiber","FiberHandle","FiberMap","FiberRef","constant","HashMap","Iterable","Layer","MutableHashMap","MutableRef","Option","Predicate","PubSub","Schedule","Scope","Stream","AlreadyProcessingMessage","EntityNotAssignedToRunner","EntityNotManagedByRunner","RunnerUnavailable","Persisted","Uninterruptible","EntityAddress","EntityId","Envelope","EntityManager","EntityReaper","hashString","internalInterruptors","ResourceMap","Message","MessageStorage","Reply","Runners","ShardId","ShardingConfig","EntityRegistered","SingletonRegistered","ShardManagerClient","ShardStorage","SingletonAddress","Snowflake","Sharding","Tag","make","gen","config","runners","shardManager","snowflakeGen","Generator","shardingScope","scope","isShutdown","storage","storageEnabled","noop","shardStorage","entityManagers","Map","shardAssignments","empty","selfShards","Set","acquiredShards","activeShardsLatch","makeLatch","events","unbounded","getRegistrationEvents","fromPubSub","isLocalRunner","address","isSome","runnerAddress","equals","value","getShardId","entityId","Math","abs","numberOfShards","isEntityOnLocalShards","has","shardId","selfAddress","addFinalizerExit","ignore","releaseAll","releasingShards","await","delete","add","unacquiredShards","size","forkIn","syncSingletons","releaseShards","close","acquired","acquire","resetShards","length","storageReadLatch","open","sleep","pipe","catchAllCause","cause","logWarning","repeat","spaced","entityMessagePollInterval","annotateLogs","package","module","fiber","runner","interruptible","suspend","refresh","flatMap","includes","andThen","void","retry","times","schedule","logError","clearSelfShards","delay","forever","releaseShardsLock","unsafeMakeSemaphore","withPermits","forEach","values","state","manager","interruptShard","concurrency","discard","release","clear","singletons","singletonFibers","withSingletonLock","registerSingleton","fnUntraced","name","run","map","get","set","dieMessage","context","wrappedRun","locally","currentLogAnnotations","never","scoped","provide","orDie","publish","logDebug","running","unsafeHas","shouldBeRunning","fiberId","remove","openStorageReadLatch","storageReadLock","withStorageReadLock","storageAlreadyProcessed","_message","sentRequestIds","sentRequestIdSets","addFinalizer","message","envelope","requestId","entityType","isProcessingFor","excludeReplies","unsafeClose","take","messages","unprocessedMessages","currentSentRequestIds","send","index","_tag","respond","ReplyWithContext","fromDefect","id","unsafeNext","defect","isProcessing","resumptionState","entityResumptionState","unprocessed","interrupts","error","failureOption","isNone","saveReply","squash","resumeEntityFromStorage","whileLoop","while","step","body","oldest","unsafeHead","ensuring","lastReceivedMessage","resumeEntityFromStorageImpl","getOrThrow","done","messageIds","push","unprocessedMessagesById","sendWithRetry","catchTags","fail","interrupt","MailboxFull","sendRetryInterval","sync","e","effect","entity","sendLocal","simulateRemoteSerialization","notifyLocal","notify","envelopeId","isTransientError","or","is","sendOutgoing","retries","catchIf","maybeRunner","isPersisted","rpc","annotations","runnerIsLocal","die","reset","clearReplies","matchCause","onSuccess","onFailure","shardManagerTimeoutFiber","extend","startShardManagerTimeout","shardManagerUnavailableTimeout","onlyIfMissing","stopShardManagerTimeout","machineId","register","setMachineId","mailbox","shardingEvents","startedLatch","eventsFiber","takeAll","event","shard","shards","intoDeferred","forkScoped","syncFiber","syncAssignments","refreshAssignmentsInterval","joinAll","zipRight","exponential","union","assignments","getAssignments","clientRequests","clients","client","makeNoSerialization","protocol","spanPrefix","type","supportsAck","generateRequestId","onFromClient","options","unsafeGet","ClientAddressTag","getCurrentFiber","requests","tag","entry","currentContext","makeClientRespond","write","clientRespondDiscard","OutgoingRequest","makeRequest","payload","headers","traceId","spanId","sampled","lastReceivedReply","none","OutgoingEnvelope","AckChunk","replyId","lastChunkId","isTransientInterrupt","interruptors","some","Interrupt","wrappedClient","method","Object","keys","merge","currentClientAddress","withFiberRuntime","makeClient","_reply","reply","clientId","exit","reaper","registerEntity","build","sharding","unregister","activeEntityCount","count","of","layer","layerGenerator","Default","GenericTag","Symbol","for","key"],"sources":["../../src/Sharding.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"Sharding.js","names":["RpcClient","RequestId","Arr","Cause","Context","Deferred","Effect","Equal","Exit","Fiber","FiberHandle","FiberMap","FiberRef","constant","HashMap","Iterable","Layer","MutableHashMap","MutableHashSet","MutableRef","Option","Predicate","PubSub","Schedule","Scope","Stream","AlreadyProcessingMessage","EntityNotAssignedToRunner","EntityNotManagedByRunner","RunnerUnavailable","Persisted","Uninterruptible","EntityAddress","EntityId","Envelope","EntityManager","EntityReaper","hashString","internalInterruptors","ResourceMap","Message","MessageStorage","Reply","Runners","ShardId","ShardingConfig","EntityRegistered","SingletonRegistered","ShardManagerClient","ShardStorage","SingletonAddress","Snowflake","Sharding","Tag","make","gen","config","runners","shardManager","snowflakeGen","Generator","shardingScope","scope","isShutdown","storage","storageEnabled","noop","shardStorage","entityManagers","Map","shardAssignments","empty","selfShards","acquiredShards","activeShardsLatch","makeLatch","events","unbounded","getRegistrationEvents","fromPubSub","isLocalRunner","address","isSome","runnerAddress","equals","value","getShardId","entityId","group","id","Math","abs","shardsPerGroup","disableValidation","isEntityOnLocalShards","has","shardId","selfAddress","addFinalizerExit","ignore","releaseAll","releasingShards","await","remove","add","unacquiredShards","size","forkIn","syncSingletons","releaseShards","close","acquired","acquire","resetShards","length","storageReadLatch","open","sleep","pipe","catchAllCause","cause","logWarning","repeat","spaced","entityMessagePollInterval","annotateLogs","package","module","fiber","runner","interruptible","suspend","refresh","flatMap","some","_","symbol","andThen","void","retry","times","schedule","logError","clearSelfShards","delay","forever","releaseShardsLock","unsafeMakeSemaphore","withPermits","forEach","values","state","manager","interruptShard","concurrency","discard","release","clear","singletons","singletonFibers","withSingletonLock","registerSingleton","fnUntraced","name","run","options","shardGroup","map","get","set","dieMessage","context","wrappedRun","locally","currentLogAnnotations","never","scoped","provide","orDie","publish","logDebug","running","unsafeHas","shouldBeRunning","fiberId","openStorageReadLatch","storageReadLock","withStorageReadLock","storageAlreadyProcessed","_message","sentRequestIds","Set","sentRequestIdSets","addFinalizer","message","envelope","requestId","entityType","isProcessingFor","excludeReplies","unsafeClose","take","messages","unprocessedMessages","currentSentRequestIds","send","index","_tag","respond","ReplyWithContext","fromDefect","unsafeNext","defect","isProcessing","resumptionState","entityResumptionState","unprocessed","interrupts","error","failureOption","isNone","saveReply","squash","resumeEntityFromStorage","whileLoop","while","step","body","oldest","unsafeHead","delete","ensuring","lastReceivedMessage","resumeEntityFromStorageImpl","getOrThrow","done","messageIds","push","unprocessedMessagesById","sendWithRetry","catchTags","fail","interrupt","MailboxFull","sendRetryInterval","sync","e","effect","entity","sendLocal","simulateRemoteSerialization","notifyLocal","notify","envelopeId","isTransientError","or","is","sendOutgoing","retries","catchIf","maybeRunner","isPersisted","rpc","annotations","runnerIsLocal","die","reset","clearReplies","matchCause","onSuccess","onFailure","shardManagerTimeoutFiber","extend","startShardManagerTimeout","shardManagerUnavailableTimeout","onlyIfMissing","stopShardManagerTimeout","machineId","register","shardGroups","setMachineId","mailbox","shardingEvents","startedLatch","eventsFiber","takeAll","event","shard","shards","intoDeferred","forkScoped","syncFiber","syncAssignments","refreshAssignmentsInterval","joinAll","zipRight","exponential","union","assignments","getAssignments","clientRequests","clients","client","makeNoSerialization","protocol","spanPrefix","type","supportsAck","generateRequestId","onFromClient","unsafeGet","ClientAddressTag","getCurrentFiber","requests","tag","entry","currentContext","makeClientRespond","write","clientRespondDiscard","OutgoingRequest","makeRequest","payload","headers","traceId","spanId","sampled","lastReceivedReply","none","OutgoingEnvelope","AckChunk","replyId","lastChunkId","isTransientInterrupt","interruptors","Interrupt","wrappedClient","method","Object","keys","merge","currentClientAddress","withFiberRuntime","getShardGroup","makeClient","_reply","reply","clientId","exit","reaper","registerEntity","build","sharding","unregister","activeEntityCount","count","of","layer","layerGenerator","Default","GenericTag","Symbol","for","key"],"sources":["../../src/Sharding.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
@@ -26,13 +26,15 @@ const defaultRunnerAddress = /*#__PURE__*/RunnerAddress.make({
26
26
  */
27
27
  export const defaults = {
28
28
  runnerAddress: /*#__PURE__*/Option.some(defaultRunnerAddress),
29
+ runnerListenAddress: /*#__PURE__*/Option.none(),
29
30
  serverVersion: 1,
30
- numberOfShards: 300,
31
+ shardsPerGroup: 300,
31
32
  shardManagerAddress: /*#__PURE__*/RunnerAddress.make({
32
33
  host: "localhost",
33
34
  port: 8080
34
35
  }),
35
36
  shardManagerUnavailableTimeout: /*#__PURE__*/Duration.minutes(10),
37
+ shardGroups: ["default"],
36
38
  entityMailboxCapacity: 4096,
37
39
  entityMaxIdleTime: /*#__PURE__*/Duration.minutes(1),
38
40
  entityTerminationTimeout: /*#__PURE__*/Duration.seconds(15),
@@ -64,8 +66,13 @@ export const config = /*#__PURE__*/Config.all({
64
66
  host: Config.string("host").pipe(Config.withDefault(defaultRunnerAddress.host), Config.withDescription("The hostname or IP address of the runner.")),
65
67
  port: Config.integer("port").pipe(Config.withDefault(defaultRunnerAddress.port), Config.withDescription("The port used for inter-runner communication."))
66
68
  }).pipe(/*#__PURE__*/Config.map(options => RunnerAddress.make(options)), Config.option),
69
+ runnerListenAddress: /*#__PURE__*/Config.all({
70
+ host: Config.string("listenHost").pipe(Config.withDefault(defaultRunnerAddress.host), Config.withDescription("The host to listen on.")),
71
+ port: Config.integer("listenPort").pipe(Config.withDefault(defaultRunnerAddress.port), Config.withDescription("The port to listen on."))
72
+ }).pipe(/*#__PURE__*/Config.map(options => RunnerAddress.make(options)), Config.option),
67
73
  serverVersion: /*#__PURE__*/Config.integer("serverVersion").pipe(/*#__PURE__*/Config.withDefault(defaults.serverVersion), /*#__PURE__*/Config.withDescription("The version of the current runner.")),
68
- numberOfShards: /*#__PURE__*/Config.integer("numberOfShards").pipe(/*#__PURE__*/Config.withDefault(defaults.numberOfShards), /*#__PURE__*/Config.withDescription("The number of shards to allocate to a runner.")),
74
+ shardGroups: /*#__PURE__*/Config.array(Config.string("shardGroups")).pipe(/*#__PURE__*/Config.withDefault(["default"]), /*#__PURE__*/Config.withDescription("The shard groups that are assigned to this runner.")),
75
+ shardsPerGroup: /*#__PURE__*/Config.integer("shardsPerGroup").pipe(/*#__PURE__*/Config.withDefault(defaults.shardsPerGroup), /*#__PURE__*/Config.withDescription("The number of shards to allocate per shard group.")),
69
76
  shardManagerAddress: /*#__PURE__*/Config.all({
70
77
  host: Config.string("shardManagerHost").pipe(Config.withDefault(defaults.shardManagerAddress.host), Config.withDescription("The host of the shard manager.")),
71
78
  port: Config.integer("shardManagerPort").pipe(Config.withDefault(defaults.shardManagerAddress.port), Config.withDescription("The port of the shard manager."))
@@ -1 +1 @@
1
- {"version":3,"file":"ShardingConfig.js","names":["Config","ConfigProvider","Context","Duration","Effect","Layer","Option","RunnerAddress","ShardingConfig","Tag","defaultRunnerAddress","make","host","port","defaults","runnerAddress","some","serverVersion","numberOfShards","shardManagerAddress","shardManagerUnavailableTimeout","minutes","entityMailboxCapacity","entityMaxIdleTime","entityTerminationTimeout","seconds","entityMessagePollInterval","entityReplyPollInterval","millis","sendRetryInterval","refreshAssignmentsInterval","simulateRemoteSerialization","layer","options","succeed","layerDefaults","config","all","string","pipe","withDefault","withDescription","integer","map","option","duration","boolean","configFromEnv","withConfigProvider","fromEnv","constantCase","layerFromEnv","effect"],"sources":["../../src/ShardingConfig.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"file":"ShardingConfig.js","names":["Config","ConfigProvider","Context","Duration","Effect","Layer","Option","RunnerAddress","ShardingConfig","Tag","defaultRunnerAddress","make","host","port","defaults","runnerAddress","some","runnerListenAddress","none","serverVersion","shardsPerGroup","shardManagerAddress","shardManagerUnavailableTimeout","minutes","shardGroups","entityMailboxCapacity","entityMaxIdleTime","entityTerminationTimeout","seconds","entityMessagePollInterval","entityReplyPollInterval","millis","sendRetryInterval","refreshAssignmentsInterval","simulateRemoteSerialization","layer","options","succeed","layerDefaults","config","all","string","pipe","withDefault","withDescription","integer","map","option","array","duration","boolean","configFromEnv","withConfigProvider","fromEnv","constantCase","layerFromEnv","effect"],"sources":["../../src/ShardingConfig.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,MAAM,MAAM,eAAe;AAEvC,OAAO,KAAKC,cAAc,MAAM,uBAAuB;AACvD,OAAO,KAAKC,OAAO,MAAM,gBAAgB;AAEzC,OAAO,KAAKC,QAAQ,MAAM,iBAAiB;AAC3C,OAAO,KAAKC,MAAM,MAAM,eAAe;AACvC,OAAO,KAAKC,KAAK,MAAM,cAAc;AACrC,OAAO,KAAKC,MAAM,MAAM,eAAe;AACvC,SAASC,aAAa,QAAQ,oBAAoB;AAElD;;;;;;AAMA,OAAM,MAAOC,cAAe,sBAAQN,OAAO,CAACO,GAAG,CAAC,gCAAgC,CAAC,EA0E7E;AAEJ,MAAMC,oBAAoB,gBAAGH,aAAa,CAACI,IAAI,CAAC;EAAEC,IAAI,EAAE,WAAW;EAAEC,IAAI,EAAE;AAAK,CAAE,CAAC;AAEnF;;;;AAIA,OAAO,MAAMC,QAAQ,GAA2B;EAC9CC,aAAa,eAAET,MAAM,CAACU,IAAI,CAACN,oBAAoB,CAAC;EAChDO,mBAAmB,eAAEX,MAAM,CAACY,IAAI,EAAE;EAClCC,aAAa,EAAE,CAAC;EAChBC,cAAc,EAAE,GAAG;EACnBC,mBAAmB,eAAEd,aAAa,CAACI,IAAI,CAAC;IAAEC,IAAI,EAAE,WAAW;IAAEC,IAAI,EAAE;EAAI,CAAE,CAAC;EAC1ES,8BAA8B,eAAEnB,QAAQ,CAACoB,OAAO,CAAC,EAAE,CAAC;EACpDC,WAAW,EAAE,CAAC,SAAS,CAAC;EACxBC,qBAAqB,EAAE,IAAI;EAC3BC,iBAAiB,eAAEvB,QAAQ,CAACoB,OAAO,CAAC,CAAC,CAAC;EACtCI,wBAAwB,eAAExB,QAAQ,CAACyB,OAAO,CAAC,EAAE,CAAC;EAC9CC,yBAAyB,eAAE1B,QAAQ,CAACyB,OAAO,CAAC,EAAE,CAAC;EAC/CE,uBAAuB,eAAE3B,QAAQ,CAAC4B,MAAM,CAAC,GAAG,CAAC;EAC7CC,iBAAiB,eAAE7B,QAAQ,CAAC4B,MAAM,CAAC,GAAG,CAAC;EACvCE,0BAA0B,eAAE9B,QAAQ,CAACoB,OAAO,CAAC,CAAC,CAAC;EAC/CW,2BAA2B,EAAE;CAC9B;AAED;;;;AAIA,OAAO,MAAMC,KAAK,GAAIC,OAAyC,IAC7D/B,KAAK,CAACgC,OAAO,CAAC7B,cAAc,EAAE;EAAE,GAAGM,QAAQ;EAAE,GAAGsB;AAAO,CAAE,CAAC;AAE5D;;;;AAIA,OAAO,MAAME,aAAa,gBAAgCH,KAAK,EAAE;AAEjE;;;;AAIA,OAAO,MAAMI,MAAM,gBAA0CvC,MAAM,CAACwC,GAAG,CAAC;EACtEzB,aAAa,eAAEf,MAAM,CAACwC,GAAG,CAAC;IACxB5B,IAAI,EAAEZ,MAAM,CAACyC,MAAM,CAAC,MAAM,CAAC,CAACC,IAAI,CAC9B1C,MAAM,CAAC2C,WAAW,CAACjC,oBAAoB,CAACE,IAAI,CAAC,EAC7CZ,MAAM,CAAC4C,eAAe,CAAC,2CAA2C,CAAC,CACpE;IACD/B,IAAI,EAAEb,MAAM,CAAC6C,OAAO,CAAC,MAAM,CAAC,CAACH,IAAI,CAC/B1C,MAAM,CAAC2C,WAAW,CAACjC,oBAAoB,CAACG,IAAI,CAAC,EAC7Cb,MAAM,CAAC4C,eAAe,CAAC,+CAA+C,CAAC;GAE1E,CAAC,CAACF,IAAI,cAAC1C,MAAM,CAAC8C,GAAG,CAAEV,OAAO,IAAK7B,aAAa,CAACI,IAAI,CAACyB,OAAO,CAAC,CAAC,EAAEpC,MAAM,CAAC+C,MAAM,CAAC;EAC5E9B,mBAAmB,eAAEjB,MAAM,CAACwC,GAAG,CAAC;IAC9B5B,IAAI,EAAEZ,MAAM,CAACyC,MAAM,CAAC,YAAY,CAAC,CAACC,IAAI,CACpC1C,MAAM,CAAC2C,WAAW,CAACjC,oBAAoB,CAACE,IAAI,CAAC,EAC7CZ,MAAM,CAAC4C,eAAe,CAAC,wBAAwB,CAAC,CACjD;IACD/B,IAAI,EAAEb,MAAM,CAAC6C,OAAO,CAAC,YAAY,CAAC,CAACH,IAAI,CACrC1C,MAAM,CAAC2C,WAAW,CAACjC,oBAAoB,CAACG,IAAI,CAAC,EAC7Cb,MAAM,CAAC4C,eAAe,CAAC,wBAAwB,CAAC;GAEnD,CAAC,CAACF,IAAI,cAAC1C,MAAM,CAAC8C,GAAG,CAAEV,OAAO,IAAK7B,aAAa,CAACI,IAAI,CAACyB,OAAO,CAAC,CAAC,EAAEpC,MAAM,CAAC+C,MAAM,CAAC;EAC5E5B,aAAa,eAAEnB,MAAM,CAAC6C,OAAO,CAAC,eAAe,CAAC,CAACH,IAAI,cACjD1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACK,aAAa,CAAC,eAC1CnB,MAAM,CAAC4C,eAAe,CAAC,oCAAoC,CAAC,CAC7D;EACDpB,WAAW,eAAExB,MAAM,CAACgD,KAAK,CAAChD,MAAM,CAACyC,MAAM,CAAC,aAAa,CAAC,CAAC,CAACC,IAAI,cAC1D1C,MAAM,CAAC2C,WAAW,CAAC,CAAC,SAAS,CAAC,CAAC,eAC/B3C,MAAM,CAAC4C,eAAe,CAAC,oDAAoD,CAAC,CAC7E;EACDxB,cAAc,eAAEpB,MAAM,CAAC6C,OAAO,CAAC,gBAAgB,CAAC,CAACH,IAAI,cACnD1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACM,cAAc,CAAC,eAC3CpB,MAAM,CAAC4C,eAAe,CAAC,mDAAmD,CAAC,CAC5E;EACDvB,mBAAmB,eAAErB,MAAM,CAACwC,GAAG,CAAC;IAC9B5B,IAAI,EAAEZ,MAAM,CAACyC,MAAM,CAAC,kBAAkB,CAAC,CAACC,IAAI,CAC1C1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACO,mBAAmB,CAACT,IAAI,CAAC,EACrDZ,MAAM,CAAC4C,eAAe,CAAC,gCAAgC,CAAC,CACzD;IACD/B,IAAI,EAAEb,MAAM,CAAC6C,OAAO,CAAC,kBAAkB,CAAC,CAACH,IAAI,CAC3C1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACO,mBAAmB,CAACR,IAAI,CAAC,EACrDb,MAAM,CAAC4C,eAAe,CAAC,gCAAgC,CAAC;GAE3D,CAAC,CAACF,IAAI,cAAC1C,MAAM,CAAC8C,GAAG,CAAEV,OAAO,IAAK7B,aAAa,CAACI,IAAI,CAACyB,OAAO,CAAC,CAAC,CAAC;EAC7Dd,8BAA8B,eAAEtB,MAAM,CAACiD,QAAQ,CAAC,gCAAgC,CAAC,CAACP,IAAI,cACpF1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACQ,8BAA8B,CAAC,eAC3DtB,MAAM,CAAC4C,eAAe,CACpB,wFAAwF,CACzF,CACF;EACDnB,qBAAqB,eAAEzB,MAAM,CAAC6C,OAAO,CAAC,uBAAuB,CAAC,CAACH,IAAI,cACjE1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACW,qBAAqB,CAAC,eAClDzB,MAAM,CAAC4C,eAAe,CAAC,mDAAmD,CAAC,CAC5E;EACDlB,iBAAiB,eAAE1B,MAAM,CAACiD,QAAQ,CAAC,mBAAmB,CAAC,CAACP,IAAI,cAC1D1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACY,iBAAiB,CAAC,eAC9C1B,MAAM,CAAC4C,eAAe,CACpB,kHAAkH,CACnH,CACF;EACDjB,wBAAwB,eAAE3B,MAAM,CAACiD,QAAQ,CAAC,0BAA0B,CAAC,CAACP,IAAI,cACxE1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACa,wBAAwB,CAAC,eACrD3B,MAAM,CAAC4C,eAAe,CAAC,kEAAkE,CAAC,CAC3F;EACDf,yBAAyB,eAAE7B,MAAM,CAACiD,QAAQ,CAAC,2BAA2B,CAAC,CAACP,IAAI,cAC1E1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACe,yBAAyB,CAAC,eACtD7B,MAAM,CAAC4C,eAAe,CAAC,sEAAsE,CAAC,CAC/F;EACDd,uBAAuB,eAAE9B,MAAM,CAACiD,QAAQ,CAAC,yBAAyB,CAAC,CAACP,IAAI,cACtE1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACgB,uBAAuB,CAAC,eACpD9B,MAAM,CAAC4C,eAAe,CAAC,gEAAgE,CAAC,CACzF;EACDZ,iBAAiB,eAAEhC,MAAM,CAACiD,QAAQ,CAAC,mBAAmB,CAAC,CAACP,IAAI,cAC1D1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACkB,iBAAiB,CAAC,eAC9ChC,MAAM,CAAC4C,eAAe,CAAC,uEAAuE,CAAC,CAChG;EACDX,0BAA0B,eAAEjC,MAAM,CAACiD,QAAQ,CAAC,4BAA4B,CAAC,CAACP,IAAI,cAC5E1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACmB,0BAA0B,CAAC,eACvDjC,MAAM,CAAC4C,eAAe,CAAC,qDAAqD,CAAC,CAC9E;EACDV,2BAA2B,eAAElC,MAAM,CAACkD,OAAO,CAAC,6BAA6B,CAAC,CAACR,IAAI,cAC7E1C,MAAM,CAAC2C,WAAW,CAAC7B,QAAQ,CAACoB,2BAA2B,CAAC,eACxDlC,MAAM,CAAC4C,eAAe,CAAC,kFAAkF,CAAC;CAE7G,CAAC;AAEF;;;;AAIA,OAAO,MAAMO,aAAa,gBAAGZ,MAAM,CAACG,IAAI,cACtCtC,MAAM,CAACgD,kBAAkB,cACvBnD,cAAc,CAACoD,OAAO,EAAE,CAACX,IAAI,CAC3BzC,cAAc,CAACqD,YAAY,CAC5B,CACF,CACF;AAED;;;;AAIA,OAAO,MAAMC,YAAY,GAAInB,OAAqD,IAIhF/B,KAAK,CAACmD,MAAM,CACVhD,cAAc,EACd4B,OAAO,GAAGhC,MAAM,CAAC0C,GAAG,CAACK,aAAa,EAAGZ,MAAM,KAAM;EAAE,GAAGA,MAAM;EAAE,GAAGH;AAAO,CAAE,CAAC,CAAC,GAAGe,aAAa,CAC7F","ignoreList":[]}
@@ -8,8 +8,8 @@ import { Sharding } from "./Sharding.js";
8
8
  * @since 1.0.0
9
9
  * @category constructors
10
10
  */
11
- export const make = (name, run) => Layer.effectDiscard(Effect.gen(function* () {
11
+ export const make = (name, run, options) => Layer.effectDiscard(Effect.gen(function* () {
12
12
  const sharding = yield* Sharding;
13
- yield* sharding.registerSingleton(name, run);
13
+ yield* sharding.registerSingleton(name, run, options);
14
14
  }));
15
15
  //# sourceMappingURL=Singleton.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Singleton.js","names":["Effect","Layer","Sharding","make","name","run","effectDiscard","gen","sharding","registerSingleton"],"sources":["../../src/Singleton.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,MAAM,MAAM,eAAe;AACvC,OAAO,KAAKC,KAAK,MAAM,cAAc;AAErC,SAASC,QAAQ,QAAQ,eAAe;AAExC;;;;AAIA,OAAO,MAAMC,IAAI,GAAGA,CAClBC,IAAY,EACZC,GAA8B,KAE9BJ,KAAK,CAACK,aAAa,CAACN,MAAM,CAACO,GAAG,CAAC,aAAS;EACtC,MAAMC,QAAQ,GAAG,OAAON,QAAQ;EAChC,OAAOM,QAAQ,CAACC,iBAAiB,CAACL,IAAI,EAAEC,GAAG,CAAC;AAC9C,CAAC,CAAC,CAAC","ignoreList":[]}
1
+ {"version":3,"file":"Singleton.js","names":["Effect","Layer","Sharding","make","name","run","options","effectDiscard","gen","sharding","registerSingleton"],"sources":["../../src/Singleton.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,MAAM,MAAM,eAAe;AACvC,OAAO,KAAKC,KAAK,MAAM,cAAc;AAErC,SAASC,QAAQ,QAAQ,eAAe;AAExC;;;;AAIA,OAAO,MAAMC,IAAI,GAAGA,CAClBC,IAAY,EACZC,GAA8B,EAC9BC,OAEC,KAEDL,KAAK,CAACM,aAAa,CAACP,MAAM,CAACQ,GAAG,CAAC,aAAS;EACtC,MAAMC,QAAQ,GAAG,OAAOP,QAAQ;EAChC,OAAOO,QAAQ,CAACC,iBAAiB,CAACN,IAAI,EAAEC,GAAG,EAAEC,OAAO,CAAC;AACvD,CAAC,CAAC,CAAC","ignoreList":[]}
@@ -28,13 +28,13 @@ export class SingletonAddress extends /*#__PURE__*/Schema.Class("@effect/cluster
28
28
  * @since 1.0.0
29
29
  */
30
30
  [Hash.symbol]() {
31
- return Hash.cached(this)(Hash.string(`${this.shardId}:${this.name}`));
31
+ return Hash.cached(this)(Hash.string(`${this.name}:${this.shardId.toString()}`));
32
32
  }
33
33
  /**
34
34
  * @since 1.0.0
35
35
  */
36
36
  [Equal.symbol](that) {
37
- return this.shardId === that.shardId && this.name === that.name;
37
+ return this.name === that.name && this.shardId[Equal.symbol](that.shardId);
38
38
  }
39
39
  }
40
40
  //# sourceMappingURL=SingletonAddress.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"SingletonAddress.js","names":["Equal","Hash","Schema","ShardId","TypeId","Symbol","for","SingletonAddress","Class","shardId","name","NonEmptyTrimmedString","symbol","cached","string","that"],"sources":["../../src/SingletonAddress.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,KAAK,MAAM,cAAc;AACrC,OAAO,KAAKC,IAAI,MAAM,aAAa;AACnC,OAAO,KAAKC,MAAM,MAAM,eAAe;AACvC,SAASC,OAAO,QAAQ,cAAc;AAEtC;;;;AAIA,OAAO,MAAMC,MAAM,gBAAkBC,MAAM,CAACC,GAAG,CAAC,kCAAkC,CAAC;AAQnF;;;;;;AAMA,OAAM,MAAOC,gBAAiB,sBAAQL,MAAM,CAACM,KAAK,CAAmB,kCAAkC,CAAC,CAAC;EACvGC,OAAO,EAAEN,OAAO;EAChBO,IAAI,EAAER,MAAM,CAACS;CACd,CAAC;EACA;;;EAGS,CAACP,MAAM,IAAIA,MAAM;EAC1B;;;EAGA,CAACH,IAAI,CAACW,MAAM,IAAC;IACX,OAAOX,IAAI,CAACY,MAAM,CAAC,IAAI,CAAC,CAACZ,IAAI,CAACa,MAAM,CAAC,GAAG,IAAI,CAACL,OAAO,IAAI,IAAI,CAACC,IAAI,EAAE,CAAC,CAAC;EACvE;EACA;;;EAGA,CAACV,KAAK,CAACY,MAAM,EAAEG,IAAsB;IACnC,OAAO,IAAI,CAACN,OAAO,KAAKM,IAAI,CAACN,OAAO,IAAI,IAAI,CAACC,IAAI,KAAKK,IAAI,CAACL,IAAI;EACjE","ignoreList":[]}
1
+ {"version":3,"file":"SingletonAddress.js","names":["Equal","Hash","Schema","ShardId","TypeId","Symbol","for","SingletonAddress","Class","shardId","name","NonEmptyTrimmedString","symbol","cached","string","toString","that"],"sources":["../../src/SingletonAddress.ts"],"sourcesContent":[null],"mappings":"AAAA;;;AAGA,OAAO,KAAKA,KAAK,MAAM,cAAc;AACrC,OAAO,KAAKC,IAAI,MAAM,aAAa;AACnC,OAAO,KAAKC,MAAM,MAAM,eAAe;AACvC,SAASC,OAAO,QAAQ,cAAc;AAEtC;;;;AAIA,OAAO,MAAMC,MAAM,gBAAkBC,MAAM,CAACC,GAAG,CAAC,kCAAkC,CAAC;AAQnF;;;;;;AAMA,OAAM,MAAOC,gBAAiB,sBAAQL,MAAM,CAACM,KAAK,CAAmB,kCAAkC,CAAC,CAAC;EACvGC,OAAO,EAAEN,OAAO;EAChBO,IAAI,EAAER,MAAM,CAACS;CACd,CAAC;EACA;;;EAGS,CAACP,MAAM,IAAIA,MAAM;EAC1B;;;EAGA,CAACH,IAAI,CAACW,MAAM,IAAC;IACX,OAAOX,IAAI,CAACY,MAAM,CAAC,IAAI,CAAC,CAACZ,IAAI,CAACa,MAAM,CAAC,GAAG,IAAI,CAACJ,IAAI,IAAI,IAAI,CAACD,OAAO,CAACM,QAAQ,EAAE,EAAE,CAAC,CAAC;EAClF;EACA;;;EAGA,CAACf,KAAK,CAACY,MAAM,EAAEI,IAAsB;IACnC,OAAO,IAAI,CAACN,IAAI,KAAKM,IAAI,CAACN,IAAI,IAAI,IAAI,CAACD,OAAO,CAACT,KAAK,CAACY,MAAM,CAAC,CAACI,IAAI,CAACP,OAAO,CAAC;EAC5E","ignoreList":[]}