【问题标题】:How to organize shared code on website Bonus: across subdomains如何在网站上组织共享代码奖励:跨子域
【发布时间】:2014-02-03 04:59:41
【问题描述】:

我应该如何组织我的网站以利用共享包?让我们以 Stackexchange 为例。有很多子域:

webapps.stackexchange.com         namespace StackExchange\webapps
programmers.stackexchange.com     namespace StackExchange\programmers
etc.

每个子域都重用库。也许有一个问题类被所有网站重用,以帮助布局提问页面。

问题包会打包在每个子域包中吗?或者是否所有包都引用了 Question 包。换句话说:是哪种情况:

StackExchange\webapps\question
StackExchange\programmers\question

或者:

StackExchange\webapps
StackExchange\programmers
StackExchange\question
WHERE StackExchange\Webapps and StackExchange\programmers use StackExchange\question

我问是因为我正在使用几个独立的工具来设置我的网站。我计划将每个工具放在同一台服务器上的自己的子域中。每当我更新一个被许多子域使用的包时,我只想在一个地方更新服务器,所以我希望它存储在它自己的命名空间中。

我应该使用 composer 之类的依赖管理器或其他东西来为我处理这个问题吗?实现这一目标的最佳做法是什么?

【问题讨论】:

    标签: php apache namespaces dependencies subdomain


    【解决方案1】:

    由于一切都将在同一台服务器上,您可以简单地在 php.ini 的包含路径中拥有一个共享目录 ---

    /usr/share/php/

    然后每个项目将能够包含来自 - 的相同文件 (编写良好的自动加载器函数也可以做到这一点,而不需要包含路径)

    以及在为项目特定目的设置包含路径时 -

    ini_set('include_path', get_include_path().".:/var/www/path/for/this/project");

    或者甚至只是根据需要包含您需要的内容:

    require_once '/usr/share/php/apis/Google_Client.php';

    【讨论】:

    • 或者这太简单了?
    【解决方案2】:

    我不得不处理一个类似的场景,我有两个共享很多功能的网站。因为我不得不重写其中一个,所以我尝试建立一个共享代码库。

    命名空间

    如何构建命名空间主要取决于个人喜好。

    就我个人而言,我使用Vendor\Package 来共享内容,Vendor\Site\Package 用于特定于站点的代码。

    想要做的是在每个特定于站点的包中放置一个共享包(正如您的第一个示例所暗示的那样),因为这样您就必须复制 em> 修改你的代码文件(因为你必须改变命名空间)。

    共享包的放置位置

    您有两个选择实际放置共享包的位置:每个应用程序(子域)的本地或服务器上的全局。

    全局包

    在这里,您可以将共享代码放在服务器上的某个位置,以便每个应用程序都可以访问它。 rm-vanda's answer 几乎描述了如何在实践中做到这一点。您不需要 Composer。

    在专业方面,您将只有一个共享包的实例,而不是多个副本。您不能忘记更新您的应用程序之一。如果您使用 APC 或 OpCache 之类的 PHP 加速器,这种方法还可以节省一些内存,因为共享库只访问缓存一次。

    本地包

    另一种方法是为每个应用程序创建一个副本。这就是 Composer 默认采用的方法。通常,您将在应用程序的主目录中有一个“供应商”目录,您可以在其中放置这些共享的东西(以及如果您使用任何第三方代码)。这样,每个应用程序都可以使用不同版本的共享库。

    就个人而言,我最喜欢本地方法。我可以忍受额外的部署工作,我认为这是最安全的方式。

    • 必须在多台服务器上拆分我的应用程序?没问题,它们已经非常独立了。
    • 应用程序的数量正在增加,如果我更新了一些东西,我就懒得检查所有的应用程序了吗?只是不要更新所有这些。
    • 我什至可以在同一台服务器上拥有一个生产环境和一个测试环境,其中包含不同版本的共享库。

    此外,使用 Composer 感觉这种方法最自然。 Composer 是一个非常棒的东西,尤其是在使用第三方代码时。

    【讨论】:

      猜你喜欢
      • 2011-07-01
      • 1970-01-01
      • 2022-01-17
      • 2011-07-04
      • 1970-01-01
      • 1970-01-01
      • 2012-10-05
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多