lograge-sql 2.0.0 → 2.2.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.
- checksums.yaml +4 -4
- data/README.md +19 -4
- data/lib/lograge/active_record_log_subscriber.rb +16 -1
- data/lib/lograge/sql/version.rb +1 -1
- data/lib/lograge/sql.rb +12 -7
- metadata +4 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 6df7e9d756f02019ce93cbac6c0b19a275035a9d0fe74c631aa699eecf149f6f
|
4
|
+
data.tar.gz: d34996be2888e4d234d914de95ee092e2b2380181dd70f4b70b2fe84fdc7cc97
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 9ef329876869d54eab7e71bf64345917185dfc2ad06d33cb3649689ddaa51ea7b257a425f5b1fb2c39da57b6b26e051d2a13a2d1687b51e99b8813f39be7e12f
|
7
|
+
data.tar.gz: c15d0baabaaede38e6d949fe64d1abf1f14229ac2160b3d8b6a3b70a2ea117e49f0b4c36693f467622d42af862a1dd27d89e3066d44938a4d83bf35633cc170c
|
data/README.md
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
# Lograge::Sql
|
2
2
|
|
3
3
|
[](https://badge.fury.io/rb/lograge-sql)
|
4
|
-
[](https://github.com/iMacTia/lograge-sql/actions/workflows/ci.yml)
|
5
5
|
|
6
6
|
Lograge::Sql is an extension to the famous [Lograge](https://github.com/roidrage/lograge) gem, which adds SQL queries to the Lograge Event and disable default ActiveRecord logging.
|
7
7
|
This is extremely useful if you're using Lograge together with the ELK stack.
|
@@ -29,7 +29,23 @@ By default, Lograge::Sql disables default logging on ActiveRecord. To preserve d
|
|
29
29
|
config.lograge_sql.keep_default_active_record_log = true
|
30
30
|
```
|
31
31
|
|
32
|
-
##
|
32
|
+
## Configuration
|
33
|
+
|
34
|
+
### Minimum query duration threshold
|
35
|
+
|
36
|
+
By default, `lograge-sql` stores all queries, but you can set a `min_duration_ms` config.
|
37
|
+
When you do so, only queries that run for AT LEAST `min_duration_ms` milliseconds will be logged, and all others will be ignored.
|
38
|
+
This can be really helpful if you want to detect `Slow SQL queries`.
|
39
|
+
|
40
|
+
```ruby
|
41
|
+
# config/initializers/lograge.rb
|
42
|
+
Rails.application.configure do
|
43
|
+
# Defaults is zero
|
44
|
+
config.lograge_sql.min_duration_ms = 5000 # milliseconds
|
45
|
+
end
|
46
|
+
```
|
47
|
+
|
48
|
+
### Output Customization
|
33
49
|
|
34
50
|
By default, the format is a string concatenation of the query name, the query duration and the query itself joined by `\n` newline:
|
35
51
|
|
@@ -66,11 +82,10 @@ Rails.application.configure do
|
|
66
82
|
end
|
67
83
|
```
|
68
84
|
|
69
|
-
|
85
|
+
### Thread-safety
|
70
86
|
|
71
87
|
[Depending on the web server in your project](https://github.com/steveklabnik/request_store#the-problem) you might benefit from improved thread-safety by adding [`request_store`](https://github.com/steveklabnik/request_store) to your Gemfile. It will be automatically picked up by `lograge-sql`.
|
72
88
|
|
73
89
|
## Contributing
|
74
90
|
|
75
91
|
Bug reports and pull requests are welcome on GitHub at https://github.com/iMacTia/lograge-sql.
|
76
|
-
|
@@ -6,11 +6,26 @@ module Lograge
|
|
6
6
|
# Every time there's an SQL query, stores it into the Thread.
|
7
7
|
# They'll later be access from the RequestLogSubscriber.
|
8
8
|
def sql(event)
|
9
|
-
|
9
|
+
increase_runtime_duration(event)
|
10
10
|
return if event.payload[:name] == 'SCHEMA'
|
11
11
|
|
12
|
+
# Only store SQL events if `event.duration` is greater than the configured +min_duration+
|
13
|
+
# No need to check if +min_duration+ is present before as it defaults to 0
|
14
|
+
return if event.duration.to_f.round(2) < Lograge::Sql.min_duration_ms.to_f
|
15
|
+
|
12
16
|
Lograge::Sql.store[:lograge_sql_queries] ||= []
|
13
17
|
Lograge::Sql.store[:lograge_sql_queries] << Lograge::Sql.extract_event.call(event)
|
14
18
|
end
|
19
|
+
|
20
|
+
private
|
21
|
+
|
22
|
+
# Add the event duration to the overall ActiveRecord::LogSubscriber.runtime;
|
23
|
+
# note we don't do this when `keep_default_active_record_log` is enabled,
|
24
|
+
# as ActiveRecord is already adding the duration.
|
25
|
+
def increase_runtime_duration(event)
|
26
|
+
return if Rails.application.config.lograge_sql.keep_default_active_record_log
|
27
|
+
|
28
|
+
ActiveRecord::LogSubscriber.runtime += event.duration
|
29
|
+
end
|
15
30
|
end
|
16
31
|
end
|
data/lib/lograge/sql/version.rb
CHANGED
data/lib/lograge/sql.rb
CHANGED
@@ -11,18 +11,17 @@ module Lograge
|
|
11
11
|
attr_accessor :formatter
|
12
12
|
# Extract information from SQL event
|
13
13
|
attr_accessor :extract_event
|
14
|
+
# Filter SQL events by duration
|
15
|
+
attr_accessor :min_duration_ms
|
14
16
|
|
15
17
|
# Initialise configuration with fallback to default values
|
16
18
|
def setup(config)
|
17
|
-
Lograge::Sql.formatter
|
18
|
-
Lograge::Sql.extract_event
|
19
|
+
Lograge::Sql.formatter = config.formatter || default_formatter
|
20
|
+
Lograge::Sql.extract_event = config.extract_event || default_extract_event
|
21
|
+
Lograge::Sql.min_duration_ms = config.min_duration_ms || 0
|
19
22
|
|
20
23
|
# Disable existing ActiveRecord logging
|
21
|
-
unless config.keep_default_active_record_log
|
22
|
-
ActiveSupport::LogSubscriber.log_subscribers.each do |subscriber|
|
23
|
-
Lograge.unsubscribe(:active_record, subscriber) if subscriber.is_a?(ActiveRecord::LogSubscriber)
|
24
|
-
end
|
25
|
-
end
|
24
|
+
unsubscribe_log_subscribers unless config.keep_default_active_record_log
|
26
25
|
|
27
26
|
return unless defined?(Lograge::ActiveRecordLogSubscriber)
|
28
27
|
|
@@ -51,6 +50,12 @@ module Lograge
|
|
51
50
|
"#{event.payload[:name]} (#{event.duration.to_f.round(2)}) #{event.payload[:sql]}"
|
52
51
|
end
|
53
52
|
end
|
53
|
+
|
54
|
+
def unsubscribe_log_subscribers
|
55
|
+
ActiveSupport::LogSubscriber.log_subscribers.each do |subscriber|
|
56
|
+
Lograge.unsubscribe(:active_record, subscriber) if subscriber.is_a?(ActiveRecord::LogSubscriber)
|
57
|
+
end
|
58
|
+
end
|
54
59
|
end
|
55
60
|
end
|
56
61
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: lograge-sql
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 2.
|
4
|
+
version: 2.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Mattia Giuffrida
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-10-10 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: activerecord
|
@@ -19,7 +19,7 @@ dependencies:
|
|
19
19
|
version: '5'
|
20
20
|
- - "<"
|
21
21
|
- !ruby/object:Gem::Version
|
22
|
-
version: '7.
|
22
|
+
version: '7.2'
|
23
23
|
type: :runtime
|
24
24
|
prerelease: false
|
25
25
|
version_requirements: !ruby/object:Gem::Requirement
|
@@ -29,7 +29,7 @@ dependencies:
|
|
29
29
|
version: '5'
|
30
30
|
- - "<"
|
31
31
|
- !ruby/object:Gem::Version
|
32
|
-
version: '7.
|
32
|
+
version: '7.2'
|
33
33
|
- !ruby/object:Gem::Dependency
|
34
34
|
name: lograge
|
35
35
|
requirement: !ruby/object:Gem::Requirement
|