Skip to main content

Change log levels without restarting.

Get exactly the logging you need, only when you need it, with Prefab dynamic logging.

Release: Structured Logging for Ruby and Rails

Β· 2 min read
Jeff Dwyer

Structured logging is great. It works just like you'd expect it to. I got into a ton of detail about Tagged vs Structured Logging last week, but the short version is that structured logging is fabulous for searching and analyzing your logs.

I'm happy to say that prefab-cloud-ruby 1.1.0 supports structured logging for ruby or rails.

Here's what that looks like, in our controller we can

class CalculatorController < ApplicationController
def index
@results = logic(height, weight)

# OLD
logger.debug "😞😞😞 finished calc results height=#{height} weight=#{weight} results=#{@results.size} "

# NEW
logger.debug "🍏🍏🍏 finished calc results", height: height, weight: weight, results: @results.size
end
end

Even with co-pilot assistance, this is so much nice than the old way of string formatting log output.

Running the server locally, we get the following output:

DEBUG  2023-09-19 14:30:18 -0400: app.controllers.calculator_controller.index 🍏🍏🍏 finished calc results height=19.0 results=6 weight=0.0

If you're using log_formatter: Prefab::Options::JSON_LOG_FORMATTER then you'll get JSON output instead.

{
"severity":"DEBUG",
"datetime":"2023-09-19T14:42:51.723-04:00",
"path":"app.controllers.calculator_controller.index",
"message":"🍏🍏🍏 finished calc results",
"height":19.0,
"weight":0.0,
"results":6
}

Of course the real reason to do this is to make it easier to search and analyze your logs. So I'll deploy and then change the log level for our controller to debug to make sure we see our output.

Dogs in the right boxes

Now we can see how nicely these show up in Datadog:

Dogs in the right boxes

Structured logging is great, and with prefab-cloud-ruby you're just a few minutes away from having it in your app. Check out the docs or learn more about dynamic logging. Happy logging!

Like what you read? Change log levels on the fly with Prefab. Start now for free.
Learn More