在我的生产环境中,我们遇到了一个我们认为是由Storable.pm创建的损坏的可存储哈希。我无法在开发环境中复制这种行为,这使得确诊变得困难。
这段代码已经运行了很长时间,而导致它出错的改变是从哈希表中删除数据。直到最近,哈希表的大小要么保持不变,要么增加。
该文件以读写方式打开,然后store_fd将数据写入文件。由于哈希表现在(有时)更小,所以它只会向这个2000字节的文件写入1000字节。剩下的1000字节是旧的、垃圾数据。在我的测试用例中,当我检索哈希表时,垃圾数据被忽略,正如预期的那样。
这段代码已经运行了很长时间,而导致它出错的改变是从哈希表中删除数据。直到最近,哈希表的大小要么保持不变,要么增加。
该文件以读写方式打开,然后store_fd将数据写入文件。由于哈希表现在(有时)更小,所以它只会向这个2000字节的文件写入1000字节。剩下的1000字节是旧的、垃圾数据。在我的测试用例中,当我检索哈希表时,垃圾数据被忽略,正如预期的那样。
open( $sf, "+< $self->{mod_state_filename}" );
flock( $sf, LOCK_EX );
$self->{mod_state} = fd_retrieve($sf);
delete ($self->{mod_state}{"somekey"});
seek( $sf, 0, 0 );
store_fd( $self->{mod_state}, $sf );
flock( $sf, LOCK_UN )
close($sf);
我的问题:
- 这个代码应该可以工作,还是必须要截断文件?
- 存储的哈希值是否使用了某种文件终止符?如果有,它是什么?
- 上面的代码,在我的测试用例中删除、添加、删除、添加,运行得非常完美。你能否提供任何可能会因为未截断文件而导致失败的测试用例序列呢?(我知道这是一个非常模糊的问题,所以请随意忽略它。)