 Practical Use of Hashes
Practical Use of Hashes
We'll fully assemble our application and test it using Redis and Spring Boot. Caching will significantly speed up request processing and reduce the load on the database.
Brief Summary from the Video
In our program, we used the following logic: when a user is added to the main database, their data is not cached because it's not necessary yet.
@Transactional
public User createUser(User user) {
    return userRepository.save(user);
}
The createUser method simply saves the user to the database.
When a request comes in to fetch a user's data by ID, we first check if the information is available in the Redis cache. This helps avoid unnecessary database queries if the data is already cached.
@Transactional
@Cacheable(value = "user-cache", key = "#id")
@SneakyThrows
public User getUserById(Long id) {
    Thread.sleep(100);
    return userRepository.findById(id).orElseThrow(
            () -> new RuntimeException(String.format("User with this id: %d not found", id))
    );
}
Using the @Cacheable annotation, we cache the data under the key user-cache, which includes the value of the id (user-cache:20 for a user with ID 20). If the data is in the cache, it is retrieved and returned. If the data is not in the cache, the method queries the database.
When deleting data from the database, it's important to remove it from the cache as well to ensure the data remains consistent and outdated information is not used.
@CacheEvict(value="user-cache", key="#id")
public void deleteUser(Long id) {
    userRepository.deleteById(id);
}
The deleteUser method deletes the user from the database and clears their data from the Redis cache to prevent using outdated information in future queries.
Benefits of Caching
Now for the exciting part — why did we implement caching? After adding the Redis cache, requests became much faster — literally up to 20 times faster! This is clearly demonstrated in the screenshots below.
Before Caching
Before implementing caching, each request went directly to the database, resulting in significant delays during processing.
After Caching
With caching in place, most requests are now handled by Redis, which significantly reduces response time.
Summary
Caching with Redis has allowed us to optimize the application's performance, speed up request processing, and reduce the load on the database. This approach is especially beneficial for high-traffic applications where request processing speed is crucial.
¡Gracias por tus comentarios!
Pregunte a AI
Pregunte a AI
Pregunte lo que quiera o pruebe una de las preguntas sugeridas para comenzar nuestra charla
Awesome!
Completion rate improved to 3.33 Practical Use of Hashes
Practical Use of Hashes
Desliza para mostrar el menú
We'll fully assemble our application and test it using Redis and Spring Boot. Caching will significantly speed up request processing and reduce the load on the database.
Brief Summary from the Video
In our program, we used the following logic: when a user is added to the main database, their data is not cached because it's not necessary yet.
@Transactional
public User createUser(User user) {
    return userRepository.save(user);
}
The createUser method simply saves the user to the database.
When a request comes in to fetch a user's data by ID, we first check if the information is available in the Redis cache. This helps avoid unnecessary database queries if the data is already cached.
@Transactional
@Cacheable(value = "user-cache", key = "#id")
@SneakyThrows
public User getUserById(Long id) {
    Thread.sleep(100);
    return userRepository.findById(id).orElseThrow(
            () -> new RuntimeException(String.format("User with this id: %d not found", id))
    );
}
Using the @Cacheable annotation, we cache the data under the key user-cache, which includes the value of the id (user-cache:20 for a user with ID 20). If the data is in the cache, it is retrieved and returned. If the data is not in the cache, the method queries the database.
When deleting data from the database, it's important to remove it from the cache as well to ensure the data remains consistent and outdated information is not used.
@CacheEvict(value="user-cache", key="#id")
public void deleteUser(Long id) {
    userRepository.deleteById(id);
}
The deleteUser method deletes the user from the database and clears their data from the Redis cache to prevent using outdated information in future queries.
Benefits of Caching
Now for the exciting part — why did we implement caching? After adding the Redis cache, requests became much faster — literally up to 20 times faster! This is clearly demonstrated in the screenshots below.
Before Caching
Before implementing caching, each request went directly to the database, resulting in significant delays during processing.
After Caching
With caching in place, most requests are now handled by Redis, which significantly reduces response time.
Summary
Caching with Redis has allowed us to optimize the application's performance, speed up request processing, and reduce the load on the database. This approach is especially beneficial for high-traffic applications where request processing speed is crucial.
¡Gracias por tus comentarios!