你没猜错,我就是吃饱了撑的,折腾一下,练下手艺。
大道理当然也会讲嘛,mysql资源占用太大,博客这种东西,不用浪费资源,sqlite足也。(当然,我不会告诉你的是,我rs1000 8g的内存空余7g多,cpu占用是0.00)。
首先,需要导出当前mysql的sql文件,mysqldump人人都会,不用说了。但如果你问gpt的话,它会让你加上一些兼容的参数,一加,反而不行,中文乱码了,所以,用默认的参数导出即可。
然后下载sql语句转换工具,因为sqlite与mysql在sql层级有小小区别。 https://raw.githubusercontent.com/dumblob/mysql2sqlite/master/mysql2sqlite
转换sql文件为sqlite格式,再用sqlite3导入上述的sql文件即可。
将sqlite数据库文件放入php可以访问到的非web的目录(你总不希望别人直接下载你的数据库吧),重要的事情来了,一定要确保这个目录php进程有写权限。sqlite文件自然需要有写权限,但该目录也一定要有写权限,因为在同级目录sqlite会建临时的wal和shm文件。
最后,修改typecho的config.inc.php,将mysql改成sqlite:

$db = new Typecho_Db('Pdo_SQLite', 'typecho_');
$db->addServer(array (
  'file' => 'sqlite文件绝对路径',
), \Typecho\Db::READ | \Typecho\Db::WRITE);

如果php没有安装pdo_sqlite模块的话,也需要装一下。
在配置文件中加上define("__TYPECHO_DEBUG__",true); 可以看到详细的出错信息,如果你不幸出错了的话。

标签: none

添加新评论

*如果只是需要与我沟通联系,请telegram @ohyessure, 而不要用评论方式,因为没有你的个人资料,我无法回复及联络你。