ngx_http_memcached_module + длинный ключ
asv
asv at pallant-mobile.ru
Mon Jan 14 12:10:15 MSK 2008
Онаружилась интересная вещь: memcached (проверялось в 1.2.1 и 1.2.4 под
FreeBSD 6.0) не сохраняет данные по некоторым ключам длиннее, чем 256 байт
При включенном логе memcache видно вот что (ключ взят, что называется, "из
головы"):
new client connection
>>set
>>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
0 3600 3
>>STORED
>>get
>>xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
>>CLIENT_ERROR bad command line format
здесь видно, что от ключа при set-е отрезается конец.
Вопрос: как защититься от такой ситуции при использовании
ngx_http_memcached_module c Request-URI в качестве ключа (обязать uri быть
короче 256 байт как то кисло...)?
Так и тянет написать нечто вроде
set $memcached_key md5("$uri");
Тогда уж точно будет работать стабильно -- все ключи
гарантированно короткой длины.
--
С уважением,
Сергей Аверьянов
More information about the nginx-ru
mailing list