Elastic Beanstalk 已内置对 RDS 的支持。但是,我想将 Postgresql 与 Elastic Beanstalk 结合使用。哪种方法最好?
答案1
我发现最简单、最干净的方法,假设您使用 Elastic Beanstalk CLI eb
:
创建一个实例(按照以下步骤):
eb init
这将创建一个 MySQL 实例。
一旦创建,就停止它。
eb stop
这将停止您的实例并删除初始设置创建的 MySQL 数据库。
.elasticbeanstalk
在项目根目录中编辑实例配置文件,替换数据库引擎进入该[aws:rds:dbinstance]
部分PostgreSQL 的。vi .elasticbeanstalk/optionsettings.<my-app>-env [aws:rds:dbinstance] DBDeletionPolicy=Delete DBEngine=postgres DBInstanceClass=db.t1.micro DBSnapshotIdentifier= DBUser=<dbrootuser>
重启实例:
eb start Starting application ".<my-app>". Waiting for environment "<my-app>-env" to launch. 2014-07-17 17:53:15 INFO createEnvironment is starting. 2014-07-17 17:53:21 INFO Using elasticbeanstalk-us-east-1-xxxxxxx as Amazon S3 storage bucket for environment data. 2014-07-17 17:53:52 INFO Created EIP: nn.nnn.nnn.nnn 2014-07-17 17:53:58 INFO Created security group named: awseb-e-xxx 2014-07-17 17:54:10 INFO Creating RDS database named: <db name>. This may take a few minutes. 2014-07-17 18:06:09 INFO Created RDS database named: <db name> 2014-07-17 18:07:07 INFO Waiting for EC2 instances to launch. This may take a few minutes.
检查状态。一旦状态变为绿色,您现在将拥有一个 postgres 数据库。
eb status --verbose URL : <my-app>-env-xxxxx.elasticbeanstalk.com Status : Ready Health : Green RDS Database: YYYYDatabase | <db name>.zzzzzz.us-east-1.rds.amazonaws.com:5432 Database Engine: postgres 9.3.3 Allocated Storage: 10 Instance Class: db.t1.micro Multi AZ: False Master Username: <dbrootuser> Creation Time: 2014-07-17 18:02:28 DB Instance Status: available
答案2
您可以将自定义 postgres 数据库设置在任何地方运行,并使您的 rails 应用程序从 database.yml 文件设置中使用它。
例如
您可以在以下位置获取托管的 postgres 实例Heroku Postgres- 它为 ActiveRecord 提供了格式非常漂亮的配置详细信息。您只需将它们放入 database.yml 文件中即可。