Navigation Menu

Skip to content

Instantly share code, notes, and snippets.

@pablosalgadom
Last active March 11, 2022 18:17
Show Gist options
  • Star 29 You must be signed in to star a gist
  • Fork 21 You must be signed in to fork a gist
  • Save pablosalgadom/4d75f30517edc6230a67 to your computer and use it in GitHub Desktop.
Save pablosalgadom/4d75f30517edc6230a67 to your computer and use it in GitHub Desktop.
app error: Missing `secret_key_base` for 'production' environment, set this value in `config/secrets.yml` (RuntimeError)
So i was using Rails 4.1 with Unicorn v4.8.2 and when i tried to deploy my app it doesn't start properly and into the unicorn.log file i found this error message:
"app error: Missing `secret_key_base` for 'production' environment, set this value in `config/secrets.yml` (RuntimeError)"
After a little research i found that Rails 4.1 change the way to manage the secret_key, so if we read the secrets.yml file located at exampleRailsProject/config/secrets.yml (you need to replace "exampleRailsProject" for your project name) you will find something like this:
# Do not keep production secrets in the repository,
# instead read values from the environment.
production:
secret_key_base: <%= ENV["SECRET_KEY_BASE"] %>
This means that rails recommends you to use an environment variable for the secret_key_base in our production server, so in order to solve this error you will need to follow this steps to create an environment variable for linux (in my case it is Ubuntu) in our production server:
1.- In the terminal of our production server you will execute the next command:
$ RAILS_ENV=production rake secret
This will give a large string with letters and numbers, this is what you need, so copy that (we will refer to that code as GENERATED_CODE).
2.1- Now if we login as root user to our server we will need to find this file and open it:
$ vi /etc/profile
Then we go to the bottom of the file ("SHIFT + G" for capital G in VI)
And we will write our environment variable with our GENERATED_CODE (Press "i" key to write in VI), be sure to be in a new line at the end of the file:
export SECRET_KEY_BASE=GENERATED_CODE
Having written the code we save the changes and close the file (we push "ESC" key and then write ":x" and "ENTER" key for save and exit in VI)
2.2 But if we login as normal user, lets call it example_user for this gist, we will need to find one of this other files:
$ vi ~/.bash_profile
$ vi ~/.bash_login
$ vi ~/.profile
These files are in order of importance, that means that if you have the first file, then you wouldn't need to write in the others. So if you found this 2 files in your directory "~/.bash_profile" and "~/.profile" you only will have to write in the first one "~/.bash_profile", because linux will read only this one and the other will be ignored.
Then we go to the bottom of the file ("SHIFT + G" for capital G in VI)
And we will write our environment variable with our GENERATED_CODE (Press "i" key to write in VI), be sure to be in a new line at the end of the file:
export SECRET_KEY_BASE=GENERATED_CODE
Having written the code we save the changes and close the file (we push "ESC" key and then write ":x" and "ENTER" key for save and exit in VI)
3.-We can verify that our environment variable is properly set in linux with this command:
$ printenv | grep SECRET_KEY_BASE
or with:
$ echo $SECRET_KEY_BASE
When you execute this command, if everything went ok, it will show you the GENERATED_CODE that we generated before. Finally with all the configuration done you can deploy without problems your Rails app with Unicorn or other.
Now when you close your shell terminal and login again to the production server you will have this environment variable set and ready to use it.
And Thats it!! i hope this mini guide help you to solve this error.
Disclaimer: i'm not a guru of linux or rails, so if you find something wrong or any error i will be glad to correct it!
@ravirakesh
Copy link

(we push "ESC" key and then write ":x" and "ENTER" key for save and exit in VI)
when we going this way at this place ":x" and "ENTER" for save and exit its demand the encrepted key
or not save exit

@nezirz
Copy link

nezirz commented Aug 23, 2015

This is solution:

At your app inside application.rb add this line:

config.secret_key_base = 'blipblapblup'

@LuisHCK
Copy link

LuisHCK commented Jul 13, 2016

TY bro that fix my problem

zirexba commented on 22 Aug 2015
This is solution:

At your app inside application.rb add this line:

config.secret_key_base = 'blipblapblup'

@paaggeli
Copy link

config.secret_key_base = '<%= ENV["SECRET_KEY_BASE"] %>' is more secure

@emarkine
Copy link

emarkine commented Jun 6, 2017

Add this line in config/environments/production.rb
config.secret_key_base = ENV['SECRET_KEY_BASE']

@bestwebua
Copy link

bestwebua commented Dec 29, 2017

Awesome! @pablosalgadom, thanks!!! :)

@bonafernando
Copy link

config.secret_key_base = 'blipblapblup'

Thank you. Fixed here!

@JulienDefrance
Copy link

If it was your first time setting SECRET_KEY_BASE, eg. unresolved tech debt since Rails 4.1 that this was introduced, how would you set it without causing your production users to have their cookies invalidated and become signed out?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment