我需要将一些 6-8GB 的静态数据作为数组对象存储到共享内存中。数据是从数据库中获取的。我想 fork() 并允许孩子根据索引访问和搜索数组中的元素。
就我而言,我只能使用 shmop() 存储“字符串”。但我想存储一个 PHP 识别为数组对象的数组。
有什么建议么?
我需要将一些 6-8GB 的静态数据作为数组对象存储到共享内存中。数据是从数据库中获取的。我想 fork() 并允许孩子根据索引访问和搜索数组中的元素。
就我而言,我只能使用 shmop() 存储“字符串”。但我想存储一个 PHP 识别为数组对象的数组。
有什么建议么?
看来这可以通过 PHP 的SEM 函数来完成。
它在内部序列化对象。鉴于数据量巨大,性能会随着数据的增加而大幅下降。并且 8GB(并且还在上升)对于 shmop 和 SEM 来说太多了,无法有效处理。
我的替代方法是在需要时简单地查询数据库(同时为每个线程存储一个本地缓存版本),我认为这会更快(尤其是使用 SSD)。所以这些功能不是我要走的路。
shmop 只能真正存储字符串。要存储数组,您需要在存储它之前对其进行序列化,并在使用它之前对其进行反序列化。
您总是可以序列化ArrayObject
并使用 Memcached 将其存储在内存中。
如果你想坚持使用 shmop: 因为shmop_write()
使用字符串来存储数据,你也需要使用serialize()
那里的方法。
使用 PHP 的serialize()
函数。
http://php.net/manual/en/function.serialize.php
我建议编写一个负责序列化/反序列化和写入/读取共享内存的类。