turbinando drupal com redis
TRANSCRIPT
Turbinando Drupal
comRedis
Daniel Santos - @apachetec
Daniel Santos - Apache
@apachetec
instagram.com/apachetec
slideshare.com/apachetec
Redis - Remote Dictionary Server
Redis é um banco de Dados NoSql. Ele foi criado por Salvatore Sanfilippo, que disponibilizou o código para a comunidade open-source em 2009
Principais diferenças entre Redis comparado ao Memcached
❖ Tipo de Dados
❖ Documentação
❖ Suporte a outras tecnologias
❖ Tamanho do valor suportado
❖ Command line
Tipos de dados suportados pelo Redis
❖ String
❖ Hashes
❖ Lists
❖ Sets
❖ Sorted Sets
String
Redis
String
Funciona da forma tradicional, Chave x Valor.
redis> set mykey "value" // Define um valor do tipo string
Execução
redis> append mykey " last value" // Concatena uma string
redis> hget mykey // Retorna a string associada a chave
redis> strlen mykey // Retorna a quantidade de caracteres de uma string
Hashes
Redis
Hashes
Funciona de uma forma parecida como propriedades em um objeto,
podendo definir uma chave e múltiplos valores com Chave x Valor,
associados a essa única chave.
redis> hset mykey field1 "field1" // Define uma chave x valor a uma key
Execução
redis> hmset mykey field2 "field2" field3 "field3" // Define múltiplos chave x valor a uma key
redis> hget mykey field1 // Retorna o valor de uma propriedade de um hash
redis> hvals mykey // Retorna somente os valores de um hash
Lists
Redis
Lists
Funciona quase como um array indexado, com ele podemos definir uma chave e uma lista de valores
associoados a essa chave.
redis> lpush mykey "value" // Adiciona um valor no topo de uma lista
Execução
redis> lpop mykey // Retorna e remove o primeiro valor de uma lista
redis> rpush mykey "value" // Adiciona um valor no fim de uma lista
redis> llen mykey // Retorna a quantidade de valores em uma lista
Sorted Set
Redis
Sorted Set
Funciona basicamente como o tipo List, salvo que ele não permite valores
duplicados e nos permite realizar ordenações.
redis> zadd mykey 0 "value" // 0 = score (weight)
Execução
redis> zrank mykey "value" // retorna o score do valor
redis> zrangebyscore mykey -inf +inf // Ordena ASC
redis> zrevrangebyscore mykey +inf -inf // Ordena DESC
Drupal + Redis
No Drupal utilizamos o módulo Redis e também temos que utilizar uma
biblioteca para integrarmos o PHP ao Redis.
Drupal + Redis
O próprio módulo sugere as bibliotecas que devemos utilizar
Predis ou PhpRedis.
settings.php
$conf['redis_client_interface'] = 'Predis'; // Definindo a biblioteca que estou utilizando.
$conf['redis_client_host'] = '127.0.0.1'; // Define o host onde está o Server do Redis.
$conf['cache_prefix'] = 'blog_'; // Um prefixo para as chaves que o Drupal irá inserir no Redis, essa configuração é muito importante quando você está utilizando o Drupal com Multi-Sites.
settings.php
Aqui são alguns arquivos que devemos sobrescrever do padrão do Drupal, assim alteramos as configurações padrões de cache, que por padrão é inserido no Banco de Dados.
$conf['lock_inc'] = 'sites/all/modules/contrib/redis/redis.lock.inc';
$conf['path_inc'] = 'sites/all/modules/contrib/redis/redis.path.inc';
$conf['cache_backends'][] = 'sites/all/modules/contrib/redis/redis.autoload.inc';
settings.php
$conf['cache_default_class'] = 'Redis_Cache';$conf['cache_class_cache'] = 'Redis_Cache';$conf['cache_class_page'] = 'Redis_Cache';$conf['cache_class_content'] = 'Redis_Cache';$conf['cache_class_block'] = 'Redis_Cache';$conf['cache_class_views'] = 'Redis_Cache';$conf['cache_class_views_data'] = 'Redis_Cache';$conf['cache_class_cache_form'] = 'Redis_Cache';$conf['cache_class_cache_menu'] = 'Redis_Cache';$conf['cache_class_cache_bootstrap'] = 'Redis_Cache';
Obs:
O Ideal de se trabalhar com Redis, é que ele não esteja no mesmo servidor da sua aplicação, pelo fato de ele usar
a memória RAM para guardar seus dados.
Live Examples
Redis
Dúvidas?
Perguntas
OBRIGADO!!!
Daniel Santos - ApacheWeb Developer Full Stack
Mobile: +55 (11) 9 6624-4654