6

我的设置:

  • 4 个网络服务器
  • 静态内容服务器(NFS 挂载)
  • 2个数据库服务器
  • 2台“做魔术”服务器
  • 另有 8 台机器指定多用途。

我正在为三种缓存机制编写一个包装器,以便它们可以以某种标准化的方式使用:文件系统、Memcached 和 APC。我正在尝试提出使用示例(以及实际放入每个缓存的内容)。

文件系统

处理我们生成然后静态服务的内容。RSS 提要、旧报告数据、用户特定页面等...这些都缓存到静态服务器。

内存缓存

PHP 会话数据、MySQL 查询结果,通常是我们系统中需要可用的东西。我们有 8 台机器可以包含在服务器池中。

装甲运兵车

我不知道。这两个“做魔术”服务器不是任何分布式系统的一部分,因此它们似乎可以在 APC 中缓存查询结果并从那里工作。过去,我什么都想不起来。

查询缓存

鉴于我们使用 SQL 的性质,查询缓存会降低性能。我已经禁用了这个。

一般来说,什么类型的数据应该存储在哪里?这种设置是否有意义?

分布式系统中的 APC 数据缓存有什么用(我想不出一个)?

有什么我遗漏的东西可以让事情变得更容易或更高效吗?

编辑:我终于明白了帕斯卡在说什么。我一直在想,我只会将我的一部分配置/任何东西移动到 APC,并且仍然从磁盘加载文件的其余部分。还有其他建议吗?

4

1 回答 1

3

我在某些项目中使用了相同的缓存机制;我们使用 APC + memcached 作为缓存系统。

在缓存数据方面,APC 和 memcached 有两个/三个主要区别:

  • APC 访问要快一些(如果我没记错的话,它比 memcached 快 5 倍),因为它只是本地的——即不涉及网络。
  • 使用 APC,您的缓存会在每台服务器上复制;使用 memcached,跨服务器没有重复
    • 这意味着 memcached 确保所有服务器具有相同版本的数据;而存储在 APC 中的数据在每台服务器上可能不同


我们一般使用:

  • 用于必须经常访问的数据的 APC,生成速度快,并且:
    • 要么不经常修改
    • 或者它是否在所有服务器上都不相同并不重要
  • memcached 用于生成需要更多时间和/或使用较少的数据。
    • 或者对于修改必须立即可见的数据(即,当写入数据库时​​,缓存条目也会重新生成)

例如,我们可以:

  • 使用 APC 存储配置变量:
    • 不要经常换
    • 经常访问
    • 很小
  • 将 memcached 用于文章内容(例如,对于 CMS 应用程序)
    • 不是那么小,而且数量很多,这意味着它可能需要比我们单独在一台服务器上更多的内存
    • 很难/很难生成


一些旁注:

  • 如果多台服务器尝试写入通过 NFS 共享的同一个文件,则可能会出现问题,因为 NFS 上没有锁定机制(据我所知)
  • APC 可以用来缓存数据,是的——但使用它的最重要原因是它的操作码缓存功能(可以在 PHP 服务器上节省大量 CPU)
  • memcached 中的条目大小有限:您不能存储大于 1M 的条目(我有时会遇到这个问题 - 很少,但发生时不好^^)
于 2010-02-28T23:53:34.617 回答