No commit activity in last 3 years
No release in over 3 years
A gem that allows your Rails apps to self-scale as they need more and more resources under Flynn. Comes with an automated mode that can be used for 'day to day' web hosting operations and a manual mode where you can control when scaling operations take place (for scripts, background jobs and anything else)
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
 Dependencies

Development

Runtime

>= 0
>= 0
 Project Readme

Warning: This gem is in active development and may have some serious bugs.

FlynnAutoScale

A gem that allows your Rails apps to self-scale as they need more and more resources under Flynn. Comes with an automated mode that can be used for "day to day" web hosting operations and a manual mode where you can control when scaling operations take place (for scripts, background jobs and anything else)

Installation

Add this line to your application's Gemfile:

gem 'flynn_auto_scale'

And then execute:

$ bundle

Make sure to migrate after installing this gem (it makes use of ActiveRecord to keep the autoscaler working)

In order to get up and running quickly, please set up the following ENV variables. Failure to set up some of these could cause "bad things to happen", so ensure you read this section.

# These are the minimum required items for [connecting to a cluster](https://flynn.io/docs/cli#adding-clusters)
FLYNN_SETUP_CLUSTER_PIN
FLYNN_SETUP_CLUSTER_NAME
FLYNN_SETUP_CLUSTER_CONTROLLER_DOMAIN
FLYNN_SETUP_CLUSTER_CONTROLLER_KEY
FLYNN_SETUP_CLUSTER_APP_NAME - the app name to be scaled.


# These are configuration variables that are used to customize how FlynnAutoScale will handle scaling events.
FLYNN_AUTO_SCALE - If present, FlynnAutoScale will attempt auto scaling operations -> (default: do nothing)
FLYNN_AUTO_SCALE_RAM - The amount of RAM in MB you'd like FlynnAutoScale to consider scaling at -> (default: 256)
FLYNN_AUTO_SCALE_COOLDOWN - How long to wait after you have scaled (in seconds) before scaling again -> (default: 0)
FLYNN_LIMIT_INSTANCES_MANUAL_MODE - If present, whether manual mode should follow the instance limits -> (default: ignore limits)
FLYNN_MIN_INSTANCES - Minimum number of instances -> (default: 1)
FLYNN_MAX_INSTANCES - Maximum number of instances -> (default: 2)

Add the following at the top of your application_controller.rb to get started with auto scaling.

# This should be a single line
around_action def scale; yield; FlynnAutoScale::Scaler.auto_scale('web'); end

Usage

For a more advanced use of the scaler, you can directly call the manual scaler yourself.

# You can pass the process name: 'console', 'web', 'worker'.
FlynnAutoScale::Scaler.scale_manual('web', 2)

Contributing

It's an open source repo, fork the thing, make some changes, and I'll put you on the list of cool people making Flynn + Rails great again.

I am also looking for a partner in crime or two to turn that database of scaling changes into a nice dashboard (a la sidekiq's web_ui). I can do it, but it's gonna be super butt ugly if I do it alone.

License

The gem is available as open source under the CC0 terms.