-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathmain.rb
More file actions
executable file
·70 lines (60 loc) · 1.87 KB
/
main.rb
File metadata and controls
executable file
·70 lines (60 loc) · 1.87 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
#!/usr/bin/env ruby
# frozen_string_literal: true
require 'rubygems'
require 'bundler/setup'
require 'uptrace'
# Configure OpenTelemetry with sensible defaults.
# Copy your project DSN here or use UPTRACE_DSN env var.
Uptrace.configure_opentelemetry(dsn: '') do |c|
# c is an instance of OpenTelemetry::SDK::Configurator
# Set your service metadata
c.service_name = 'myservice'
c.service_version = '1.0.0'
# Add environment information
c.resource = OpenTelemetry::SDK::Resources::Resource.create(
'deployment.environment.name' => ENV.fetch('RACK_ENV', 'development')
)
end
# Ensure logs are flushed even if the program exits unexpectedly.
at_exit { OpenTelemetry.logger_provider.shutdown }
# Obtain a logger from the OpenTelemetry logger provider.
logger = OpenTelemetry.logger_provider.logger(name: 'my_app_or_gem', version: '0.1.0')
# Emit a simple info log.
logger.on_emit(
timestamp: Time.now,
severity_text: 'INFO',
body: 'Processing user request for Thuja plicata.',
attributes: {
'user.id' => 123,
'operation' => 'fetch_data',
'plant_type' => 'cedar',
'is_evergreen' => true
}
)
# Emit a warning log with different attributes.
logger.on_emit(
timestamp: Time.now,
severity_text: 'WARN',
severity_number: OpenTelemetry::Logs::SeverityNumber::SEVERITY_NUMBER_WARN,
body: 'Database connection is slow.',
attributes: {
'component' => 'database',
'latency_ms' => 500
}
)
# Emit an error log.
begin
raise StandardError, 'Failed to write to disk'
rescue StandardError => e
logger.on_emit(
timestamp: Time.now,
severity_text: 'ERROR',
severity_number: OpenTelemetry::Logs::SeverityNumber::SEVERITY_NUMBER_ERROR,
body: "An error occurred: #{e.message}",
attributes: {
'exception.type' => e.class.name,
'exception.message' => e.message,
'exception.stacktrace' => e.backtrace.join("\n")
}
)
end