【问题标题】:Fluentd: Not able to pipe Rails log to Fluentd STDOUTFluentd:无法将 Rails 日志通过管道传输到 Fluentd STDOUT
【发布时间】:2015-03-20 12:34:42
【问题描述】:

我正在关注这个Fluentd post 来设置带有 Rails 的 Fluentd 的工作版本。我的fluent-logger.yml

development:
  fluent_host: "localhost"
  fluent_port: 24224
  tag: "foo"
  messages_type: "string"

application.rb:

config.log_level = :info
config.logger = ActFluentLoggerRails::Logger.new
config.lograge.enabled = true
config.lograge.formatter = Lograge::Formatters::Json.new

我的td-agent.conf 指令如下所示:

<source>
  type forward
  port 24224
</source>

<match foo>
  type stdout
</match>

当我启动我的 rails 服务器时,我没有看到任何日志消息通过管道传输到 td-agent.log 。我正在使用 act-fluent-logger-rails gem。

但是,当我在 rails 控制台中使用 fluent-logger gem 并执行以下命令时:

require 'fluent-logger'
Fluent::Logger::FluentLogger.open(nil, :host=>'localhost',:port=>24224)
Fluent::Logger.post("fluentd.test.follow",{"from"=>"A","to"=>"B"})

我可以看到 STDOUT 填充了我发送的消息。我在哪里出错了,在应用程序中运行它?任何对此的注意都会很棒! TIA。

【问题讨论】:

  • 当您在 Rails 应用程序上执行某项操作时,td-agent.log 是否会收到任何日志消息?
  • 是的,在我重新启动系统后它起作用了。日志开始在td-agent.log 聚合。

标签: ruby-on-rails ruby logging fluentd


【解决方案1】:

也许您的 Rails 应用程序是一个 API。在这种情况下,您可能需要设置config.lograge.base_controller_class = 'ActionController::API'

【讨论】:

    猜你喜欢
    • 2021-02-02
    • 2022-07-07
    • 1970-01-01
    • 1970-01-01
    • 2021-09-16
    • 1970-01-01
    • 2020-02-15
    • 2017-11-18
    • 2018-06-19
    相关资源
    最近更新 更多