memory-leak 0.10.1 → 0.10.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 +4 -4
- checksums.yaml.gz.sig +0 -0
- data/lib/memory/leak/cluster.rb +2 -2
- data/lib/memory/leak/monitor.rb +1 -6
- data/lib/memory/leak/version.rb +1 -1
- data/readme.md +8 -0
- data/releases.md +8 -0
- data.tar.gz.sig +0 -0
- metadata +1 -1
- metadata.gz.sig +0 -0
checksums.yaml
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
---
|
|
2
2
|
SHA256:
|
|
3
|
-
metadata.gz:
|
|
4
|
-
data.tar.gz:
|
|
3
|
+
metadata.gz: 44ee78dcce5647ddf54028dd2798b6174546034d4c1d75d7ac376b0c8388f163
|
|
4
|
+
data.tar.gz: 8bd39321c4b2d0e4512fb0effcd548111e3a7aac8c7ed863078e94bb1553dafd
|
|
5
5
|
SHA512:
|
|
6
|
-
metadata.gz:
|
|
7
|
-
data.tar.gz:
|
|
6
|
+
metadata.gz: bc5de061e905c1e6342116fae217defa90a781de60cc447fe3b29bef556c5b0936e086b7e66e8649efb24a30bece55626a88a964720219ecb81362d224d07e63
|
|
7
|
+
data.tar.gz: 9a55596e1a67c1a21276a8c29c02004fc4fe0541c51a8a93e213f8c8bf5f046a9bb59055010e270d53f9b1ebd0d63b9d8a097cfee7558f630a37b9fc230b88a2
|
checksums.yaml.gz.sig
CHANGED
|
Binary file
|
data/lib/memory/leak/cluster.rb
CHANGED
|
@@ -113,7 +113,7 @@ module Memory
|
|
|
113
113
|
if @total_size > total_size_limit
|
|
114
114
|
Console.warn(self, "Total memory usage exceeded limit.", total_size: @total_size, total_size_limit: total_size_limit, maximum_shared_size: maximum_shared_size, sum_private_size: sum_private_size, host_memory: host_memory)
|
|
115
115
|
else
|
|
116
|
-
Console.
|
|
116
|
+
Console.debug(self, "Total memory usage within limit.", total_size: @total_size, total_size_limit: total_size_limit, maximum_shared_size: maximum_shared_size, sum_private_size: sum_private_size, host_memory: host_memory)
|
|
117
117
|
return false
|
|
118
118
|
end
|
|
119
119
|
|
|
@@ -172,7 +172,7 @@ module Memory
|
|
|
172
172
|
if free_size < free_size_minimum
|
|
173
173
|
Console.warn(self, "Free memory below minimum.", free_size: free_size, free_size_minimum: free_size_minimum, host_memory: host_memory)
|
|
174
174
|
else
|
|
175
|
-
Console.
|
|
175
|
+
Console.debug(self, "Free memory above minimum.", free_size: free_size, free_size_minimum: free_size_minimum, host_memory: host_memory)
|
|
176
176
|
return false
|
|
177
177
|
end
|
|
178
178
|
|
data/lib/memory/leak/monitor.rb
CHANGED
|
@@ -18,11 +18,6 @@ module Memory
|
|
|
18
18
|
# True memory leaks will eventually hit this threshold_size, while small fluctuations will not.
|
|
19
19
|
DEFAULT_THRESHOLD_SIZE = 1024*1024*10
|
|
20
20
|
|
|
21
|
-
# We track the last N process size increases.
|
|
22
|
-
# If the process size is not stabilizing within the specified increase_limit, we can assume there is a leak.
|
|
23
|
-
# With a default interval of 10 seconds, this will track the last ~3 minutes of process size increases.
|
|
24
|
-
DEFAULT_INCREASE_LIMIT = 20
|
|
25
|
-
|
|
26
21
|
# Create a new monitor.
|
|
27
22
|
#
|
|
28
23
|
# @parameter process_id [Integer] The process ID to monitor.
|
|
@@ -30,7 +25,7 @@ module Memory
|
|
|
30
25
|
# @parameter maximum_size_limit [Numeric | Nil] The maximum process size allowed, in bytes, before we assume a memory leak.
|
|
31
26
|
# @parameter threshold_size [Numeric] The threshold for process size increases, in bytes.
|
|
32
27
|
# @parameter increase_limit [Numeric] The limit for the number of process size increases, before we assume a memory leak.
|
|
33
|
-
def initialize(process_id = Process.pid, maximum_size: nil, maximum_size_limit: nil, threshold_size: DEFAULT_THRESHOLD_SIZE, increase_limit:
|
|
28
|
+
def initialize(process_id = Process.pid, maximum_size: nil, maximum_size_limit: nil, threshold_size: DEFAULT_THRESHOLD_SIZE, increase_limit: nil)
|
|
34
29
|
@process_id = process_id
|
|
35
30
|
|
|
36
31
|
@sample_count = 0
|
data/lib/memory/leak/version.rb
CHANGED
data/readme.md
CHANGED
|
@@ -14,6 +14,14 @@ Please see the [project documentation](https://socketry.github.io/memory-leak/)
|
|
|
14
14
|
|
|
15
15
|
Please see the [project releases](https://socketry.github.io/memory-leak/releases/index) for all releases.
|
|
16
16
|
|
|
17
|
+
### v0.10.3
|
|
18
|
+
|
|
19
|
+
- Move normal memory usage logs to `debug` level instead of `info` to reduce noise in production environments.
|
|
20
|
+
|
|
21
|
+
### v0.10.2
|
|
22
|
+
|
|
23
|
+
- Disable default `increase_limit: nil`.
|
|
24
|
+
|
|
17
25
|
### v0.10.0
|
|
18
26
|
|
|
19
27
|
- Introduce `free_size_minimum` to monitor minimum free memory size, which can be used to trigger alerts or actions when available memory is critically low.
|
data/releases.md
CHANGED
|
@@ -1,5 +1,13 @@
|
|
|
1
1
|
# Releases
|
|
2
2
|
|
|
3
|
+
## v0.10.3
|
|
4
|
+
|
|
5
|
+
- Move normal memory usage logs to `debug` level instead of `info` to reduce noise in production environments.
|
|
6
|
+
|
|
7
|
+
## v0.10.2
|
|
8
|
+
|
|
9
|
+
- Disable default `increase_limit: nil`.
|
|
10
|
+
|
|
3
11
|
## v0.10.0
|
|
4
12
|
|
|
5
13
|
- Introduce `free_size_minimum` to monitor minimum free memory size, which can be used to trigger alerts or actions when available memory is critically low.
|
data.tar.gz.sig
CHANGED
|
Binary file
|
metadata
CHANGED
metadata.gz.sig
CHANGED
|
Binary file
|