Sha256: 7a5de7ec30ed0cc0cf8a9df580498457ef7e805f2a4daee3b72bcd9fc9d82702
Contents?: true
Size: 1.71 KB
Versions: 1
Compression:
Stored size: 1.71 KB
Contents
require "fluent/mixin/config_placeholders" require "fluent/mixin/plaintextformatter" require 'fluent/mixin/rewrite_tag_name' module Fluent class RemoteSyslogTcpOutput < Fluent::Output Fluent::Plugin.register_output("remote_syslog_tcp", self) config_param :hostname, :string, :default => "" include Fluent::Mixin::PlainTextFormatter include Fluent::Mixin::ConfigPlaceholders include Fluent::HandleTagNameMixin include Fluent::Mixin::RewriteTagName config_param :host, :string config_param :port, :integer, :default => 514 config_param :facility, :string, :default => "syslog" config_param :severity, :string, :default => "debug" config_param :tag, :string, :default => "fluentd" def initialize super require "remote_syslog_logger_custom" require "socket" @loggers = {} end def shutdown @loggers.values.each(&:close) super end def emit(tag, es, chain) es.each do |time, record| new_record = {} record.each_pair do |k, v| if k == 'msec' new_record["timestamp"] = "#{time.to_s}.#{v}".to_f elsif v.is_a?(String) new_record[k] = v.force_encoding("utf-8") else new_record[k] = v end end new_record["test_msg"] = time tag = rewrite_tag!(tag.dup) @loggers[tag] ||= RemoteSyslogLoggerCustom::TcpSender.new(@host, @port, facility: new_record['facility'] || @facility, severity: new_record["severity"] || @severity, program: tag, local_hostname: Socket.gethostname) @loggers[tag].transmit format(tag, time, new_record) end chain.next end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
fluent-plugin-remote_syslog_tcp-0.3.9.95 | lib/fluent/plugin/out_remote_syslog_tcp.rb |