I know that you can run tasks as part of each deploy, but I only want to bootstrap the database once.
相关问题
- How to generate 12 digit unique number in redshift
- Use awslogs with kubernetes 'natively'
- Eager-loading association count with Arel (Rails 3
- Assume/switch role in aws toolkit for eclipse 2.0
- 'no SavedModel bundles found!' on tensorfl
相关文章
- Right way to deploy Rails + Puma + Postgres app to
- how many objects are returned by aws s3api list-ob
- AWS S3 in rails - how to set the s3_signature_vers
- Passthrough input to output in AWS Step Functions
- “No explicit conversion of Symbol into String” for
- Rspec controller error expecting <“index”> but
- Factory_girl has_one relation with validates_prese
- Rails: Twitter Bootstrap Buttons when visited get
Kristian's answer is close, but you should also add:
So that the DB is only seeded from 1 EC2 instance, rather than all of them at the same time. Depending on your EB deployment/version, the
export HOME
may or may not be needed.I used the information provided at this address to create a script that will run AFTER migrations and after each deploy: http://www.emind.co/how-to/how-to-run-rake-dbseed-in-amazon-elastic-beanstalk
I preferred this method so that I could keep track of the file on the EC2 instance. When I initially deployed this on my old servers (which were running Linux <1.0.9) I had no issue. However, I recently had to upgrade the server machines to 64bit Amazon Linux 2014.03 v1.0.9 running Ruby 2.0 (Puma) and the script began to fail. It will likely fail if you are using different Linux versions.
The key here is /usr/local/bin/ to your rake command to use the proper rake. I took this directly from the other scripts found at /opt/elasticbeanstalk/hooks/appdeploy/pre/:
It should be noted that this script is still not correct as I am not running "bundle exec rake" which is highly advised if you plan to run any rake command (it's a feature request currently on AWS for other scripts). If you wish to have ALL scripts run the bundle exec before "rake" take a look at the .config files posted here: https://github.com/alienfast/elastic-beanstalk
If this still doesn't work for you, I suggest sshing to one of your EC2 instances that are running your app, or deploy a new one running the same Linux/Ruby version and navigate to the "/opt/elasticbeanstalk/hooks/appdeploy/pre/" to see what the other scripts are doing.
I hope others find this useful!
to do commands on your elastic beanstalk instance, you can setup custom commands configurations that will get run when you do update your application. (In fact, there is a whole docs page dedicated to the different types of container commands you can do).
.ebextensions
directory in the root of your application, create one..config
" -- I arbitrarily named mineseed.config
borrowing from what hfogel wrote, you can put something in there like this:
add this new code to your repo:
git add .
thengit commit -m 'added seed config script'
thengit push
git aws.push
To verify that your command actually ran, go into your elastic beanstalk console and expand the details for your environment, and navigate to the
logs
tab, and refresh your logs and view them. Inside there, simply do actrl + f
for "seed" until you see your seed command was run. If you don't see it in there somewhere, then it didn't run.It's a while since the question was asked, so perhaps you've figured it out. Anyway, you can add a file called (for instance) seed.config in the .beanstalk folder. Enter something like this and your seeds will be run:
The only way I found was to ssh into the ec2 instance and run "rake db:seed RAILS_ENV=production" manually from /var/app/current.