typecho一直都是用的mysql作为数据库存储,最近因为服务器到期需要迁移网站,所有的服务都转到docker了,迁移起来略显麻烦,因此就想抛弃mysql了,直接使用sqlite作为存储。这样迁移网站只要复制一下db文件就可以了,不用每次都得搭个mysql或者容器,简单方便。

typecho本身就是支持sqlite的,只不过在安装的时候如果选择了mysql,就没有办法在界面上更改数据库类型了,要修改只能通过改代码配置来完成。数据库的配置放在网站根路径下的config.inc.php文件中,有这么一段:

/** 定义数据库参数 */
$db = new Typecho_Db('Pdo_Mysql', 'tp_');
$db->addServer(array (
  'host' => 'db',
  'user' => 'xxxxx',
  'password' => 'xxxxxx',
  'charset' => 'utf8',
  'port' => '3306',
  'database' => 'typecho',
), Typecho_Db::READ | Typecho_Db::WRITE);
Typecho_Db::set($db);

要想改成sqlite的方式,只需修改配置为以下内容即可:

/** 定义数据库参数 */
$db = new Typecho_Db('Pdo_SQLite', 'tp_');
$db->addServer(array (
  'file' => '/xx/xx/xx/xx.db',
), Typecho_Db::READ | Typecho_Db::WRITE);
Typecho_Db::set($db);

修改之后即可生效,但这里还缺少了重要的一步:迁移数据。如何迁移数据可参考使用Navicate迁移Mysql到Sqlite

迁移完成后的几处安全建议:

  1. 不要将db文件放到网站目录内,可能导致db文件通过外部链接下载
  2. db文件命名尽量随机,不要轻易被人猜出
  3. 如果db文件放在网站目录内,要在nginx配置设置访问db文件直接返回404

迁移之后如何验证切换成功了:

  1. 确认网站可以正常访问
  2. 每查看一次网站,都会导致db文件更新,可通过后台查看文件更新时间是不是最新

最后修改:2021 年 08 月 22 日
喜欢就给我点赞吧