AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 56531
Accepted
Simon
Simon
Asked: 2009-08-21 01:02:42 +0800 CST2009-08-21 01:02:42 +0800 CST 2009-08-21 01:02:42 +0800 CST

为 apache httpd 服务器上的站点寻找一个好的用户/组配置

  • 772

我们有一个设置,不同的人在他们的本地机器上开发,稍后将更改提交到本地服务器存储库。

为了将更改同步到我们的外部生产服务器,我们运行一个脚本,将本地 subversion 导出同步到它。

我们在进行此同步时遇到了问题,因为为了工作,在远程服务器上进行同步的用户需要是远程文件的所有者。

我们的解决方案是:

在远程服务器上创建一个用户 (siteowner) 给他站点的所有权 (chown siteowner.siteowner /var/www/site) 将 apache 添加到 siteowner 的组中(我们在 htaccess 检查中遇到了一些问题,我们可以' t chown siteowner.apache,因为当 rsync 进行同步时,它会将权限更改为 siteowner.siteowner)

我的问题是......这个设置似乎合理?你还知道其他更好的吗?提前致谢!

apache-2.2
  • 2 2 个回答
  • 359 Views

2 个回答

  • Voted
  1. Best Answer
    Martijn Heemels
    2009-08-21T02:44:22+08:002009-08-21T02:44:22+08:00

    我们为基于 PHP 的网站使用以下工作流程。

    用户将他们的工作提交给 Subversion。我们不允许开发人员手动将代码部署到 Staging 和 Live。为什么不分期?因为我们希望它能够密切模拟 Live。部署是通过Webistrano完成的,它是著名且强大的Capistrano部署工具的 Web 前端。我们已经创建了所谓的配方来编写部署脚本。它大约执行以下操作:

    • Webistrano 以用户 'deploy' 身份通过 ssh 登录服务器
    • 它更新远程工作副本缓存
    • 它使用硬链接将生成的工作副本复制到发布// 文件夹(以节省磁盘空间和提高速度)。
    • 将客户数据(即未存储在 subversion 中的文件)符号链接到适当的位置。
    • 新版本修改为 775 以授予组写入权限。
    • 如果上述所有步骤都成功,它将“当前”符号链接更改为 /releases// 文件夹。
    • 它执行 'apache2ctl graceful' 来刷新仍在缓存先前版本的任何缓存(例如 php 的 realpath() )。
    • 如果存储的版本超过一定数量,则清除最旧的版本。

    网络服务器配置为使虚拟主机的 docroot 指向“当前”符号链接,因此在部署期间旧站点可见,并且在成功部署后新站点立即出现。

    代码归 deploy:deploy 所有,但客户数据目录归 deploy:upload 所有,并在创建时设置其 SGID 位。

    Apache 的 www-data 用户是“deploy”和“upload”组的成员。开发人员在服务器上拥有个人 scp 帐户,并且是“上传”组的成员。这种设置对我们来说非常有效,因为开发人员只能通过 Webistrano 与代码进行交互。它可以防止管理员以外的“实时快速修复”,并大大减少了事故。Webistrano 的内置回滚功能可以快速恢复错误的部署。

    开发人员被授予对客户数据目录的写入权限(由于上传组),因此他们可以上传占位符内容或帮助客户预填充网站。毕竟,svn 中没有存储任何客户内容。目录上的 SGID 位确保只有上传文件的用户所有权被设置为上传的用户(提供一点责任)。组所有权仍然由 SGID 设置为“上传”,以便 Apache 或其他开发人员仍然可以读写创建的文件和目录。

    事实证明,清晰的 Webistrano 界面非常有用,而且由于 Capistrano 内置了上述大部分功能,我们的部署方法只有两打行。其中大部分是覆盖 Ruby-on-Rails 特定的默认值。

    • 1
  2. Razique
    2009-08-21T02:05:56+08:002009-08-21T02:05:56+08:00

    您可以通过这种方式重新考虑工作流程:

    • 每个人都可以提交到 SVN 服务器,而不是玩 apache 权限,而是在生产服务器上创建一个用户并添加一个 SFTP 服务器。

    • 每个人都在处理他们的文件,当完成对 SVN 服务器的提交时,他们使用他们的 SFTP 客户端将他们的文件投入生产。(因为他们都将使用同一个用户,你不会为权限而烦恼)

    实际上,在投入生产之前,您应该有一个额外的服务器用于预生产。
    在每次提交到生产服务器之前,他们会将他们的文件添加到预生产服务器,这在理想情况下必须是生产服务器的精确复制。
    验证更改后,他们可以将文件投入生产。

    • 0

相关问题

  • Apache Django Mod_Wsgi - 自动重新加载应用程序

  • Apache:对多个虚拟主机使用相同的目录指令

  • Apache 上的子域不工作 - 找不到服务器

  • PHP 作为 CGI 还是 Apache 模块?

  • 避免将某些丢失的文件记录到 Apache2 错误日志中

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    从 IP 地址解析主机名

    • 8 个回答
  • Marko Smith

    如何按大小对 du -h 输出进行排序

    • 30 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    Windows 中执行反向 DNS 查找的命令行实用程序是什么?

    • 14 个回答
  • Marko Smith

    如何检查 Windows 机器上的端口是否被阻塞?

    • 4 个回答
  • Marko Smith

    我应该打开哪个端口以允许远程桌面?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    MikeN 在 Nginx 中,如何在维护子域的同时将所有 http 请求重写为 https? 2009-09-22 06:04:43 +0800 CST
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    0x89 bash中的双方括号和单方括号有什么区别? 2009-08-10 13:11:51 +0800 CST
  • Martin Hope
    kch 如何更改我的私钥密码? 2009-08-06 21:37:57 +0800 CST
  • Martin Hope
    Kyle Brandt IPv4 子网如何工作? 2009-08-05 06:05:31 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve