ruby_for_grafana_loki 0.0.3 → 0.0.5
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +16 -3
- data/lib/ruby_for_grafana_loki/client.rb +30 -26
- data/lib/ruby_for_grafana_loki/version.rb +1 -1
- data/lib/ruby_for_grafana_loki.rb +2 -2
- metadata +16 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: '008364bfc6b1bf0553546183972f87eb93794364317f2cc6a56b944c14a4deb8'
|
4
|
+
data.tar.gz: 00affa1f6564765b4ad1211e1c3efdae57e2e7c7202f9049e75c572772d237ec
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: af9ed24b5ba9981b6cf927928779e33b8e0129a72280acdbc673f712cd33e4c3a98292204abaf7881897635e897b459d61ba024a98cee2a9e0d2df78ec1f3d3d
|
7
|
+
data.tar.gz: d67fd43f8db4dce356f9bbcf65c6da681b330b9d8ca140aea08ccf78a30b13875c00ce0655328c41bcb8f2bd00ab3c80d704e18ead795934235c09ffe02c15aa
|
data/README.md
CHANGED
@@ -1,5 +1,18 @@
|
|
1
1
|
|
2
2
|
# Usage in your gem or application
|
3
|
-
|
4
|
-
|
5
|
-
|
3
|
+
<pre>
|
4
|
+
|
5
|
+
- add gem "ruby_for_grafana_loki-0.0.5.gem" //to the Gemfile
|
6
|
+
- bundle install
|
7
|
+
|
8
|
+
in the project:
|
9
|
+
- logs_type = %w(ERROR WARN FATAL) // Use custom logs type: ERROR, WARN, FATAL, INFO, DEBUG
|
10
|
+
- log_file_path = "log/#{Rails.env}.log"
|
11
|
+
- client = RubyForGrafanaLoki.client(log_file_path, logs_type)
|
12
|
+
- client.jobName = "job name" // your job name
|
13
|
+
- client.hostName = "host name" // your host name
|
14
|
+
- client.sourceName = "source name" // your source name
|
15
|
+
- client.send_all_logs
|
16
|
+
- client.send_log("This is a test log message.")
|
17
|
+
|
18
|
+
</pre>
|
@@ -1,37 +1,46 @@
|
|
1
1
|
module RubyForGrafanaLoki
|
2
|
+
LOGS_TYPE = %w(ERROR WARN FATAL INFO DEBUG).freeze
|
2
3
|
class Client
|
3
4
|
include RubyForGrafanaLoki::Request
|
4
5
|
|
5
|
-
|
6
|
+
attr_accessor :job_name
|
7
|
+
attr_accessor :host_name
|
8
|
+
attr_accessor :source_name
|
9
|
+
|
10
|
+
def initialize(log_file_path, allowed_logs_type = LOGS_TYPE)
|
6
11
|
@log_file_path = log_file_path
|
12
|
+
@allowed_logs_type = allowed_logs_type
|
13
|
+
@job_name = "job_name"
|
14
|
+
@host_name = "host_name"
|
15
|
+
@source_name = "source_name"
|
7
16
|
end
|
8
17
|
|
9
18
|
def send_all_logs
|
10
19
|
File.open(@log_file_path, 'r') do |file|
|
11
20
|
file.each_line do |line|
|
12
|
-
send_log(line)
|
21
|
+
send_log(line) if match_logs_type?(line)
|
13
22
|
end
|
14
23
|
end
|
15
24
|
end
|
25
|
+
|
16
26
|
def send_log(log_message)
|
17
27
|
curr_datetime = Time.now.to_i * 1_000_000_000
|
18
28
|
|
19
|
-
|
20
|
-
msg = "On server #{host} detected error"
|
29
|
+
msg = "On server #{@host_name} detected error"
|
21
30
|
|
22
31
|
payload = {
|
23
|
-
|
32
|
+
'streams' => [
|
24
33
|
{
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
34
|
+
'stream' => {
|
35
|
+
'source' => @source_name,
|
36
|
+
'job' => @job_name,
|
37
|
+
'host' => @host_name
|
29
38
|
},
|
30
|
-
|
31
|
-
|
39
|
+
'values' => [[curr_datetime.to_s, log_message]],
|
40
|
+
'entries' => [
|
32
41
|
{
|
33
|
-
|
34
|
-
|
42
|
+
'ts' => curr_datetime,
|
43
|
+
'line' => "[WARN] " + msg
|
35
44
|
}
|
36
45
|
]
|
37
46
|
}
|
@@ -41,21 +50,16 @@ module RubyForGrafanaLoki
|
|
41
50
|
json_payload = JSON.generate(payload)
|
42
51
|
uri = '/loki/api/v1/push'
|
43
52
|
|
44
|
-
# Use logger for sending logs to both default logger and Loki
|
45
|
-
# @logger.info "Sending log to Loki: #{json_payload}"
|
46
|
-
|
47
|
-
# Send logs to Loki using the post method
|
48
53
|
post(uri, json_payload)
|
49
54
|
end
|
55
|
+
|
56
|
+
private
|
57
|
+
|
58
|
+
def match_logs_type?(log_line)
|
59
|
+
type = log_line.match(/(ERROR|WARN|FATAL|INFO|DEBUG)/)&.to_s
|
60
|
+
|
61
|
+
@allowed_logs_type.include?(type)
|
62
|
+
end
|
50
63
|
end
|
51
64
|
end
|
52
65
|
|
53
|
-
|
54
|
-
# # In your application code
|
55
|
-
#
|
56
|
-
# # Example with Rails logger
|
57
|
-
# rails_logger = Logger.new(STDOUT)
|
58
|
-
# client = RubyForGrafanaLoki.client(rails_logger)
|
59
|
-
#
|
60
|
-
# # Send a log entry to Loki
|
61
|
-
# client.send_log("This is a log message.")
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: ruby_for_grafana_loki
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.5
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Oleg Ten
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-12-
|
11
|
+
date: 2023-12-06 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: faraday
|
@@ -38,6 +38,20 @@ dependencies:
|
|
38
38
|
- - "~>"
|
39
39
|
- !ruby/object:Gem::Version
|
40
40
|
version: '2.4'
|
41
|
+
- !ruby/object:Gem::Dependency
|
42
|
+
name: rspec
|
43
|
+
requirement: !ruby/object:Gem::Requirement
|
44
|
+
requirements:
|
45
|
+
- - ">="
|
46
|
+
- !ruby/object:Gem::Version
|
47
|
+
version: '0'
|
48
|
+
type: :runtime
|
49
|
+
prerelease: false
|
50
|
+
version_requirements: !ruby/object:Gem::Requirement
|
51
|
+
requirements:
|
52
|
+
- - ">="
|
53
|
+
- !ruby/object:Gem::Version
|
54
|
+
version: '0'
|
41
55
|
description: Attempt to make gem
|
42
56
|
email:
|
43
57
|
- tennet0505@gmail.com
|