<!-- review: finished -->

<a id="external-redis2"></a>

# Redis2

O módulo `redis2` fornece a capacidade de interagir com um servidor
Redis 2.x. Ele implementa o protocolo Redis 2.0 unificado completo, incluindo suporte
para pipelining Redis.

<a id="installation-23"></a>

## Instalação

Para [instalar](https://pt.angie.software//angie/docs/installation/index.md#install-packages) o módulo, use um dos seguintes pacotes:

- Angie: `angie-module-redis2`
- Angie PRO: `angie-pro-module-redis2`

<a id="loading-the-module-23"></a>

## Carregando o Módulo

Para trabalhar com o módulo, ele deve ser carregado no contexto `main{}`.
O exemplo abaixo também usa diretivas do módulo [set-misc](https://pt.angie.software//angie/docs/installation/external-modules/set-misc.md#external-set-misc):

```nginx
load_module modules/ndk_http_module.so;
load_module modules/ngx_http_set_misc_module.so;
load_module modules/ngx_http_redis2_module.so;
```

<a id="configuration-example-97"></a>

## Exemplo de Configuração

```nginx
upstream redis_upstream {
    server 127.0.0.1:6379;
}

server {
    listen       80;
    server_name  localhost;

    # Definir um valor de chave
    location /foo {
        set $value 'first';
        redis2_query set one $value;
        redis2_pass redis_upstream;
    }

    # Obter um valor por chave
    location /bar {
        redis2_query get one;
        redis2_pass redis_upstream;
    }

    # Definir um valor de chave a partir de 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;
    }

    # Obter um valor por chave a partir de parâmetros de consulta
    location /get {
        set_unescape_uri $key $arg_key;
        redis2_query get $key;
        redis2_pass 127.0.0.1:6379;
    }

    # Executar múltiplos comandos em 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;
    }

    # Executar um comando arbitrário passado em um 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;
    }
}
```

#### WARNING
Importante! Diferentemente da diretiva `proxy_pass` no Angie, o uso de variáveis no parâmetro da diretiva `redis2_pass` não é permitido.

<a id="request-execution-demonstration"></a>

## Demonstração da Execução de Requisições

Exemplos de trabalho com o módulo.

```console
$ curl localhost/foo
+OK

$ curl localhost/bar
$5
first
```

Aqui `$5` é o comprimento do valor (5 bytes), e `first` é o valor em si.

```console
$ curl 'localhost/set/?key=two&val=second%20value'
+OK

$ curl 'localhost/get/?key=two'
$12
second value

$ curl 'localhost/get/?key=three'
$-1
```

O valor `$-1` indica que a chave `three` não existe.

```console
$ curl localhost/pipeline
+OK
$5
first
+OK
$11
first first
```

Executando comandos Redis arbitrários:

```console
$ curl 'localhost/cmd/?command=set%20three%20"third%20value"'
+OK

$ curl 'localhost/cmd/?command=get%20three'
$11
third value
```

<a id="additional-information-24"></a>

## Informações Adicionais

Documentação detalhada e código fonte estão disponíveis em:
[https://github.com/openresty/redis2-nginx-module](https://github.com/openresty/redis2-nginx-module).
