可道云kodexplorer报错database disk image is malformed

owncloud, nextcloud应该同理,这类网盘如果你同样是使用的php内置的sqlite作为数据库管理软件,解决方法大同小异。

报错信息

出错了! (warning!)think_trace();
database disk image is malformed[SQL statement]:SELECT COUNT(*) AS tp_count FROM `group` WHERE ( parentID = '1' )

报错原因我猜测是因为我将可道云安装在了外置硬盘,而不知什么情况我移动硬盘的设备标识符/dev/sdc3改变了,变成了/dev/sdb3,而我用的磁盘管理软件diskman自动挂载路径随之改变成/mnt/sdb3,个人猜测就是应该是因为这个原因导致的。

解决方法

因为用的是php内置的sqlite3,所以数据库文件名后缀是.php而不是.sql或者什么.db

在kodexplorer程序目录下的data/system目录下有一个php文件,可以通过ls -lh查看占用空间最大的那个基本就没错了,我生产环境上的文件路径是/mnt/sdb3/kodexplorer/data/system/t8ZuK56w4Tny.php,文件大小大概是5、6兆。
如果我没记错的话,owncloud的文件结构好像也差不多,在程序的根路径下同样有个data目录。

cd /mnt/sdb3/kodexplorer/data/system/
# 备份
cp t8ZuK56w4Tny.php t8ZuK56w4Tny.php.bak
sqlite3 t8ZuK56w4Tny.php .dump > tmp.php
vim tmp.php

不会用vim就用nano编辑文本,跳转最后一行,将最后一行ROLLBACK; -- due to errors修改成COMMIT;保存退出。BTW, vim按两次Shift+z就可以保存退出,比:wq方便多了。

sqlite3 t8ZuK56w4Tny.php < tmp.php

DONE!

参考:sqlite关于The database disk image is malformed问题的解决


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部