开发者

Capifony and git bare repo

I have this deploy.rb file:

set :application, "UDA"
set :domain,      "10.0.0.59"
set :deploy_to,   "/h开发者_开发问答ome/gitek/www/uda/"
set :app_path,    "app"

set :user,        "gitek"

ssh_options[:port] = 22
set :php_bin, "/usr/bin/php"

set :scm,         :git
#set  :git_enable_submodules,  1
set  :repository,             "#{domain}:/var/repos/uda.git"
set  :deploy_via,             :remote_cache

# Or: `accurev`, `bzr`, `cvs`, `darcs`, `subversion`, `mercurial`, `perforce`, `subversion` or `none`

set :model_manager, "doctrine"
# Or: `propel`
role :web,        domain                         # Your HTTP server, Apache/etc
role :app,        domain                         # This may be the same as your `Web` server
role :db,         domain, :primary => true       # This is where Rails migrations will run

set  :keep_releases,  5
set :use_sudo,    false

set :update_vendors, true
ssh_options[:forward_agent] = true


set :shared_files,      ["app/config/parameters.ini"]
set :shared_children,     [app_path + "/logs", web_path + "/uploads", "vendor"]

My repo, is bare repo and it is located in the same server, in "/var/repos/".

The fact is that I´m getting this error when I executed "cap deploy" command:

gitek@/Applications/MAMP/htdocs/uda$ 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 10.0.0.59:/var/repos/uda.git HEAD"
    command finished in 5487ms
  * executing "if [ -d /home/gitek/www/uda/shared/cached-copy ]; then cd /home/gitek/www/uda/shared/cached-copy && git fetch -q origin && git fetch --tags -q origin && git reset -q --hard 051be2de2155dfac7cfb45df0b4c2fb6ca633555 && git clean -q -d -x -f; else git clone -q 10.0.0.59:/var/repos/uda.git /home/gitek/www/uda/shared/cached-copy && cd /home/gitek/www/uda/shared/cached-copy && git checkout -q -b deploy 051be2de2155dfac7cfb45df0b4c2fb6ca633555; fi"
    servers: ["10.0.0.59"]
    [10.0.0.59] executing command
 ** [10.0.0.59 :: err] Permission denied, please try again.
 ** [10.0.0.59 :: err] Permission denied, please try again.
 ** [10.0.0.59 :: err] Permission denied (publickey,password).
 ** [10.0.0.59 :: err] fatal: The remote end hung up unexpectedly
    command finished in 754ms
*** [deploy:update_code] rolling back
  * executing "rm -rf /home/gitek/www/uda/releases/20111013112554; true"
    servers: ["10.0.0.59"]
    [10.0.0.59] executing command
    command finished in 20ms
failed: "sh -c 'if [ -d /home/gitek/www/uda/shared/cached-copy ]; then cd /home/gitek/www/uda/shared/cached-copy && git fetch -q origin && git fetch --tags -q origin && git reset -q --hard 051be2de2155dfac7cfb45df0b4c2fb6ca633555 && git clean -q -d -x -f; else git clone -q 10.0.0.59:/var/repos/uda.git /home/gitek/www/uda/shared/cached-copy && cd /home/gitek/www/uda/shared/cached-copy && git checkout -q -b deploy 051be2de2155dfac7cfb45df0b4c2fb6ca633555; fi'" on 10.0.0.59
gitek@/Applications/MAMP/htdocs/uda$ 

I think that the problem comes because my git repo is a bare one...

does anyone know how to resolve that?

Thanks in advance


Change your deploy.rb and set the repository like that:

set :repository, "ssh://USER@SERVERIP/var/repos/uda.git"

Don´t forget to add to autorized_keys2 (on your server 10.0.0.59? )

cat .ssh/id_rsa.pub | ssh USER@SERVER "cat >> .ssh/authorized_keys2"

Hope it helps. It works for me.


The problem is that you are trying to access the server using the network and git can't authenticate due to a missing SSH key.

If the server is on the same deploy machine, it doesn't make sense to clone using a remote connection. Clone the local repository by passing the repository path.

set  :repository,  "/var/repos/uda.git"
0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新问答

问答排行榜