0

我运行自己的博客系统已经有一段时间了,我注意到对于大多数页面,每次访问页面时都需要执行几个(5-10)个相同的数据库查询。

现在我正在考虑将数据缓存到 xml 文件中。这是我这样做的计划:

--- 发布/编辑博客时,将数据插入/更新到 MySQL 数据库,并生成 xml 文件

<?xml version="1.0" encoding="UTF-8"?>
<data>
    <id>32</id>
    <title>caching data with xml</title>
    <date>2012-10-01</date>
    <content><![CDATA[<p>blah...blah...blah...</p>]]></content>
</data>

--- 当页面被访问时,首先检查文件是否存在(以防万一),然后解析 xml 文件和格式/输出数据。

if(file_exists("path/to/blog/32.xml")) {
    $data = simplexml_load_file("path/to/blog/32.xml");
    echo '<h2'>.$data->title.'</h2>';
    echo '<p'>.$data->date.'</p>';
    echo $data->content;
}
else {
    mysql_query(...);
}

通过这样做,MySQL 可以做更少的工作,但我不太确定这是否会在以后引起任何问题,例如 100 或 300 个访问者同时访问同一个页面。PHP可以处理吗?我用这种方法做对了吗?

提前感谢您提供任何信息和提示。

顺便说一句,我还没有考虑使用这些模板。

4

3 回答 3

1

一般来说,如果可能的话,谈论缓存总是个好主意,我想你的 xml 解决方案不会引起太多的性能问题。但是您可以考虑改用Memcache(这可能更方便)。

如果您出于某种原因不想使用 Memcache 而是使用 XML 缓存,并且您不确定它是否会损害或提高性能,您可以简单地对 SQL 查询和缓存解决方案进行基准测试,然后进行比较。

然而,在我看来,这听起来像是过早的优化。您的博客真的同时获得 300 名访问者还是一些虚构的案例?

于 2012-10-19T20:38:53.380 回答
0

明天应该发布的XAP 9.1 就包含了这个功能。

我们意识到需要缓存 XML 数据并使用 XPath 对其进行查询,因此我们添加了一个新的原生 XML API。

[免责声明我在 GigaSpaces 工作]

于 2012-10-20T08:19:07.600 回答
0

我相信memcached可以自动做这样的事情,我会尝试重用已经存在的东西而不是重新发明轮子..

于 2012-10-19T20:36:22.890 回答