Redis2#
El módulo Para instalar el módulo, use uno de los siguientes paquetes: Angie: Angie PRO: Para trabajar con el módulo, debe cargarse en el contexto Advertencia ¡Importante! A diferencia de la directiva Ejemplos de trabajo con el módulo. Aquí El valor Ejecutando comandos Redis arbitrarios: La documentación detallada y el código fuente están disponibles en:
openresty/redis2-nginx-module.redis2
proporciona la capacidad de interactuar con un servidor
Redis 2.x. Implementa el protocolo Redis 2.0 unificado completo, incluyendo soporte
para pipelining de Redis.Instalación#
angie-module-redis2
angie-pro-module-redis2
Carga del módulo#
main{}
.
El ejemplo a continuación también usa directivas del módulo set-misc:load_module modules/ndk_http_module.so;
load_module modules/ngx_http_set_misc_module.so;
load_module modules/ngx_http_redis2_module.so;
Ejemplo de configuración#
upstream redis_upstream {
server 127.0.0.1:6379;
}
server {
listen 80;
server_name localhost;
# Establecer valor de clave
location /foo {
set $value 'first';
redis2_query set one $value;
redis2_pass redis_upstream;
}
# Obtener valor por clave
location /bar {
redis2_query get one;
redis2_pass redis_upstream;
}
# Establecer valor de clave desde parámetros de consulta
location /set {
set_unescape_uri $key $arg_key;
set_unescape_uri $val $arg_val;
redis2_query set $key $val;
redis2_pass 127.0.0.1:6379;
}
# Obtener valor por clave desde parámetros de consulta
location /get {
set_unescape_uri $key $arg_key;
redis2_query get $key;
redis2_pass 127.0.0.1:6379;
}
# Ejecutar múltiples comandos en pipeline
location /pipeline {
set $value 'first';
redis2_query set one $value;
redis2_query get one;
redis2_query set one 'first first';
redis2_query get one;
redis2_pass 127.0.0.1:6379;
}
# Ejecutar comando arbitrario pasado en parámetro de consulta
location /cmd {
set_unescape_uri $cmd $arg_command;
redis2_raw_query "$cmd\r\n";
redis2_pass 127.0.0.1:6379;
}
}
proxy_pass
en Angie, no está permitido usar variables en el parámetro de la directiva redis2_pass
.Demostración de ejecución de solicitudes#
$ curl localhost/foo
+OK
$ curl localhost/bar
$5
first
$5
es la longitud del valor (5 bytes), y first
es el valor mismo.$ curl 'localhost/set/?key=two&val=second%20value'
+OK
$ curl 'localhost/get/?key=two'
$12
second value
$ curl 'localhost/get/?key=three'
$-1
$-1
indica que la clave three
no existe.$ curl localhost/pipeline
+OK
$5
first
+OK
$11
first first
$ curl 'localhost/cmd/?command=set%20three%20"third%20value"'
+OK
$ curl 'localhost/cmd/?command=get%20three'
$11
third value
Información adicional#