instana 1.11.6 → 1.209.2
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.circleci/config.yml +263 -0
- data/.editorconfig +10 -0
- data/.github/ISSUE_TEMPLATE/bug.yml +39 -0
- data/.github/ISSUE_TEMPLATE/config.yml +5 -0
- data/.gitignore +3 -0
- data/.rubocop.yml +14 -1136
- data/.rubocop_todo.yml +1140 -0
- data/Appraisals +124 -0
- data/Gemfile +14 -32
- data/LICENSE +2 -1
- data/README.md +2 -6
- data/Rakefile +18 -49
- data/bin/console +8 -4
- data/docker-compose.yml +20 -0
- data/examples/opentracing.rb +4 -0
- data/examples/tracing.rb +4 -0
- data/extras/license_header.rb +44 -0
- data/gemfiles/.bundle/config +1 -2
- data/gemfiles/aws_30.gemfile +22 -0
- data/gemfiles/cuba_30.gemfile +18 -0
- data/gemfiles/dalli_20.gemfile +18 -0
- data/gemfiles/excon_02.gemfile +18 -0
- data/gemfiles/excon_021.gemfile +18 -0
- data/gemfiles/excon_079.gemfile +18 -0
- data/gemfiles/graphql_10.gemfile +18 -0
- data/gemfiles/grpc_10.gemfile +18 -0
- data/gemfiles/mongo_216.gemfile +18 -0
- data/gemfiles/net_http_01.gemfile +17 -0
- data/gemfiles/rack_16.gemfile +18 -0
- data/gemfiles/rack_20.gemfile +18 -0
- data/gemfiles/rails_42.gemfile +21 -0
- data/gemfiles/rails_50.gemfile +21 -0
- data/gemfiles/rails_52.gemfile +21 -0
- data/gemfiles/rails_60.gemfile +21 -0
- data/gemfiles/redis_40.gemfile +18 -0
- data/gemfiles/resque_122.gemfile +19 -0
- data/gemfiles/resque_20.gemfile +18 -0
- data/gemfiles/rest_client_16.gemfile +18 -0
- data/gemfiles/rest_client_20.gemfile +18 -0
- data/gemfiles/roda_20.gemfile +18 -0
- data/gemfiles/roda_30.gemfile +18 -0
- data/gemfiles/shoryuken_50.gemfile +19 -0
- data/gemfiles/sidekiq_42.gemfile +18 -0
- data/gemfiles/sidekiq_50.gemfile +18 -0
- data/gemfiles/sinatra_14.gemfile +18 -0
- data/instana.gemspec +8 -14
- data/lib/instana/activator.rb +58 -0
- data/lib/instana/activators/action_cable.rb +24 -0
- data/lib/instana/activators/action_controller_api.rb +21 -0
- data/lib/instana/activators/action_controller_base.rb +21 -0
- data/lib/instana/activators/action_mailer.rb +22 -0
- data/lib/instana/activators/action_view.rb +21 -0
- data/lib/instana/activators/active_job.rb +21 -0
- data/lib/instana/activators/active_record.rb +21 -0
- data/lib/instana/activators/aws_sdk_dynamodb.rb +20 -0
- data/lib/instana/activators/aws_sdk_lambda.rb +20 -0
- data/lib/instana/activators/aws_sdk_s3.rb +20 -0
- data/lib/instana/activators/aws_sdk_sns.rb +20 -0
- data/lib/instana/activators/aws_sdk_sqs.rb +20 -0
- data/lib/instana/activators/cuba.rb +21 -0
- data/lib/instana/activators/dalli.rb +23 -0
- data/lib/instana/activators/excon.rb +20 -0
- data/lib/instana/activators/graphql.rb +22 -0
- data/lib/instana/activators/grpc_client.rb +20 -0
- data/lib/instana/activators/grpc_server.rb +20 -0
- data/lib/instana/activators/mongo.rb +23 -0
- data/lib/instana/activators/net_http.rb +20 -0
- data/lib/instana/activators/rack.rb +16 -0
- data/lib/instana/activators/rails.rb +18 -0
- data/lib/instana/activators/redis.rb +20 -0
- data/lib/instana/activators/resque_client.rb +21 -0
- data/lib/instana/activators/resque_worker.rb +32 -0
- data/lib/instana/activators/rest_client.rb +20 -0
- data/lib/instana/activators/roda.rb +21 -0
- data/lib/instana/activators/shoryuken.rb +24 -0
- data/lib/instana/activators/sidekiq_client.rb +24 -0
- data/lib/instana/activators/sidekiq_worker.rb +24 -0
- data/lib/instana/activators/sinatra.rb +21 -0
- data/lib/instana/backend/agent.rb +68 -0
- data/lib/instana/backend/gc_snapshot.rb +41 -0
- data/lib/instana/backend/host_agent.rb +83 -0
- data/lib/instana/backend/host_agent_activation_observer.rb +99 -0
- data/lib/instana/backend/host_agent_lookup.rb +57 -0
- data/lib/instana/backend/host_agent_reporting_observer.rb +129 -0
- data/lib/instana/backend/process_info.rb +72 -0
- data/lib/instana/backend/request_client.rb +74 -0
- data/lib/instana/backend/serverless_agent.rb +116 -0
- data/lib/instana/base.rb +15 -29
- data/lib/instana/config.rb +31 -23
- data/lib/instana/frameworks/cuba.rb +32 -3
- data/lib/instana/frameworks/rails.rb +22 -32
- data/lib/instana/frameworks/roda.rb +41 -3
- data/lib/instana/frameworks/sinatra.rb +16 -3
- data/lib/instana/instrumentation/action_cable.rb +53 -0
- data/lib/instana/instrumentation/action_controller.rb +84 -0
- data/lib/instana/instrumentation/action_mailer.rb +22 -0
- data/lib/instana/instrumentation/action_view.rb +30 -0
- data/lib/instana/instrumentation/active_job.rb +52 -0
- data/lib/instana/instrumentation/active_record.rb +50 -0
- data/lib/instana/instrumentation/aws_sdk_dynamodb.rb +48 -0
- data/lib/instana/instrumentation/aws_sdk_lambda.rb +37 -0
- data/lib/instana/instrumentation/aws_sdk_s3.rb +55 -0
- data/lib/instana/instrumentation/aws_sdk_sns.rb +29 -0
- data/lib/instana/instrumentation/aws_sdk_sqs.rb +98 -0
- data/lib/instana/instrumentation/dalli.rb +10 -18
- data/lib/instana/instrumentation/excon.rb +73 -61
- data/lib/instana/instrumentation/graphql.rb +78 -0
- data/lib/instana/instrumentation/grpc.rb +73 -66
- data/lib/instana/instrumentation/instrumented_request.rb +190 -0
- data/lib/instana/instrumentation/mongo.rb +46 -0
- data/lib/instana/instrumentation/net-http.rb +54 -44
- data/lib/instana/instrumentation/rack.rb +57 -48
- data/lib/instana/instrumentation/redis.rb +13 -18
- data/lib/instana/instrumentation/resque.rb +28 -51
- data/lib/instana/instrumentation/rest-client.rb +5 -17
- data/lib/instana/instrumentation/shoryuken.rb +44 -0
- data/lib/instana/instrumentation/sidekiq-client.rb +4 -10
- data/lib/instana/instrumentation/sidekiq-worker.rb +4 -10
- data/lib/instana/instrumented_logger.rb +26 -0
- data/lib/instana/logger_delegator.rb +31 -0
- data/lib/instana/open_tracing/carrier.rb +7 -0
- data/lib/instana/open_tracing/instana_tracer.rb +99 -0
- data/lib/instana/rack.rb +4 -0
- data/lib/instana/secrets.rb +59 -0
- data/lib/instana/serverless.rb +160 -0
- data/lib/instana/setup.rb +36 -12
- data/lib/instana/snapshot/deltable.rb +25 -0
- data/lib/instana/snapshot/docker_container.rb +151 -0
- data/lib/instana/snapshot/fargate_container.rb +88 -0
- data/lib/instana/snapshot/fargate_process.rb +67 -0
- data/lib/instana/snapshot/fargate_task.rb +72 -0
- data/lib/instana/snapshot/google_cloud_run_instance.rb +69 -0
- data/lib/instana/snapshot/google_cloud_run_process.rb +58 -0
- data/lib/instana/snapshot/lambda_function.rb +39 -0
- data/lib/instana/snapshot/ruby_process.rb +48 -0
- data/lib/instana/tracer.rb +42 -148
- data/lib/instana/tracing/processor.rb +48 -21
- data/lib/instana/tracing/span.rb +70 -61
- data/lib/instana/tracing/span_context.rb +34 -2
- data/lib/instana/util.rb +25 -137
- data/lib/instana/version.rb +4 -1
- data/lib/instana.rb +12 -2
- data/lib/opentracing.rb +29 -3
- data/sonar-project.properties +9 -0
- data/test/activator_test.rb +30 -0
- data/test/backend/agent_test.rb +80 -0
- data/test/backend/gc_snapshot_test.rb +11 -0
- data/test/backend/host_agent_activation_observer_test.rb +73 -0
- data/test/backend/host_agent_lookup_test.rb +78 -0
- data/test/backend/host_agent_reporting_observer_test.rb +274 -0
- data/test/backend/host_agent_test.rb +57 -0
- data/test/backend/process_info_test.rb +83 -0
- data/test/backend/request_client_test.rb +39 -0
- data/test/backend/serverless_agent_test.rb +83 -0
- data/test/benchmarks/bench_id_generation.rb +3 -0
- data/test/benchmarks/bench_opentracing.rb +3 -0
- data/test/config_test.rb +11 -14
- data/test/frameworks/cuba_test.rb +44 -30
- data/test/frameworks/roda_test.rb +46 -30
- data/test/frameworks/sinatra_test.rb +52 -30
- data/test/instana_test.rb +14 -4
- data/test/instrumentation/aws_test.rb +196 -0
- data/test/instrumentation/dalli_test.rb +3 -0
- data/test/instrumentation/excon_test.rb +20 -3
- data/test/instrumentation/graphql_test.rb +119 -0
- data/test/instrumentation/grpc_test.rb +6 -2
- data/test/instrumentation/mongo_test.rb +37 -0
- data/test/instrumentation/{net-http_test.rb → net_http_test.rb} +40 -0
- data/test/instrumentation/rack_instrumented_request_test.rb +151 -0
- data/test/instrumentation/rack_test.rb +404 -0
- data/test/instrumentation/rails_action_cable_test.rb +131 -0
- data/test/{frameworks/rails/actioncontroller_test.rb → instrumentation/rails_action_controller_test.rb} +48 -17
- data/test/instrumentation/rails_action_mailer_test.rb +37 -0
- data/test/instrumentation/rails_action_view_test.rb +151 -0
- data/test/instrumentation/rails_active_job_test.rb +65 -0
- data/test/instrumentation/rails_active_record_database_missing_test.rb +43 -0
- data/test/instrumentation/rails_active_record_test.rb +115 -0
- data/test/instrumentation/redis_test.rb +13 -0
- data/test/instrumentation/resque_test.rb +63 -17
- data/test/instrumentation/{rest-client_test.rb → rest_client_test.rb} +9 -0
- data/test/instrumentation/shoryuken_test.rb +47 -0
- data/test/instrumentation/sidekiq-client_test.rb +4 -0
- data/test/instrumentation/sidekiq-worker_test.rb +4 -0
- data/test/secrets_test.rb +112 -0
- data/test/serverless_test.rb +369 -0
- data/test/snapshot/deltable_test.rb +17 -0
- data/test/snapshot/docker_container_test.rb +82 -0
- data/test/snapshot/fargate_container_test.rb +82 -0
- data/test/snapshot/fargate_process_test.rb +35 -0
- data/test/snapshot/fargate_task_test.rb +49 -0
- data/test/snapshot/google_cloud_run_instance_test.rb +74 -0
- data/test/snapshot/google_cloud_run_process_test.rb +33 -0
- data/test/snapshot/lambda_function_test.rb +37 -0
- data/test/snapshot/ruby_process_test.rb +14 -0
- data/test/support/apps/active_record/active_record.rb +24 -0
- data/test/{servers/grpc_50051.rb → support/apps/grpc/boot.rb} +4 -1
- data/test/{apps → support/apps/grpc}/grpc_server.rb +3 -0
- data/test/{servers/rackapp_6511.rb → support/apps/http_endpoint/boot.rb} +3 -0
- data/test/{servers/rails_3205.rb → support/apps/rails/boot.rb} +10 -13
- data/test/{models → support/apps/rails/models}/block.rb +4 -1
- data/test/{models → support/apps/rails/models}/block6.rb +3 -0
- data/test/support/apps/resque/boot.rb +5 -0
- data/test/{jobs → support/apps/resque/jobs}/resque_error_job.rb +3 -3
- data/test/{jobs → support/apps/resque/jobs}/resque_fast_job.rb +6 -3
- data/test/support/apps/sidekiq/boot.rb +25 -0
- data/test/{jobs → support/apps/sidekiq/jobs}/sidekiq_job_1.rb +3 -0
- data/test/{jobs → support/apps/sidekiq/jobs}/sidekiq_job_2.rb +3 -0
- data/test/{servers → support/apps}/sidekiq/worker.rb +5 -2
- data/test/support/helpers.rb +97 -0
- data/test/support/mock_timer.rb +20 -0
- data/test/test_helper.rb +49 -145
- data/test/tracing/custom_test.rb +4 -4
- data/test/tracing/id_management_test.rb +13 -63
- data/test/tracing/instrumented_logger_test.rb +39 -0
- data/test/tracing/opentracing_test.rb +21 -5
- data/test/tracing/processor_test.rb +58 -0
- data/test/tracing/span_context_test.rb +22 -0
- data/test/tracing/span_test.rb +165 -0
- data/test/tracing/tracer_async_test.rb +32 -0
- data/test/tracing/tracer_test.rb +113 -14
- data/test/util_test.rb +10 -0
- metadata +249 -160
- data/.travis.yml +0 -43
- data/Dockerfile +0 -16
- data/benchmarks/10k-rack-traces.rb +0 -92
- data/benchmarks/Gemfile +0 -7
- data/benchmarks/Gemfile.lock +0 -38
- data/benchmarks/id_generation.rb +0 -12
- data/benchmarks/opentracing.rb +0 -26
- data/benchmarks/rack_vanilla_vs_traced.rb +0 -85
- data/benchmarks/stackprof_rack_tracing.rb +0 -77
- data/benchmarks/time_processing.rb +0 -12
- data/gemfiles/libraries.gemfile +0 -71
- data/gemfiles/rails32.gemfile +0 -51
- data/gemfiles/rails42.gemfile +0 -50
- data/gemfiles/rails50.gemfile +0 -52
- data/gemfiles/rails52.gemfile +0 -52
- data/gemfiles/rails60.gemfile +0 -72
- data/lib/instana/agent/helpers.rb +0 -84
- data/lib/instana/agent/hooks.rb +0 -41
- data/lib/instana/agent/tasks.rb +0 -48
- data/lib/instana/agent.rb +0 -499
- data/lib/instana/collector.rb +0 -116
- data/lib/instana/collectors/gc.rb +0 -57
- data/lib/instana/collectors/memory.rb +0 -34
- data/lib/instana/collectors/thread.rb +0 -30
- data/lib/instana/eum/eum-test.js.erb +0 -17
- data/lib/instana/eum/eum.js.erb +0 -17
- data/lib/instana/frameworks/instrumentation/abstract_mysql_adapter.rb +0 -58
- data/lib/instana/frameworks/instrumentation/action_controller.rb +0 -183
- data/lib/instana/frameworks/instrumentation/action_view.rb +0 -43
- data/lib/instana/frameworks/instrumentation/active_record.rb +0 -27
- data/lib/instana/frameworks/instrumentation/mysql2_adapter.rb +0 -81
- data/lib/instana/frameworks/instrumentation/mysql_adapter.rb +0 -56
- data/lib/instana/frameworks/instrumentation/postgresql_adapter.rb +0 -85
- data/lib/instana/helpers.rb +0 -44
- data/lib/instana/instrumentation.rb +0 -25
- data/lib/instana/opentracing/carrier.rb +0 -4
- data/lib/instana/opentracing/tracer.rb +0 -18
- data/lib/instana/test.rb +0 -42
- data/lib/instana/thread_local.rb +0 -15
- data/lib/oj_check.rb +0 -16
- data/test/agent/agent_test.rb +0 -148
- data/test/apps/cuba.rb +0 -15
- data/test/apps/roda.rb +0 -10
- data/test/apps/sinatra.rb +0 -5
- data/test/frameworks/rack_test.rb +0 -200
- data/test/frameworks/rails/actionview3_test.rb +0 -210
- data/test/frameworks/rails/actionview4_test.rb +0 -208
- data/test/frameworks/rails/actionview5_test.rb +0 -221
- data/test/frameworks/rails/activerecord_test.rb +0 -227
- data/test/servers/helpers/sidekiq_worker_initializer.rb +0 -27
- data/test/tracing/trace_test.rb +0 -67
data/gemfiles/rails60.gemfile
DELETED
@@ -1,72 +0,0 @@
|
|
1
|
-
source 'https://rubygems.org'
|
2
|
-
git_source(:github) { |repo| "https://github.com/#{repo}.git" }
|
3
|
-
|
4
|
-
# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
|
5
|
-
gem 'rails', '~> 6.0.2', '>= 6.0.2.1'
|
6
|
-
# Use sqlite3 as the database for Active Record
|
7
|
-
gem 'sqlite3', '~> 1.4'
|
8
|
-
# Use Puma as the app server
|
9
|
-
gem 'puma', '~> 4.1'
|
10
|
-
# Use SCSS for stylesheets
|
11
|
-
gem 'sass-rails', '>= 6'
|
12
|
-
# Transpile app-like JavaScript. Read more: https://github.com/rails/webpacker
|
13
|
-
gem 'webpacker', '~> 4.0'
|
14
|
-
# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks
|
15
|
-
gem 'turbolinks', '~> 5'
|
16
|
-
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
|
17
|
-
gem 'jbuilder', '~> 2.7'
|
18
|
-
# Use Redis adapter to run Action Cable in production
|
19
|
-
# gem 'redis', '~> 4.0'
|
20
|
-
# Use Active Model has_secure_password
|
21
|
-
# gem 'bcrypt', '~> 3.1.7'
|
22
|
-
|
23
|
-
gem 'mysql2', '0.4.10'
|
24
|
-
|
25
|
-
# Use Active Storage variant
|
26
|
-
# gem 'image_processing', '~> 1.2'
|
27
|
-
|
28
|
-
# Reduces boot times through caching; required in config/boot.rb
|
29
|
-
gem 'bootsnap', '>= 1.4.2', require: false
|
30
|
-
|
31
|
-
group :development, :test do
|
32
|
-
# Call 'byebug' anywhere in the code to stop execution and get a debugger console
|
33
|
-
gem 'byebug', platforms: [:mri, :mingw, :x64_mingw]
|
34
|
-
end
|
35
|
-
|
36
|
-
group :development do
|
37
|
-
# Access an interactive console on exception pages or by calling 'console' anywhere in the code.
|
38
|
-
gem 'web-console', '>= 3.3.0'
|
39
|
-
gem 'listen', '>= 3.0.5', '< 3.2'
|
40
|
-
# Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
|
41
|
-
gem 'spring'
|
42
|
-
gem 'spring-watcher-listen', '~> 2.0.0'
|
43
|
-
end
|
44
|
-
|
45
|
-
group :test do
|
46
|
-
# Adds support for Capybara system testing and selenium driver
|
47
|
-
gem 'capybara', '>= 2.15'
|
48
|
-
gem 'selenium-webdriver'
|
49
|
-
# Easy installation and use of web drivers to run system tests with browsers
|
50
|
-
gem 'webdrivers'
|
51
|
-
end
|
52
|
-
|
53
|
-
group :development, :test do
|
54
|
-
gem 'rake'
|
55
|
-
gem 'minitest', '5.9.1'
|
56
|
-
gem 'minitest-reporters'
|
57
|
-
gem 'minitest-debugger', :require => false
|
58
|
-
gem 'rack-test'
|
59
|
-
gem 'webmock'
|
60
|
-
# public_suffix dropped support for Ruby 2.1 and earlier.
|
61
|
-
gem 'public_suffix', '< 3.0'
|
62
|
-
end
|
63
|
-
|
64
|
-
|
65
|
-
# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
|
66
|
-
gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]
|
67
|
-
|
68
|
-
# Include the Instana Ruby gem's base set of gems
|
69
|
-
gemspec :path => File.expand_path(File.dirname(__FILE__) + '/../')
|
70
|
-
|
71
|
-
|
72
|
-
# vim:syntax=ruby
|
@@ -1,84 +0,0 @@
|
|
1
|
-
module AgentHelpers
|
2
|
-
# Attempts to determine if we're running inside a container.
|
3
|
-
# The qualifications are:
|
4
|
-
# 1. Linux based OS
|
5
|
-
# 2. /proc/self/cpuset exists and contents include a container id
|
6
|
-
def running_in_container?
|
7
|
-
return false unless @is_linux
|
8
|
-
|
9
|
-
cpuset_contents = get_cpuset_contents
|
10
|
-
|
11
|
-
if cpuset_contents.nil? or cpuset_contents == '/'
|
12
|
-
::Instana.logger.debug "running_in_container? == no"
|
13
|
-
return false
|
14
|
-
end
|
15
|
-
::Instana.logger.debug "running_in_container? == yes"
|
16
|
-
true
|
17
|
-
end
|
18
|
-
|
19
|
-
# Attempts to determine the true process ID by querying the
|
20
|
-
# /proc/<pid>/sched file. This works on linux currently.
|
21
|
-
#
|
22
|
-
def get_sched_pid
|
23
|
-
sched_file = "/proc/self/sched"
|
24
|
-
pid = Process.pid
|
25
|
-
|
26
|
-
if File.exist?(sched_file)
|
27
|
-
v = File.open(sched_file, &:readline)
|
28
|
-
pid = v.match(/\d+/).to_s.to_i
|
29
|
-
end
|
30
|
-
pid
|
31
|
-
end
|
32
|
-
|
33
|
-
# Open and read /proc/<pid>/cpuset and return as a string. Used as
|
34
|
-
# part of the announce payload for process differentiation.
|
35
|
-
#
|
36
|
-
def get_cpuset_contents
|
37
|
-
cpuset_file = "/proc/#{Process.pid}/cpuset"
|
38
|
-
contents = ""
|
39
|
-
|
40
|
-
if File.exist?(cpuset_file)
|
41
|
-
contents = File.open(cpuset_file, "r").read
|
42
|
-
end
|
43
|
-
contents.chomp
|
44
|
-
rescue Exception => e
|
45
|
-
Instana.logger.debug { "#{__method__}:#{File.basename(__FILE__)}:#{__LINE__}: #{e.message}" }
|
46
|
-
return nil
|
47
|
-
end
|
48
|
-
|
49
|
-
# Returns the PID that we are reporting to
|
50
|
-
#
|
51
|
-
def report_pid
|
52
|
-
@process[:report_pid]
|
53
|
-
end
|
54
|
-
|
55
|
-
# Determine whether the pid has changed since Agent start.
|
56
|
-
#
|
57
|
-
# @ return [Boolean] true or false to indicate if forked
|
58
|
-
#
|
59
|
-
def forked?
|
60
|
-
@process[:pid] != Process.pid
|
61
|
-
end
|
62
|
-
|
63
|
-
# Indicates if the agent is ready to send metrics
|
64
|
-
# and/or data.
|
65
|
-
#
|
66
|
-
def ready?
|
67
|
-
# In test, we're always ready :-)
|
68
|
-
return true if ENV.key?('INSTANA_TEST')
|
69
|
-
|
70
|
-
# Occasionally Run Fork detection
|
71
|
-
if rand(10) > 8
|
72
|
-
if !@is_resque_worker && (@process[:pid] != Process.pid)
|
73
|
-
::Instana.logger.debug "Instana: detected fork. (this pid: #{Process.pid}/#{Process.ppid}) Calling after_fork"
|
74
|
-
after_fork
|
75
|
-
end
|
76
|
-
end
|
77
|
-
|
78
|
-
@state == :ready || @state == :announced
|
79
|
-
rescue => e
|
80
|
-
Instana.logger.debug { "#{__method__}:#{File.basename(__FILE__)}:#{__LINE__}: #{e.message}" }
|
81
|
-
Instana.logger.debug { e.backtrace.join("\r\n") } unless ENV.key?('INSTANA_TEST')
|
82
|
-
return false
|
83
|
-
end
|
84
|
-
end
|
data/lib/instana/agent/hooks.rb
DELETED
@@ -1,41 +0,0 @@
|
|
1
|
-
module AgentHooks
|
2
|
-
# Used post fork to re-initialize state and restart communications with
|
3
|
-
# the host agent.
|
4
|
-
#
|
5
|
-
def after_fork
|
6
|
-
::Instana.logger.debug "after_fork hook called. Falling back to unannounced state and spawning a new background agent thread."
|
7
|
-
|
8
|
-
@timers.cancel
|
9
|
-
|
10
|
-
# Reseed the random number generator for this
|
11
|
-
# new thread.
|
12
|
-
srand
|
13
|
-
|
14
|
-
transition_to(:unannounced)
|
15
|
-
|
16
|
-
setup
|
17
|
-
spawn_background_thread
|
18
|
-
end
|
19
|
-
|
20
|
-
def before_resque_fork
|
21
|
-
::Instana.logger.debug "before_resque_fork hook called. pid/ppid: #{Process.pid}/#{Process.ppid}"
|
22
|
-
@is_resque_worker = true
|
23
|
-
end
|
24
|
-
|
25
|
-
def after_resque_fork
|
26
|
-
::Instana.logger.debug "after_resque_fork hook called. pid/ppid: #{Process.pid}/#{Process.ppid}"
|
27
|
-
|
28
|
-
@timers.cancel
|
29
|
-
|
30
|
-
# Reseed the random number generator for this
|
31
|
-
# new thread.
|
32
|
-
srand
|
33
|
-
|
34
|
-
::Instana.config[:metrics][:enabled] = false
|
35
|
-
|
36
|
-
@process[:pid] = Process.pid
|
37
|
-
|
38
|
-
setup
|
39
|
-
spawn_background_thread
|
40
|
-
end
|
41
|
-
end
|
data/lib/instana/agent/tasks.rb
DELETED
@@ -1,48 +0,0 @@
|
|
1
|
-
module AgentTasks
|
2
|
-
# When request(s) are received by the host agent, it is sent here
|
3
|
-
# for handling & processing.
|
4
|
-
#
|
5
|
-
# @param json_string [String] the requests from the host agent
|
6
|
-
#
|
7
|
-
|
8
|
-
OJ_OPTIONS = {mode: :strict}
|
9
|
-
|
10
|
-
def handle_agent_tasks(json_string)
|
11
|
-
tasks = Oj.load(json_string, OJ_OPTIONS)
|
12
|
-
|
13
|
-
if tasks.is_a?(Hash)
|
14
|
-
process_agent_task(tasks)
|
15
|
-
elsif tasks.is_a?(Array)
|
16
|
-
tasks.each do |t|
|
17
|
-
process_agent_task(t)
|
18
|
-
end
|
19
|
-
end
|
20
|
-
end
|
21
|
-
|
22
|
-
# Process a task sent from the host agent.
|
23
|
-
#
|
24
|
-
# @param task [String] the request json from the host agent
|
25
|
-
#
|
26
|
-
def process_agent_task(task)
|
27
|
-
if task.key?("action")
|
28
|
-
if task["action"] == "ruby.source"
|
29
|
-
payload = ::Instana::Util.get_rb_source(task["args"]["file"])
|
30
|
-
else
|
31
|
-
payload = { :error => "Unrecognized action: #{task["action"]}. An newer Instana gem may be required for this. Current version: #{::Instana::VERSION}" }
|
32
|
-
end
|
33
|
-
else
|
34
|
-
payload = { :error => "Instana Ruby: No action specified in request." }
|
35
|
-
end
|
36
|
-
|
37
|
-
path = "com.instana.plugin.ruby/response.#{@process[:report_pid]}?messageId=#{URI.encode(task['messageId'])}"
|
38
|
-
uri = URI.parse("http://#{@discovered[:agent_host]}:#{@discovered[:agent_port]}/#{path}")
|
39
|
-
req = Net::HTTP::Post.new(uri)
|
40
|
-
req.body = Oj.dump(payload, OJ_OPTIONS)
|
41
|
-
::Instana.logger.debug "Responding to agent request: #{req.inspect}"
|
42
|
-
make_host_agent_request(req)
|
43
|
-
|
44
|
-
rescue StandardError => e
|
45
|
-
Instana.logger.debug { "#{__method__}:#{File.basename(__FILE__)}:#{__LINE__}: #{e.message}" }
|
46
|
-
Instana.logger.debug { e.backtrace.join("\r\n") }
|
47
|
-
end
|
48
|
-
end
|