Sha256: b855009afe2d60ca9c9478d88401439da5cdef637e896827b179aac4acf078f4

Contents?: true

Size: 1.3 KB

Versions: 1

Compression:

Stored size: 1.3 KB

Contents

require 'uri'
require 'socket'
require 'json'
require 'thwait'

# Read syslog messages from one or more sockets, and send it to a logstash
# server.
#
class Syslogstash
	def initialize(cfg)
		@cfg    = cfg
		@stats  = PrometheusExporter.new(cfg)
		@writer = LogstashWriter.new(cfg, @stats)
		@reader = SyslogReader.new(cfg, @writer, @stats)
		@logger = cfg.logger
	end

	def run
		if @cfg.stats_server
			@logger.debug("main") { "Running stats server" }
			@stats.run
		end

		@writer.run
		@reader.run

		dead_thread = ThreadsWait.new(@reader.thread, @writer.thread).next_wait

		if dead_thread == @writer.thread
			@logger.error("main") { "Writer thread crashed." }
		elsif dead_thread == @reader.thread
			@logger.error("main") { "Reader thread crashed." }
		else
			@logger.fatal("main") { "ThreadsWait#next_wait returned unexpected value #{dead_thread.inspect}" }
			exit 1
		end

		begin
			dead_thread.join
		rescue Exception => ex
			@logger.error("main") { (["Exception in crashed thread was: #{ex.message} (#{ex.class})"] + ex.backtrace).join("\n  ") }
		end

		exit 1
	end

	def force_disconnect!
		@writer.force_disconnect!
	end
end

require_relative 'syslogstash/config'
require_relative 'syslogstash/syslog_reader'
require_relative 'syslogstash/logstash_writer'
require_relative 'syslogstash/prometheus_exporter'

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
syslogstash-2.2.0 lib/syslogstash.rb