In my deploy-file I set the group to www-data:
set :user, "root"
set :group, "www-data"
so when using cap:setup I expected capistrano to chown the folders with root:www-data
But all folders and files are root:root.
Any ideas where this problem could come from?
Information: I'm Using system-wide-rvm.
Just chiming in: there is no mention of :group in Capistrano source code whatsoever. I suppose it's a cargo cult option. And the :user option is only used for the SSH connection.
As to your question, directories and files that Capistrano creates are created with the default permissions, it never
chown
s them in any way; if you're deploying asroot
then they will belong toroot:root
.as for my understanding you should do it manually, what setup does is to use the user to login, not to set the rights to directory.
I have found no group setting for capistrano, maybe you were using some extensions for it?
What you could do to change it could be:
But in first place you should not use root for deployment, as @Julian mentions in comment better practice is to use separate user for this task and set his group to proper group, then it will not require the above task and will work automatically.
Better than fixing an issue is not having it in the first place:
Say we call him
deployer
.set :user, 'deployer'
sudo
, so turn it off by addingset :use_sudo, false
to your
deploy.rb
.