Skip to content

Latest commit

 

History

History
60 lines (54 loc) · 2.75 KB

UPGRADING.md

File metadata and controls

60 lines (54 loc) · 2.75 KB

Upgrade Guide

honeycomb-rails to beeline-ruby

  1. Update Gemfile, remove honeycomb-rails and add beeline-ruby
  2. Run bundle install
  3. Remove the honeycomb.rb initializer from config/initializers
  4. Add the following to the config.ru file
    # config.ru
    require 'honeycomb-beeline'
    
    Honeycomb.init(writekey: 'YOUR_API_KEY', dataset: 'YOUR_DATASET')
    
    # these next two lines should already exist in some form in this file, it's important to init the honeycomb library before this
    require ::File.expand_path('../config/environment', __FILE__)
    run Rails.application
  5. You can use the same write key and dataset from the honeycomb initialiser above, note: the honeycomb-beeline only supports sending events to one dataset. This is due to the fact that the new beeline will include traces for your application by default and these are only viewable from within the same dataset
  6. Replace any honeycomb_metadata calls in your controllers like the following
    def index
      @bees = Bee.all
      Rack::Honeycomb.add_field(request.env, :bees_count, @bees.count)
      # honeycomb_metadata[:bees_count] = @bees.count
    end
  7. If you are manually using the libhoney client as well, it is suggested that you remove the usages of it and rely on the beeline.
  8. Instrument interesting calls using the new span API as per the example below
      class HomeController < ApplicationController
        def index
          Honeycomb.span do
            @interesting_information = perform_intensive_calculations(params[:honey])
          end
        end
      end
  9. honeycomb-rails had the ability to automatically populate user information onto your events. Unfortunately beeline-ruby does not support this out of the box. You can use something like this snippet below to continue populating this (example for Devise)
    class ApplicationController < ActionController::Base
      before_action do
        Rack::Honeycomb.add_field(request.env, "user.id", current_user.id)
        Rack::Honeycomb.add_field(request.env, "user.email", current_user.email)
      end
    end
  10. (Optional) If you are using Sequel for database access there are some additional steps to configure
    # config.ru
    require 'honeycomb-beeline'
    require 'sequel-honeycomb/auto_install'
    
    Honeycomb.init(writekey: 'YOUR_API_KEY', dataset: 'YOUR_DATASET')
    Sequel::Honeycomb::AutoInstall.auto_install!(honeycomb_client: Honeycomb.client, logger: Honeycomb.logger)
    
    # these next two lines should already exist in some form in this file, it's important to init the honeycomb library before this
    require ::File.expand_path('../config/environment', __FILE__)
    run Rails.application