我正在尝试解冻在64位Solaris(生产)计算机上使用Storable冻结的数据库BLOB。当我尝试在32位Windows(开发)PC上解冻时,我收到“字节顺序不兼容错误”。
perl -v (on solaris)
This is perl, v5.8.8 built for i86pc-solaris-64
perl -v (on Windows)
This is perl, v5.10.1 built for MSWin32-x86-multi-thread
确切错误是:
(Unable to read: Byte order is not compatible at blib\lib\Storable.pm (autosplit into blib\lib\auto\Storable\thaw.al) line 415, at ../handlers/Search/actions/SearchSendQueue.pm line 124 )
SearchSendQueue.pm的第124行:
my $object = thaw( $item->{object} );
有人知道如何在32位机器上解冻这个对象吗?
注意:该对象有效且可在64位生产计算机上运行。 我已经尝试过“$ Storable :: interwork_56_64bit = 1;”正如其他论坛所建议的那样。
答案 0 :(得分:8)
Storable文档说:
Storable写入一个文件头,其中包含构建Storable的C编译器的各种C语言类型的大小(当不按网络顺序写入时),并且将拒绝加载由Storable写入的文件而不是相同(或兼容) )建筑。
在同一部分中,他们建议Storable的基本用法是本地和 FAST 持久性方法。但是,您可以使用nstore
以 network 字节顺序存储持久化结构。结果是它读取和存储速度较慢,但适用于所有平台。
因此,建议您必须使用64位计算机使用nstore
以网络顺序读取和重新存储数据。
答案 1 :(得分:5)
我知道文档表明它应该是可能的,但除非在64位计算机上使用nfreeze / nstore *,否则我无法使其工作。