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。
迁移完成后的几处安全建议:
- 不要将db文件放到网站目录内,可能导致db文件通过外部链接下载
- db文件命名尽量随机,不要轻易被人猜出
- 如果db文件放在网站目录内,要在nginx配置设置访问db文件直接返回404
迁移之后如何验证切换成功了:
- 确认网站可以正常访问
- 每查看一次网站,都会导致db文件更新,可通过后台查看文件更新时间是不是最新
此处评论已关闭