0

我正在为我的 codeigniter 应用程序创建一个数据库驱动的路由。问题是,如果我的表中有超过 X 几十行,我的应用程序运行速度非常慢!问题是我没有使用或从我创建的路由表中获取任何信息。

事实上,我在我的应用程序的缓存文件夹中使用路由文件。

所以这是我没有缓存文件和数据库为空的:

在此处输入图像描述

0.0071 / 0,0196 / 0.0268

这是我的 20.000 行和缓存文件的内容:(缓存文件为 20.000 行)

在此处输入图像描述

0.2637 / 0,0114 / 0.2752

这是我对空数据库和缓存文件的看法:(缓存文件为 20.000 行)

在此处输入图像描述

0.0036 / 0.0142 / 0.0179

所以,我不知道为什么我在这三个基准之间有这么大的差异!

有没有办法缓存数据库或对此做些什么?

如果有人可以帮助我,请提前致谢。

4

1 回答 1

0

在我的第一个案例中,我使用的是这样的 Hooks:

require_once APPPATH."config/database.php";

$hook['pre_system'] = array(
     'class'    => 'Router_Hook',
     'function' => 'get_routes',
     'filename' => 'Router_Hook.php',
     'filepath' => 'hooks',
     'params'   => array($db['default']['hostname'],$db['default']['username'],$db['default']['password'],$db['default']['database'],$db['default']['dbprefix'],)
                        );

在我的 router_hook 文件中,我有:

function get_routes($params)
{
    global $DB_ROUTES;

    mysql_connect($params[0], $params[1], $params[2]);

    mysql_select_db($params[3]);

    $sql = "SELECT * FROM {$params[4]}routes";
    $query = mysql_query($sql);

    $routes = array();
    while ($route = mysql_fetch_array($query, MYSQL_ASSOC)) {
        $routes[$route['route']] = $route['controller'];
    }
    mysql_free_result($query);
    mysql_close();
    $DB_ROUTES = $routes;
}

我的路由中包含 config/routes.php 中的全局变量

现在我将它更改为缓存文件夹中的缓存版本 => cache/routes.php 并将其包含在我的 config/routes.php

所以我不再需要我的钩子了 => 性能提升!

于 2013-03-16T09:43:47.330 回答