8

Capistrano を AmazonRDS とうまく連携させることができないようです。これを正しく設定するための情報をあちこち探しましたが、何も見つかりませんでした。今、私cap deployがプロセスがタイムアウトしたとき。

これは私の deploy.rb です:

set :deploy_to, "/opt/bitnami/apps/annarbortshirtcompany.com/cms/" 
set :scm, :git
set :repository,  "ssh://user@ec2-repository.compute-1.amazonaws.com/~/repo/cms.git"
set :deploy_via, :remote_cache

set :user, "user"
ssh_options[:keys] = [File.join(ENV["HOME"], "EC2", "admin.pem")]
ssh_options[:forward_agent] = true
set :branch, "master"
set :use_sudo, true

set :location, "ec2-webserver.compute-1.amazonaws.com"
role :web, location
role :app, location
role :db, "cmsinstance.c7r8frl6npxn.us-east-1.rds.amazonaws.com", :primary => true

# If you are using Passenger mod_rails uncomment this:
namespace :deploy do
  task :start do ; end
  task :stop do ; end
  task :restart, :roles => :app, :except => { :no_release => true } do
    run "#{try_sudo} touch #{File.join(current_path,'tmp','restart.txt')}"
  end
end

RDS データベース インスタンスのユーザー名は、ここで設定した SSH ユーザー名とは異なりますが、database.yml で定義されています。これはおそらくカピストラーノによって読み取られていないと思いますが、それを実現する方法がわかりません。

「キャップデプロイ」すると:

ubuntu@ubuntu-VirtualBox:~/RailsApps/cms$ cap deploy
  * executing `deploy'
  * executing `deploy:update'
 ** transaction: start
  * executing `deploy:update_code'
    updating the cached checkout on all servers
    executing locally: "git ls-remote ssh://user@ec2-repository.compute-1.amazonaws.com/~/repo/cms.git master"
    command finished in 1590ms
  * executing "if [ -d /app-directory/shared/cached-copy ]; then cd /app-directory/shared/cached-copy && git fetch -q origin && git fetch --tags -q origin && git reset -q --hard ffc4ec7762566f801c4a9140aa3980dc71e3d06f && git clean -q -d -x -f; else git clone -q  ssh://user@ec2-repository.amazonaws.com/~/repo/cms.git /app-directory/shared/cached-copy && cd /app-directory/shared/cached-copy && git checkout -q -b deploy ffc4ec7762566f801c4a9140aa3980dc71e3d06f; fi"
    servers: ["ec2-webserver.compute-1.amazonaws.com", "dbinstance.us-east1.rds.amazonaws.com"]
*** [deploy:update_code] rolling back
  * executing "rm -rf /app-directory/releases/20110607161612; true"
    servers: ["ec2-webserver.compute-1.amazonaws.com", "dbinstance.us-east1.rds.amazonaws.com"]
 ** [deploy:update_code] exception while rolling back: Capistrano::ConnectionError, connection failed for: dbinstance.us-east1.rds.amazonaws.com (Errno::ETIMEDOUT: Connection timed out - connect(2))
    connection failed for: dbinstance.us-east1.rds.amazonaws.com (Errno::ETIMEDOUT: Connection timed out - connect(2))

「すべてのサーバーでキャッシュされたチェックアウトを更新する」必要があるのはなぜですか? この時点では、DB サーバーは必要ありません。これを修正する方法に困惑しています。うまくいけば、誰かが私を正しい方向に向けることができます!

4

1 に答える 1

26

私はまさにこの問題を抱えていて、恥ずかしいことに、5時間か6時間は苦労しました. 結局、問題が何であるかを理解したとき、私はこれを一度知っていたがそれを忘れていたので、自分自身を叩きたくなりました. deploy.rb のこの部分から始まる、問題の核心は次のとおりです。

set :location, "ec2-webserver.compute-1.amazonaws.com"
role :web, location
role :app, location
role :db, "cmsinstance.c7r8frl6npxn.us-east-1.rds.amazonaws.com", :primary => true

Capistrano のマシン ロールを定義するとき、実際にはどのマシンが特定のロールを実行するかを特定するのではなく、ロール のデプロイ レシピを適用するときにCapistrano コードが実行されるマシンを特定します。したがって、:db ロールを定義するときは、RDS インスタンスではなく、 EC2 インスタンスを指す必要があります。RDS マシンに ssh できないため、Capistrano がそこでレシピを実行することは不可能です。代わりに、:web と :app を指しているのと同じマシンを :db で指すようにします。つまり、

set :location, "ec2-webserver.compute-1.amazonaws.com"
role :web, location
role :app, location
role :db, location, :primary => true

RDS マシンはどのように関与しますか? SQL を実行する必要がある RDBMS を実際に実行しているマシンを指定するのは、database.yml ファイルです。ターゲット データベースの host: 値を設定していることを確認する必要があります。

production:
  adapter: mysql2
  encoding: utf8
  reconnect: false
  database: <your_db>_production
  pool: 5
  username: <username>
  password: <password>
  host: cmsinstance.c7r8frl6npxn.us-east-1.rds.amazonaws.com

わかる?

これが私が経験した欲求不満を他の誰かに救うことを願っています.

  • デビッド
于 2011-06-21T18:08:27.620 に答える