基于另一个数据的新站点 - 最佳系统架构?

New site based on data from another - the best system architecture?

事情是这样的:

  1. 我有一个网站,我们称它为 Catalogue。这是一个高级产品目录,里面有很多项目。它在基于 php 的 CMS 上工作,不是我做的,是一个相当完整和复杂的系统。重要的是,它有用户认证系统和数据库中的大量用户。除非您已登录,否则您无法访问大部分产品。

  2. 我想要另一个网站,我想自己建立这个网站。它将包含一些产品的附加数据、扩展的下载部分和一些媒体。我想用 Django 构建它。

这个其他网站将大量使用 Catalogue 的数据库: - 它需要使用目录中的 login/pass 授权用户 - 需要客户数据来自定义他们的视图。

我没有构建更高级系统的丰富经验。有经验的程序员,你能告诉我你会怎么做吗?

具体来说,我担心数据库:我应该只使用原始数据库吗?并将所有与 django 相关的东西合并到其中?它会影响目录吗? 这通常是个好主意吗?

如前所述,我将使用 Catalogue 数据库中的用户数据来验证用户身份。这个想法是否存在一些安全问题?

我直觉上觉得我应该使用一个数据库而不是两个。如有不妥请指正

请让我知道您对这个想法的看法。也许它不值得追求,应该以完全不同的方式来做?

谢谢,

C

有多种方法可以做到这一点,在做出决定之前需要权衡各种风险。因为这是您的第一次,所以犯错的风险很高(没有冒犯,就是这样),因此,对已在生产中使用的数据库进行修改可能不是最好的主意。如果您进行更改,可能会对其他网站产生负面影响,并且您可能很难弄清楚是什么导致了更改或如何从中恢复。

您仍然可以(技术上)使用相同的实际数据库服务器,而只需使用不同的数据库,以便将其全部存储在同一个地方。您可能会遇到一些问题,具体取决于数据库的锁定方式,因此您需要考虑对数据库的访问以及类似的事情。您也可以轻松地使用不同的数据库并将所有内容分开。

使用相同数据库的缺点包括无论您使用哪个数据库都有最大连接数和 IO,因此如果您的新站点成功,可能会导致另一个站点在查询时间方面变慢以及那种性质的东西。

关于身份验证,您可以采用几种方法。在您使用单独的数据库的情况下,您可以从数据库中执行实际读取以检查身份验证和权限以及类似的东西。您还可以为旧网站创建一个 API,然后让新网站使用该 API 进行身份验证。

总而言之,我的意见是使用不同的数据库,并将旧数据库用于只读目的。稍后,您可以创建一个 API,两个应用程序都可以在其上运行以限制代码重复。但是,尝试合并可能会带来很大的问题,特别是如果您是系统新手。