opentelemetry-instrumentation-redis 0.13.0 → 0.18.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 0a5cd190659e00aace1df688dce3ac8f38f2ac40d7efa19cbb5aca0806dce096
4
- data.tar.gz: 7f9caf155420b96cbd635f38ee80edef4edb2eec2be16f09ad4e3edcf50500aa
3
+ metadata.gz: b97d1d7565c42c6b2a1c5a3d351c1b289c958de50295fdc5b75bcb04dd08e90f
4
+ data.tar.gz: '0901c065c1a7cb6bd7412ea275a836b6575e2ae52096047822cc980963c187e0'
5
5
  SHA512:
6
- metadata.gz: 753997ce1412b22461cb5ab347a42aad85242643c281a0222f75a32e148c4e9a2d36befb2a926827cc2741d6d692b6528ae008c6f6f9d983b86b2d8089de7382
7
- data.tar.gz: dde075a5056b9067d8692a3fec46a8e0f48bb120526a85558210a6b80f14daeac87c6f9271b2fc452318610894dd3489f50285a3d7795dd52f6ff3176acb23a7
6
+ metadata.gz: d068fef46b939f32433777e0d2a361f8108eae305c9c019817efc67ecb86b4d147591200b6fe6699e801b1c2d3884a34c3c07f2c1816f1948e7008b60d79bbac
7
+ data.tar.gz: e15af756ab9191474be4ba2b5783158288553ca34a6563a518159825f165663bbc13260901b2bdf58abac84712db8b922bb739f6bd2712d4dc740c2634dc964f
data/CHANGELOG.md CHANGED
@@ -1,5 +1,32 @@
1
1
  # Release History: opentelemetry-instrumentation-redis
2
2
 
3
+ ### v0.18.0 / 2021-05-21
4
+
5
+ * ADDED: Updated API depedency for 1.0.0.rc1
6
+ refactor: redis attribute utils [#760](https://github.com/open-telemetry/opentelemetry-ruby/pull/760)
7
+ refactor: simplify redis attribute assignment [#758](https://github.com/open-telemetry/opentelemetry-ruby/pull/758)
8
+ test: split redis instrumentation test [#754](https://github.com/open-telemetry/opentelemetry-ruby/pull/754)
9
+ * ADDED: Option to obfuscate redis arguments
10
+ * FIXED: Instrument Redis more thoroughly by patching Client#process.
11
+
12
+ ### v0.17.0 / 2021-04-22
13
+
14
+ * (No significant changes)
15
+
16
+ ### v0.16.0 / 2021-03-17
17
+
18
+ * FIXED: Update DB semantic conventions
19
+ * FIXED: Example scripts now reference local common lib
20
+ * DOCS: Replace Gitter with GitHub Discussions
21
+
22
+ ### v0.15.0 / 2021-02-18
23
+
24
+ * ADDED: Add instrumentation config validation
25
+
26
+ ### v0.14.0 / 2021-02-03
27
+
28
+ * (No significant changes)
29
+
3
30
  ### v0.13.0 / 2021-01-29
4
31
 
5
32
  * (No significant changes)
@@ -10,13 +37,13 @@
10
37
 
11
38
  ### v0.11.0 / 2020-12-11
12
39
 
13
- * ADDED: Accept config for redis peer service attribute
14
- * ADDED: Move utf8 encoding to common utils
15
- * FIXED: Copyright comments to not reference year
40
+ * ADDED: Accept config for redis peer service attribute
41
+ * ADDED: Move utf8 encoding to common utils
42
+ * FIXED: Copyright comments to not reference year
16
43
 
17
44
  ### v0.10.1 / 2020-12-09
18
45
 
19
- * FIXED: Semantic conventions db.type -> db.system
46
+ * FIXED: Semantic conventions db.type -> db.system
20
47
 
21
48
  ### v0.10.0 / 2020-12-03
22
49
 
@@ -24,21 +51,21 @@
24
51
 
25
52
  ### v0.9.0 / 2020-11-27
26
53
 
27
- * BREAKING CHANGE: Add timeout for force_flush and shutdown
54
+ * BREAKING CHANGE: Add timeout for force_flush and shutdown
28
55
 
29
- * ADDED: Redis attribute propagation
30
- * ADDED: Add timeout for force_flush and shutdown
56
+ * ADDED: Redis attribute propagation
57
+ * ADDED: Add timeout for force_flush and shutdown
31
58
 
32
59
  ### v0.8.0 / 2020-10-27
33
60
 
34
- * BREAKING CHANGE: Remove 'canonical' from status codes
61
+ * BREAKING CHANGE: Remove 'canonical' from status codes
35
62
 
36
- * FIXED: Remove 'canonical' from status codes
63
+ * FIXED: Remove 'canonical' from status codes
37
64
 
38
65
  ### v0.7.0 / 2020-10-07
39
66
 
40
- * DOCS: Added redis documentation
41
- * DOCS: Standardize toplevel docs structure and readme
67
+ * DOCS: Added redis documentation
68
+ * DOCS: Standardize toplevel docs structure and readme
42
69
 
43
70
  ### v0.6.0 / 2020-09-10
44
71
 
data/README.md CHANGED
@@ -41,15 +41,32 @@ OpenTelemetry::Instrumentation::Redis.with_attributes('peer.service' => 'cache')
41
41
  end
42
42
  ```
43
43
 
44
+ ### Configuration options
45
+
46
+ ```ruby
47
+ OpenTelemetry::SDK.configure do |c|
48
+ c.use 'OpenTelemetry::Instrumentation::Redis', {
49
+ # The obfuscation of arguments in the db.statement attribute is enabled by default.
50
+ # To disable, set enable_statement_obfuscation to false.
51
+ enable_statement_obfuscation: true,
52
+ }
53
+ end
54
+ ```
55
+
44
56
  ## Example
45
57
 
46
58
  An example of usage can be seen in [`example/redis.rb`](https://github.com/open-telemetry/opentelemetry-ruby/blob/main/instrumentation/redis/example/redis.rb).
47
59
 
60
+ ## Development
61
+
62
+ You'll need Redis installed locally to run the test suite. Once you've
63
+ installed it, it will start and stop automatically when you run `rake`.
64
+
48
65
  ## How can I get involved?
49
66
 
50
67
  The `opentelemetry-instrumentation-redis` gem source is [on github][repo-github], along with related gems including `opentelemetry-api` and `opentelemetry-sdk`.
51
68
 
52
- The OpenTelemetry Ruby gems are maintained by the OpenTelemetry-Ruby special interest group (SIG). You can get involved by joining us on our [gitter channel][ruby-gitter] or attending our weekly meeting. See the [meeting calendar][community-meetings] for dates and times. For more information on this and other language SIGs, see the OpenTelemetry [community page][ruby-sig].
69
+ The OpenTelemetry Ruby gems are maintained by the OpenTelemetry-Ruby special interest group (SIG). You can get involved by joining us in [GitHub Discussions][discussions-url] or attending our weekly meeting. See the [meeting calendar][community-meetings] for dates and times. For more information on this and other language SIGs, see the OpenTelemetry [community page][ruby-sig].
53
70
 
54
71
  ## License
55
72
 
@@ -61,4 +78,4 @@ Apache 2.0 license. See [LICENSE][license-github] for more information.
61
78
  [license-github]: https://github.com/open-telemetry/opentelemetry-ruby/blob/main/LICENSE
62
79
  [ruby-sig]: https://github.com/open-telemetry/community#ruby-sig
63
80
  [community-meetings]: https://github.com/open-telemetry/community#community-meetings
64
- [ruby-gitter]: https://gitter.im/open-telemetry/opentelemetry-ruby
81
+ [discussions-url]: https://github.com/open-telemetry/opentelemetry-ruby/discussions
@@ -6,6 +6,7 @@
6
6
 
7
7
  require 'opentelemetry'
8
8
  require 'opentelemetry/common'
9
+ require 'opentelemetry-instrumentation-base'
9
10
 
10
11
  module OpenTelemetry
11
12
  module Instrumentation
@@ -19,10 +19,12 @@ module OpenTelemetry
19
19
  defined?(::Redis)
20
20
  end
21
21
 
22
+ option :peer_service, default: nil, validate: :string
23
+ option :enable_statement_obfuscation, default: true, validate: :boolean
24
+
22
25
  private
23
26
 
24
27
  def require_dependencies
25
- require_relative 'utils'
26
28
  require_relative 'patches/client'
27
29
  end
28
30
 
@@ -10,53 +10,73 @@ module OpenTelemetry
10
10
  module Patches
11
11
  # Module to prepend to Redis::Client for instrumentation
12
12
  module Client
13
- def call(*args, &block)
14
- response = nil
13
+ MAX_STATEMENT_LENGTH = 500
14
+ private_constant :MAX_STATEMENT_LENGTH
15
15
 
16
- attributes = client_attributes
17
- attributes['db.statement'] = Utils.format_statement(args)
18
- tracer.in_span(
19
- Utils.format_command(args),
20
- attributes: attributes,
21
- kind: :client
22
- ) do
23
- response = super(*args, &block)
24
- end
25
-
26
- response
27
- end
28
-
29
- def call_pipeline(*args, &block)
30
- response = nil
31
-
32
- attributes = client_attributes
33
- attributes['db.statement'] = Utils.format_pipeline_statement(args)
34
- tracer.in_span(
35
- 'pipeline',
36
- attributes: attributes,
37
- kind: :client
38
- ) do
39
- response = super(*args, &block)
40
- end
41
-
42
- response
43
- end
44
-
45
- private
46
-
47
- def client_attributes
16
+ def process(commands) # rubocop:disable Metrics/AbcSize, Metrics/MethodLength
48
17
  host = options[:host]
49
18
  port = options[:port]
50
19
 
51
20
  attributes = {
52
21
  'db.system' => 'redis',
53
- 'db.instance' => options[:db].to_s,
54
- 'db.url' => "redis://#{host}:#{port}",
55
22
  'net.peer.name' => host,
56
23
  'net.peer.port' => port
57
24
  }
25
+
26
+ attributes['db.redis.database_index'] = options[:db] unless options[:db].zero?
58
27
  attributes['peer.service'] = config[:peer_service] if config[:peer_service]
59
- attributes.merge(OpenTelemetry::Instrumentation::Redis.attributes)
28
+ attributes.merge!(OpenTelemetry::Instrumentation::Redis.attributes)
29
+
30
+ parsed_commands = parse_commands(commands)
31
+ parsed_commands = OpenTelemetry::Common::Utilities.truncate(parsed_commands, MAX_STATEMENT_LENGTH)
32
+ parsed_commands = OpenTelemetry::Common::Utilities.utf8_encode(parsed_commands, binary: true)
33
+ attributes['db.statement'] = parsed_commands
34
+
35
+ span_name = if commands.length == 1
36
+ commands[0][0].to_s.upcase
37
+ else
38
+ 'PIPELINED'
39
+ end
40
+
41
+ tracer.in_span(span_name, attributes: attributes, kind: :client) do |s|
42
+ super(commands).tap do |reply|
43
+ if reply.is_a?(::Redis::CommandError)
44
+ s.record_exception(reply)
45
+ s.status = Trace::Status.new(
46
+ Trace::Status::ERROR,
47
+ description: reply.message
48
+ )
49
+ end
50
+ end
51
+ end
52
+ end
53
+
54
+ private
55
+
56
+ # Examples of commands received for parsing
57
+ # Redis#queue [[[:set, "v1", "0"]], [[:incr, "v1"]], [[:get, "v1"]]]
58
+ # Redis#pipeline: [[:set, "v1", "0"], [:incr, "v1"], [:get, "v1"]]
59
+ # Redis#hmset [[:hmset, "hash", "f1", 1234567890.0987654]]
60
+ # Redis#set [[:set, "K", "x"]]
61
+ def parse_commands(commands) # rubocop:disable Metrics/AbcSize
62
+ commands.map do |command|
63
+ # We are checking for the use of Redis#queue command, if we detect the
64
+ # extra level of array nesting we return the first element so it
65
+ # can be parsed.
66
+ command = command[0] if command.is_a?(Array) && command[0].is_a?(Array)
67
+
68
+ # If we receive an authentication request command
69
+ # we want to short circuit parsing the commands
70
+ # and return the obfuscated command
71
+ return 'AUTH ?' if command[0] == :auth
72
+
73
+ command[0] = command[0].to_s.upcase
74
+ if config[:enable_statement_obfuscation]
75
+ command[0] + ' ?' * (command.size - 1)
76
+ else
77
+ command.join(' ')
78
+ end
79
+ end.join("\n")
60
80
  end
61
81
 
62
82
  def tracer
@@ -7,7 +7,7 @@
7
7
  module OpenTelemetry
8
8
  module Instrumentation
9
9
  module Redis
10
- VERSION = '0.13.0'
10
+ VERSION = '0.18.0'
11
11
  end
12
12
  end
13
13
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: opentelemetry-instrumentation-redis
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.13.0
4
+ version: 0.18.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - OpenTelemetry Authors
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2021-01-30 00:00:00.000000000 Z
11
+ date: 2021-05-21 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: opentelemetry-api
@@ -16,70 +16,70 @@ dependencies:
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: 0.13.0
19
+ version: 1.0.0.rc1
20
20
  type: :runtime
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - "~>"
25
25
  - !ruby/object:Gem::Version
26
- version: 0.13.0
26
+ version: 1.0.0.rc1
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: opentelemetry-common
29
29
  requirement: !ruby/object:Gem::Requirement
30
30
  requirements:
31
31
  - - "~>"
32
32
  - !ruby/object:Gem::Version
33
- version: 0.13.0
33
+ version: 0.18.0
34
34
  type: :runtime
35
35
  prerelease: false
36
36
  version_requirements: !ruby/object:Gem::Requirement
37
37
  requirements:
38
38
  - - "~>"
39
39
  - !ruby/object:Gem::Version
40
- version: 0.13.0
40
+ version: 0.18.0
41
41
  - !ruby/object:Gem::Dependency
42
- name: appraisal
42
+ name: opentelemetry-instrumentation-base
43
43
  requirement: !ruby/object:Gem::Requirement
44
44
  requirements:
45
45
  - - "~>"
46
46
  - !ruby/object:Gem::Version
47
- version: 2.2.0
48
- type: :development
47
+ version: 0.18.0
48
+ type: :runtime
49
49
  prerelease: false
50
50
  version_requirements: !ruby/object:Gem::Requirement
51
51
  requirements:
52
52
  - - "~>"
53
53
  - !ruby/object:Gem::Version
54
- version: 2.2.0
54
+ version: 0.18.0
55
55
  - !ruby/object:Gem::Dependency
56
- name: bundler
56
+ name: appraisal
57
57
  requirement: !ruby/object:Gem::Requirement
58
58
  requirements:
59
- - - ">="
59
+ - - "~>"
60
60
  - !ruby/object:Gem::Version
61
- version: '1.17'
61
+ version: 2.2.0
62
62
  type: :development
63
63
  prerelease: false
64
64
  version_requirements: !ruby/object:Gem::Requirement
65
65
  requirements:
66
- - - ">="
66
+ - - "~>"
67
67
  - !ruby/object:Gem::Version
68
- version: '1.17'
68
+ version: 2.2.0
69
69
  - !ruby/object:Gem::Dependency
70
- name: fakeredis
70
+ name: bundler
71
71
  requirement: !ruby/object:Gem::Requirement
72
72
  requirements:
73
- - - "~>"
73
+ - - ">="
74
74
  - !ruby/object:Gem::Version
75
- version: 0.7.0
75
+ version: '1.17'
76
76
  type: :development
77
77
  prerelease: false
78
78
  version_requirements: !ruby/object:Gem::Requirement
79
79
  requirements:
80
- - - "~>"
80
+ - - ">="
81
81
  - !ruby/object:Gem::Version
82
- version: 0.7.0
82
+ version: '1.17'
83
83
  - !ruby/object:Gem::Dependency
84
84
  name: minitest
85
85
  requirement: !ruby/object:Gem::Requirement
@@ -100,14 +100,14 @@ dependencies:
100
100
  requirements:
101
101
  - - "~>"
102
102
  - !ruby/object:Gem::Version
103
- version: '0.0'
103
+ version: 1.0.0.rc1
104
104
  type: :development
105
105
  prerelease: false
106
106
  version_requirements: !ruby/object:Gem::Requirement
107
107
  requirements:
108
108
  - - "~>"
109
109
  - !ruby/object:Gem::Version
110
- version: '0.0'
110
+ version: 1.0.0.rc1
111
111
  - !ruby/object:Gem::Dependency
112
112
  name: redis
113
113
  requirement: !ruby/object:Gem::Requirement
@@ -194,16 +194,15 @@ files:
194
194
  - lib/opentelemetry/instrumentation/redis.rb
195
195
  - lib/opentelemetry/instrumentation/redis/instrumentation.rb
196
196
  - lib/opentelemetry/instrumentation/redis/patches/client.rb
197
- - lib/opentelemetry/instrumentation/redis/utils.rb
198
197
  - lib/opentelemetry/instrumentation/redis/version.rb
199
198
  homepage: https://github.com/open-telemetry/opentelemetry-ruby
200
199
  licenses:
201
200
  - Apache-2.0
202
201
  metadata:
203
- changelog_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-redis/v0.13.0/file.CHANGELOG.html
202
+ changelog_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-redis/v0.18.0/file.CHANGELOG.html
204
203
  source_code_uri: https://github.com/open-telemetry/opentelemetry-ruby/tree/main/instrumentation/redis
205
204
  bug_tracker_uri: https://github.com/open-telemetry/opentelemetry-ruby/issues
206
- documentation_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-redis/v0.13.0
205
+ documentation_uri: https://open-telemetry.github.io/opentelemetry-ruby/opentelemetry-instrumentation-redis/v0.18.0
207
206
  post_install_message:
208
207
  rdoc_options: []
209
208
  require_paths:
@@ -219,7 +218,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
219
218
  - !ruby/object:Gem::Version
220
219
  version: '0'
221
220
  requirements: []
222
- rubygems_version: 3.1.4
221
+ rubygems_version: 3.1.6
223
222
  signing_key:
224
223
  specification_version: 4
225
224
  summary: Redis instrumentation for the OpenTelemetry framework
@@ -1,65 +0,0 @@
1
- # frozen_string_literal: true
2
-
3
- # Copyright The OpenTelemetry Authors
4
- #
5
- # SPDX-License-Identifier: Apache-2.0
6
-
7
- module OpenTelemetry
8
- module Instrumentation
9
- module Redis
10
- # Utility functions
11
- module Utils
12
- extend self
13
-
14
- PLACEHOLDER = '?'
15
- VALUE_MAX_LEN = 50
16
- CMD_MAX_LEN = 500
17
-
18
- def format_command(command_args)
19
- format_arg(resolve_command_args(command_args).first)
20
- end
21
-
22
- def format_pipeline_statement(command_args)
23
- command_args[0].commands.map do |args|
24
- format_statement(args)
25
- end.join("\n")
26
- end
27
-
28
- def format_statement(command_args)
29
- command_args = resolve_command_args(command_args)
30
- return 'AUTH ?' if auth_command?(command_args)
31
-
32
- cmd = command_args.map { |x| format_arg(x) }.join(' ')
33
- truncate(cmd, CMD_MAX_LEN)
34
- end
35
-
36
- def format_arg(arg)
37
- str = arg.is_a?(Symbol) ? arg.to_s.upcase : arg.to_s
38
- str = OpenTelemetry::Common::Utilities.utf8_encode(str, binary: true)
39
- truncate(str, VALUE_MAX_LEN)
40
- rescue StandardError => e
41
- OpenTelemetry.logger.debug("non formattable Redis arg #{str}: #{e}")
42
- PLACEHOLDER
43
- end
44
-
45
- def auth_command?(command_args)
46
- return false unless command_args.is_a?(Array) && !command_args.empty?
47
-
48
- command_args.first.to_sym == :auth
49
- end
50
-
51
- # Unwraps command array when Redis is called with the following syntax:
52
- # redis.call([:cmd, 'arg1', ...])
53
- def resolve_command_args(command_args)
54
- return command_args.first if command_args.is_a?(Array) && command_args.first.is_a?(Array)
55
-
56
- command_args
57
- end
58
-
59
- def truncate(string, size)
60
- string.size > size ? "#{string[0...size - 3]}..." : string
61
- end
62
- end
63
- end
64
- end
65
- end