Commit 4c3a3cc2 authored by Matthias Kaeppler's avatar Matthias Kaeppler

Rescue from and log startup errors in exporters

This brings back code we had removed in
https://gitlab.com/gitlab-org/gitlab/-/merge_requests/74625

It also streamlines the logging implementation somewhat
and recovers from errors in the daemon startup routine.
parent b89aad23
...@@ -11,28 +11,26 @@ module Gitlab ...@@ -11,28 +11,26 @@ module Gitlab
attr_accessor :readiness_checks attr_accessor :readiness_checks
def initialize(settings, **options) def initialize(settings, log_enabled:, log_file:, **options)
super(**options) super(**options)
@settings = settings @settings = settings
# log_enabled does not exist for all exporters
log_sink = log_enabled ? File.join(Rails.root, 'log', log_file) : File::NULL
@logger = WEBrick::Log.new(log_sink)
@logger.time_format = "[%Y-%m-%dT%H:%M:%S.%L%z]"
end end
def enabled? def enabled?
settings.enabled settings.enabled
end end
def log_filename
raise NotImplementedError
end
private private
attr_reader :settings attr_reader :settings, :logger
def start_working def start_working
logger = WEBrick::Log.new(log_filename)
logger.time_format = "[%Y-%m-%dT%H:%M:%S.%L%z]"
access_log = [ access_log = [
[logger, WEBrick::AccessLog::COMBINED_LOG_FORMAT] [logger, WEBrick::AccessLog::COMBINED_LOG_FORMAT]
] ]
...@@ -44,6 +42,9 @@ module Gitlab ...@@ -44,6 +42,9 @@ module Gitlab
server.mount '/', Rack::Handler::WEBrick, rack_app server.mount '/', Rack::Handler::WEBrick, rack_app
true true
rescue StandardError => e
logger.error(e)
false
end end
def run_thread def run_thread
......
...@@ -4,12 +4,11 @@ module Gitlab ...@@ -4,12 +4,11 @@ module Gitlab
module Metrics module Metrics
module Exporter module Exporter
class SidekiqExporter < BaseExporter class SidekiqExporter < BaseExporter
def log_filename def initialize(settings, **options)
if settings['log_enabled'] super(settings,
File.join(Rails.root, 'log', 'sidekiq_exporter.log') log_enabled: settings['log_enabled'],
else log_file: 'sidekiq_exporter.log',
File::NULL **options)
end
end end
end end
end end
......
...@@ -26,8 +26,8 @@ module Gitlab ...@@ -26,8 +26,8 @@ module Gitlab
attr_reader :running attr_reader :running
# This exporter is always run on master process # This exporter is always run on master process
def initialize def initialize(**options)
super(Settings.monitoring.web_exporter) super(Settings.monitoring.web_exporter, log_enabled: true, log_file: 'web_exporter.log', **options)
# DEPRECATED: # DEPRECATED:
# these `readiness_checks` are deprecated # these `readiness_checks` are deprecated
...@@ -39,10 +39,6 @@ module Gitlab ...@@ -39,10 +39,6 @@ module Gitlab
] ]
end end
def log_filename
File.join(Rails.root, 'log', 'web_exporter.log')
end
def mark_as_not_running! def mark_as_not_running!
@running = false @running = false
end end
......
...@@ -4,13 +4,8 @@ require 'spec_helper' ...@@ -4,13 +4,8 @@ require 'spec_helper'
RSpec.describe Gitlab::Metrics::Exporter::BaseExporter do RSpec.describe Gitlab::Metrics::Exporter::BaseExporter do
let(:settings) { double('settings') } let(:settings) { double('settings') }
let(:exporter) { described_class.new(settings) } let(:log_enabled) { false }
let(:log_filename) { File.join(Rails.root, 'log', 'sidekiq_exporter.log') } let(:exporter) { described_class.new(settings, log_enabled: log_enabled, log_file: 'test_exporter.log') }
before do
allow_any_instance_of(described_class).to receive(:log_filename).and_return(log_filename)
allow_any_instance_of(described_class).to receive(:settings).and_return(settings)
end
describe 'when exporter is enabled' do describe 'when exporter is enabled' do
before do before do
...@@ -61,6 +56,38 @@ RSpec.describe Gitlab::Metrics::Exporter::BaseExporter do ...@@ -61,6 +56,38 @@ RSpec.describe Gitlab::Metrics::Exporter::BaseExporter do
exporter.start.join exporter.start.join
end end
context 'logging enabled' do
let(:log_enabled) { true }
let(:logger) { instance_double(WEBrick::Log) }
before do
allow(logger).to receive(:time_format=)
allow(logger).to receive(:info)
end
it 'configures a WEBrick logger with the given file' do
expect(WEBrick::Log).to receive(:new).with(end_with('test_exporter.log')).and_return(logger)
exporter
end
it 'logs any errors during startup' do
expect(::WEBrick::Log).to receive(:new).and_return(logger)
expect(::WEBrick::HTTPServer).to receive(:new).and_raise 'fail'
expect(logger).to receive(:error)
exporter.start
end
end
context 'logging disabled' do
it 'configures a WEBrick logger with the null device' do
expect(WEBrick::Log).to receive(:new).with(File::NULL).and_call_original
exporter
end
end
end end
describe 'when thread is not alive' do describe 'when thread is not alive' do
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::Metrics::Exporter::SidekiqExporter do
let(:exporter) { described_class.new(Settings.monitoring.sidekiq_exporter) }
after do
exporter.stop
end
context 'with valid config' do
before do
stub_config(
monitoring: {
sidekiq_exporter: {
enabled: true,
log_enabled: false,
port: 0,
address: '127.0.0.1'
}
}
)
end
it 'does start thread' do
expect(exporter.start).not_to be_nil
end
it 'does not enable logging by default' do
expect(exporter.log_filename).to eq(File::NULL)
end
end
context 'with logging enabled' do
before do
stub_config(
monitoring: {
sidekiq_exporter: {
enabled: true,
log_enabled: true,
port: 0,
address: '127.0.0.1'
}
}
)
end
it 'returns a valid log filename' do
expect(exporter.log_filename).to end_with('sidekiq_exporter.log')
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment