Как увеличить значения с плавающей запятой с помощью PHP-клиента AeroSpike? Размещение значений с плавающей запятой работает нормально, но приращение заметно нарушает процесс php и возвращает nginx bad gateway.
Код, который я использую:
$key = $db->initKey("test", "queries", 'bench');
$p = array('a' => 2.3);
$db->put($key, $p); // works fine
$db->increment($key, 'a', 4.2); // php process crashes at this point
Одно из наших производственных приложений также столкнулось с той же проблемой, используя Java-клиент Aerospike в качестве писателя и PHP-клиент в качестве читателя. Мы справились с этой проблемой, сохранив нашу валюту в виде двойных длинных целых, преобразовав ее в 12-значную шкалу и отбросив период. Например, $ 1,2345 будет храниться в значении корзины как 1234500000000. Это позволяет нам отправлять инкрементные мультиоперации в Aerospike.
Когда клиент PHP считывает значение для хранения на наш сервер БД для составления отчетов, мы конвертируем 64-битное целое число обратно в двойную 12-разрядную шкалу. 1234500000000 -> 1,2345.
Других решений пока нет …