Domine inglês técnico de programação em 2025, seja qual for seu nível. Inscrição gratuita

Caching em Java: otimize com Ehcache e Redis
Rocketseat

Rocketseat

2 min de leitura
java
A otimização de desempenho é um dos principais desafios para desenvolvedores que desejam criar aplicações robustas e escaláveis. Caching é uma das estratégias mais eficientes para acelerar respostas e reduzir o consumo de recursos, sendo essencial em aplicações de alta performance. Neste artigo, exploraremos duas ferramentas poderosas de caching no ecossistema Java: Ehcache e Redis. Vamos entender seus conceitos, aplicar exemplos práticos e descobrir como escolher a melhor solução para diferentes cenários.

Por que caching é tão importante?

Imagine o seguinte: você visita sua cafeteria favorita diariamente e sempre pede o mesmo café. Em vez de preparar o café do zero a cada visita, o barista deixa a sua bebida pronta assim que você entra na loja. Esse é o princípio do caching: armazenar dados frequentemente acessados em um local de rápido acesso para evitar repetições desnecessárias.
Na prática, caching traz os seguintes benefícios:
  • Velocidade: diminui o tempo de resposta ao evitar acessos repetidos a fontes mais lentas, como bancos de dados. Por exemplo, uma API de produtos pode armazenar no cache os resultados de consultas frequentes, evitando novas buscas ao banco e retornando os dados instantaneamente ao usuário.
  • Escalabilidade: reduz a carga nos servidores, permitindo que a aplicação suporte mais usuários simultaneamente.
  • Eficiência de recursos: minimiza o consumo de CPU e memória, otimizando custos.
  • Melhoria da Experiência do usuário: respostas rápidas mantêm os usuários engajados.

Tipos e estratégias de caching

Antes de mergulharmos no Ehcache e Redis, é importante conhecer os tipos e estratégias de caching:
  • Em memória: armazena dados na RAM, oferecendo acesso extremamente rápido.
  • Distribuído: permite que vários servidores compartilhem o cache, útil para sistemas escaláveis.

Estratégias comuns:

  1. Cache-Aside (Lazy Loading): carrega os dados no cache somente quando requisitados.
  1. Write-Through: atualiza simultaneamente o cache e a fonte de dados.
  1. Read-Through: automatiza a recuperação de dados ao cache quando solicitado.
  1. Time-to-Live (TTL): expira dados automaticamente após um período definido.

Ehcache: caching simples e eficiente em Java

O Ehcache é uma biblioteca open-source projetada para facilitar a implementação de caching em aplicações Java. Ele é ideal para casos onde o foco está no desempenho em memória e na simplicidade de integração.

Vantagens do Ehcache

  • Fácil configuração: pode ser configurado via XML ou programaticamente.
  • Eviction policies: gerencia o tamanho do cache com estratégias como LRU (Least Recently Used).
  • Suporte a múltiplos caches: permite criar caches personalizados para diferentes necessidades.

Exemplo prático com Ehcache

Vamos configurar o Ehcache para armazenar dados em memória de forma eficiente.
1. Adicionando a dependência no Maven:
<dependency> <groupId>org.ehcache</groupId> <artifactId>ehcache</artifactId> <version>3.9.4</version> </dependency>
2. Configuração básica com XML:
<ehcache> <cache alias="exampleCache"> <expiry> <ttl unit="seconds">120</ttl> </expiry> <resources> <heap unit="entries">1000</heap> </resources> </cache> </ehcache>
3. Uso do cache em código:
CacheManager cacheManager = CacheManagerBuilder.newCacheManager(new XmlConfiguration(getClass().getResource("/ehcache.xml"))); Cache<String, String> cache = cacheManager.getCache("exampleCache", String.class, String.class); // Adicionando e recuperando dados do cache cache.put("key1", "value1"); String value = cache.get("key1");

Redis: caching distribuído e escalável

O Redis é uma solução de armazenamento em memória que vai além de caching, suportando diversos tipos de dados e funcionalidades como persistência e clustering. Sua velocidade e escalabilidade o tornam perfeito para aplicações de alto desempenho.

Recursos do Redis

  • Flexibilidade: suporte a tipos de dados como strings, hashes, e listas.
  • TTL embutido: define expiração automática para dados armazenados.
  • Clusterização: permite distribuir o cache entre vários nós para lidar com grandes volumes de dados.
  • Pub/Sub: Ideal para notificação de eventos e invalidação de cache.

Exemplo prático com Redis

1. Adicionando a dependência no Maven:
<dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>4.0.1</version> </dependency>
2. Configuração básica e conexão:
Jedis jedis = new Jedis("localhost"); jedis.set("key1", "value1"); String value = jedis.get("key1"); System.out.println("Retrieved value: " + value);
3. Implementando Cache-Aside com Redis:
public String getFromCacheOrSource(String key) { String value = jedis.get(key); if (value == null) { value = fetchDataFromDatabase(key); // Simula a consulta ao banco jedis.setex(key, 3600, value); // Cache com expiração de 1 hora } return value; }

Ehcache vs. Redis: qual escolher?

Critério
Ehcache
Redis
Armazenamento
Em memória (heap/off-heap)
Em memória (com persistência opcional)
Distribuído
Limitado
Totalmente suportado
Velocidade
Alta
Muito alta
Complexidade
Baixa
Moderada
Casos de Uso
Aplicações locais e simples
Aplicações distribuídas e escaláveis
Escolha o Ehcache se sua aplicação é monolítica ou precisa de um caching rápido e simples. Prefira o Redis para sistemas distribuídos e requisitos avançados.

Elevando o nível do seu código

Dicas de otimização:

  • Monitore o cache: ferramentas como JConsole (Ehcache) e RedisInsight (Redis) ajudam a entender o comportamento do cache, oferecendo uma interface gráfica que facilita o monitoramento, especialmente para iniciantes.
  • Valide o TTL: escolha tempos de expiração adequados para manter os dados atualizados.
  • Implemente cache invalidation: remova ou atualize entradas desatualizadas de forma eficiente.

Conclusão

Caching é uma técnica essencial para melhorar o desempenho de aplicações Java. Ferramentas como Ehcache e Redis oferecem soluções robustas para diferentes cenários. Comece experimentando com as configurações básicas apresentadas neste artigo e explore o potencial dessas ferramentas em seus projetos.
page icon
Quer elevar ainda mais o seu conhecimento em Java e dominar ferramentas como essas? Acesse a formação em Java da Rocketseat e acelere sua evolução na programação!

Aprenda programação do zero e DE GRAÇA

No Discover você vai descomplicar a programação, aprender a criar seu primeiro site com a mão na massa e iniciar sua transição de carreira.

COMECE A ESTUDAR AGORA