在我的部署文件中,我将组设置为 www-data:
set :user, "root"
set :group, "www-data"
所以在使用 cap:setup 时,我希望 capistrano 使用 root:www-data chown 文件夹
但所有文件夹和文件都是 root:root。
这个问题可能来自哪里的任何想法?
信息:我正在使用系统范围的 rvm。
在我的部署文件中,我将组设置为 www-data:
set :user, "root"
set :group, "www-data"
所以在使用 cap:setup 时,我希望 capistrano 使用 root:www-data chown 文件夹
但所有文件夹和文件都是 root:root。
这个问题可能来自哪里的任何想法?
信息:我正在使用系统范围的 rvm。
至于我的理解,您应该手动进行,设置的作用是使用用户登录,而不是设置目录的权限。
我没有找到 capistrano 的组设置,也许你使用了一些扩展?
你可以做些什么来改变它:
after "deploy:setup", :setup_group
task :setup_group do
run "chown -R :#{group} #{deploy_to} && chmod -R g+s #{deploy_to}"
end
但首先你不应该使用root进行部署,正如@Julian 在评论中提到的更好的做法是使用单独的用户来完成这个任务并将他的组设置为适当的组,那么它就不需要上述任务并且会自动工作。
只是插话:在 Capistrano 源代码中没有提到 :group。我想这是一个货物崇拜的选择。:user 选项仅用于 SSH 连接。
至于您的问题,Capistrano 创建的目录和文件是使用默认权限创建的,它绝不会chown
以任何方式创建它们;如果您正在部署,root
那么它们将属于root:root
.
比解决问题更好的是首先没有它:
deployer
。set :user, 'deployer'
sudo
,所以通过添加set :use_sudo, false
deploy.rb
.