sql >> Base de Datos >  >> NoSQL >> Redis

¿Cómo utilizar la inserción masiva de Redis?

Aquí está:

echo -n '*3\r\n$3\r\nset\r\n$3\r\nkey\r\n$5\r\nvalue\r\n' | ./redis-cli --pipe
All data transferred. Waiting for the last reply...
Last reply received from server.
errors: 0, replies: 1

Su problema probablemente proviene de los separadores cr+lf. Puede usar el comando hexdump -C para verificar este punto:

echo -n '*3\r\n$3\r\nset\r\n$3\r\nkey\r\n$5\r\nvalue\r\n' | hexdump -C
00000000  2a 33 0d 0a 24 33 0d 0a  73 65 74 0d 0a 24 33 0d  |*3..$3..set..$3.|
00000010  0a 6b 65 79 0a 0d 24 35  0d 0a 76 61 6c 75 65 0d  |.key..$5..value.|
00000020  0a                                                |.|
00000021

Además, es posible que desee verificar que su objetivo sea una instancia de Redis reciente y no una versión anterior a la 1-2 (que no es compatible con el "protocolo unificado").

Nota: las líneas anteriores funcionan bien con zsh. Si usa bash, debe agregar $ antes de la cotización para activar la cotización ANSI-C:

echo -n $'*3\r\n$3\r\nset\r\n$3\r\nkey\r\n$5\r\nvalue\r\n' | hexdump -C