async-container-supervisor 0.9.2 → 0.9.3

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.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 9013912b7ef22165d93ebf5f6958d26be67b99f601a28b3ac6e7208fc4e8db54
4
- data.tar.gz: 2de566c74dc9fabad2bc5ccb0f0bf329581860fbb8e27f14944cefecfacef9b2
3
+ metadata.gz: 4765d4a1500ef475808f032d7140aacd3beac8e939c68b34c3884d0cee53bef3
4
+ data.tar.gz: fc6fd02c0376c43685f32a2556122fa7c10d36388411241927f6bd58bf9a741f
5
5
  SHA512:
6
- metadata.gz: bde00386e4f3faa439e149b872bb22075725f05235769a1b5084760f059e0e1aed7a669dec9232125aa5053b1afdf09a016c444a16918c4da92210169e9e50b0
7
- data.tar.gz: 844be24d31216db2cdfb978aaf888d15be0982e3211c384e7239bd564ef08880d5d870d887084319232ce6760594b37974623c11c5686c433c92ae3de960e67d
6
+ metadata.gz: 43c99bc5e998157859b494039c62e44bbc2469a82824f482a6d5918c658c35a0e173a3f5c910f5a947b530bbbccdf8a0e1a7eb42a14f54ac268f6d4581b63a43
7
+ data.tar.gz: 8444b007dbdfc4a8ecfd6834cdf5e19d73939421ababec4be2dedc5db5d5d6551c29b9264259966df2d637b162dd0a63f847a7dbefdc683c429ee27a534d3b76
checksums.yaml.gz.sig CHANGED
Binary file
@@ -30,6 +30,9 @@ module Async
30
30
  @options = options
31
31
 
32
32
  @processes = Hash.new{|hash, key| hash[key] = Set.new.compare_by_identity}
33
+
34
+ # Queue to serialize cluster modifications to prevent race conditions:
35
+ @guard = Mutex.new
33
36
  end
34
37
 
35
38
  # @attribute [Memory::Leak::Cluster] The cluster of processes being monitored.
@@ -50,7 +53,10 @@ module Async
50
53
 
51
54
  if connections.empty?
52
55
  Console.debug(self, "Registering process.", child: {process_id: process_id})
53
- self.add(process_id)
56
+ # Queue the cluster modification to avoid race conditions:
57
+ @guard.synchronize do
58
+ self.add(process_id)
59
+ end
54
60
  end
55
61
 
56
62
  connections.add(connection)
@@ -66,7 +72,9 @@ module Async
66
72
 
67
73
  if connections.empty?
68
74
  Console.debug(self, "Removing process.", child: {process_id: process_id})
69
- @cluster.remove(process_id)
75
+ @guard.synchronize do
76
+ @cluster.remove(process_id)
77
+ end
70
78
  end
71
79
  end
72
80
  end
@@ -119,14 +127,16 @@ module Async
119
127
  def run
120
128
  Async do
121
129
  Loop.run(interval: @interval) do
122
- # This block must return true if the process was killed.
123
- @cluster.check! do |process_id, monitor|
124
- Console.error(self, "Memory leak detected!", child: {process_id: process_id}, monitor: monitor)
125
-
126
- begin
127
- memory_leak_detected(process_id, monitor)
128
- rescue => error
129
- Console.error(self, "Failed to handle memory leak!", child: {process_id: process_id}, exception: error)
130
+ @guard.synchronize do
131
+ # This block must return true if the process was killed.
132
+ @cluster.check! do |process_id, monitor|
133
+ Console.error(self, "Memory leak detected!", child: {process_id: process_id}, monitor: monitor)
134
+
135
+ begin
136
+ memory_leak_detected(process_id, monitor)
137
+ rescue => error
138
+ Console.error(self, "Failed to handle memory leak!", child: {process_id: process_id}, exception: error)
139
+ end
130
140
  end
131
141
  end
132
142
  end
@@ -9,7 +9,7 @@ module Async
9
9
  module Container
10
10
  # @namespace
11
11
  module Supervisor
12
- VERSION = "0.9.2"
12
+ VERSION = "0.9.3"
13
13
  end
14
14
  end
15
15
  end
data/readme.md CHANGED
@@ -26,6 +26,10 @@ Please see the [project documentation](https://socketry.github.io/async-containe
26
26
 
27
27
  Please see the [project releases](https://socketry.github.io/async-container-supervisor/releases/index) for all releases.
28
28
 
29
+ ### v0.9.3
30
+
31
+ - Serialize `register`/`remove` and `check!` operations in `MemoryMonitor`.
32
+
29
33
  ### v0.9.1
30
34
 
31
35
  - Close `Call` queue if asynchronous call fails during dispatch - further messages will fail with `ClosedQueueError`.
data/releases.md CHANGED
@@ -1,5 +1,9 @@
1
1
  # Releases
2
2
 
3
+ ## v0.9.3
4
+
5
+ - Serialize `register`/`remove` and `check!` operations in `MemoryMonitor`.
6
+
3
7
  ## v0.9.1
4
8
 
5
9
  - Close `Call` queue if asynchronous call fails during dispatch - further messages will fail with `ClosedQueueError`.
data.tar.gz.sig CHANGED
Binary file
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: async-container-supervisor
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.9.2
4
+ version: 0.9.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - Samuel Williams
@@ -154,7 +154,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
154
154
  - !ruby/object:Gem::Version
155
155
  version: '0'
156
156
  requirements: []
157
- rubygems_version: 3.6.9
157
+ rubygems_version: 4.0.3
158
158
  specification_version: 4
159
159
  summary: A supervisor for managing multiple container processes.
160
160
  test_files: []
metadata.gz.sig CHANGED
Binary file