加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

perl – SQLite的磁盘I / O错误

发布时间:2020-12-16 06:15:11 所属栏目:大数据 来源:网络整理
导读:我有一个(小)动态网站(大致)是一个使用SQLite数据库的Perl CGI脚本.包DBI是Perl中使用的抽象层. 大约一周前,我开始看到此错误消息: disk I/O error(10) at dbdimp.c line 271 由于这是运行Apache的托管站点,我无法看到硬盘是否(几乎)已满.访问命令“df”被
我有一个(小)动态网站(大致)是一个使用SQLite数据库的Perl CGI脚本.包DBI是Perl中使用的抽象层.

大约一周前,我开始看到此错误消息:

disk I/O error(10) at dbdimp.c line 271

由于这是运行Apache的托管站点,我无法看到硬盘是否(几乎)已满.访问命令“df”被禁用….但我使用(UNIX)shell命令“yes> blah”来测试磁盘仍然可以创建新文件.我的数据库非常小 – 不到50千字节.

我检查了文件和目录权限:目录和所有父项都是r,x(所有读/可执行文件).包含我的SQLite数据库文件的目录也是一个w(所有写入).数据库文件本身有一个w,一个r(所有读/写).

我写了一个简单的Perl程序来测试我可以运行失败的选择查询:它运行正常.

我在数据库上运行了查询“VACUUM”.我再次尝试了我的测试 – 没有改进.

我将SQLite数据库转储到原始SQL(使用SQLite shell命令“.dump”)并重建.我再次尝试了我的测试 – 没有改进.

有什么建议?我很困惑……通常,上面的列表可以捕获大多数编程/设置错误.

解决方法

不幸的是,sqlite3.h对具体问题的描述并不十分清楚.错误代码10在此处定义:

#define SQLITE_IOERR       10   /* Some kind of disk I/O error occurred */

您可能遇到/ tmp在某些点已满或sqlite无法访问内存以写入其页面缓存的问题.如果您的db是50kb,这是不太可能的,因为sqlite应该能够将页面缓存保存在内存中.

您可以尝试制作数据库的副本,希望sqlite可以读取复制的数据库并更新您的代码以反映:

$sqlite3 your.db
sqlite> begin immediate;
<press CTRL+Z>
$cp your.db copyofyour.db
$exit
sqlite> rollback;

您还应该检查日志以查看是否每次请求或间歇性地发生这种情况.您可能想要查看是否可以访问其他命令来监视服务器运行状况(顶部,免费).能够重现这个问题似乎是你手头的第一项任务.如果您无法一致地重现它,则可能是与内存相关的问题.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读