Redis와 함께 Java 응용 프로그램에서 캐싱 레이어 구현
redis는 데이터베이스로드를 줄이고 빠른 데이터 검색을 가능하게하여 성능을 향상시키기 위해 Java 응용 프로그램의 캐싱에 사용됩니다. 1. docker : docker run -d -p 6379 : 6379 redis를 사용하여 Redis 설치. 2. pom.xml에 스프링 부트 스타터-다타-빨간색과 상추 코어 의존성을 추가하십시오. 3. 호스트, 포트 및 풀 설정으로 Application.yml에서 redis 연결을 구성하십시오. 4. @EnableCaching을 사용하여 READISCONFIG 클래스를 작성하고 Genericjackson2jsonRedisserializer를 사용하여 JSON 직렬화를 위해 Redistemplate를 사용자 정의하십시오. 5. @Cachable을 사용하여 캐시 또는 실행 및 캐시, @CachePut에서 검색하여 실행 후 캐시를 업데이트하고 캐시 된 데이터를 제거하려면 @CacheEvict. 6. Entryttl (duration.ofminutes (10))로 readiscachemanager bean을 정의하여 10 분 만료를 설정하십시오. 7. Keys *와 같은 Redis-Cli 명령을 사용하여 캐시를 모니터링하고 "사용자 :: 1"을 얻습니다. 8. 캐시 히트 및 누락을 검증하기 위해 단위 테스트를 작성하십시오. 모범 사례에는 의미있는 키 사용, 캐시에서 크거나 민감한 데이터를 피하고 캐시 처리 처리가 우아하게 미스, 선택적으로 시작시 캐시를 따뜻하게하는 것이 포함됩니다. Spring Boot와의 통합은 캐싱 구현을 단순화하면서 응용 프로그램 성능 및 확장 성을 크게 향상시킵니다.
Redis를 사용하여 Java 애플리케이션에 캐싱 레이어를 추가하면 데이터베이스로드를 줄이고 데이터 검색 속도를 높이면 성능이 크게 향상 될 수 있습니다. 효과적으로 구현하는 방법은 다음과 같습니다.

캐싱에 Redis를 사용하는 이유는 무엇입니까?
Redis는 속도, 유연성 및 다양한 데이터 구조에 대한 지원으로 유명한 메모리 데이터 저장소입니다. 캐싱에 이상적입니다.
- 데이터는 RAM에 저장되므로 밀리 초 이하의 읽기/쓰기 작업이 가능합니다.
- 유명한 데이터를 관리하는 데 도움이되는 만료 (TTL)를 지원합니다.
- 상추 및 제디와 같은 고객을 통해 Java와 잘 통합됩니다.
1 단계 : REDIS 및 종속성 설정
먼저, Redis가 실행 중인지 확인하십시오. 로컬로 설치하거나 Docker를 사용할 수 있습니다.

Docker Run -D -P 6379 : 6379 Redis
그런 다음 pom.xml
(Maven의 경우)에 필요한 종속성을 추가하십시오.
<의존성> <groupid> org.springframework.boot </groupid> <artifactid> 스프링 부트 스타터-다타-레 디스 </artifactid> </의존성> <의존성> <groupid> io.lettuce </groupid> <artifactid> 상추-코어 </artifactid> </의존성>
양상추는 비동기 및 비 블로킹 기능으로 인해 스프링 부팅에 권장되는 Redis 클라이언트입니다.

2 단계 : 스프링 부팅에서 Redis를 구성하십시오
application.yml
또는 application.properties
에서 redis 연결을 구성하십시오.
봄: Redis : 호스트 : LocalHost 포트 : 6379 상추: 수영장: 최대 활동 : 8 Max-Idle : 8 민오 : 0
필요한 경우 RedisConnectionFactory
및 RedisTemplate
사용자 정의 할 수도 있습니다.
@구성 @EnableCaching 공개 클래스 readisconfig { @콩 public redistemplate <string, 객체> redistemplate (readisconnectionFactory ConnectionFactory) { Redistemplate <String, Object> Template = New Redistemplate <> (); template.setConnectionFactory (ConnectionFactory); template.setKeyserializer (new StringRedisserializer ()); template.setValueserializer (새로운 genericjackson2jsonredisserializer ()); 리턴 템플릿; } }
GenericJackson2JsonRedisSerializer
사용하면 복잡한 Java 객체를 JSON에 직렬화하고 Redis에 저장할 수 있습니다.
3 단계 : 캐싱 주석을 활성화하고 사용하십시오
@EnableCaching
사용하여 기본 응용 프로그램 클래스 또는 구성 클래스에 주석을 달 수 있습니다.
@SpringBootApplication @EnableCaching 공공 수업 응용 프로그램 { public static void main (String [] args) { SpringApplication.run (application.class, args); } }
이제 서비스 계층에서 캐싱 주석을 사용하십시오.
@서비스 공개 클래스 사용자 서비스 { @autowired 개인 userpository userrepository; @Cachable (value = "user", key = "#id") 공개 사용자 getUserByid (긴 ID) { System.out.println ( "DB에서 사용자 가져 오기 :"id); return userrepository.findbyid (id) .orelse (null); } @cacheput (value = "user", key = "#user.id") 공개 사용자 updateUser (사용자 사용자) { return userrepository.save (user); } @cacheevict (value = "user", key = "#id") 공개 void deleteuser (Long Id) { userreepository.deletebyid (id); } }
-
@Cacheable
: 먼저 캐시를 확인합니다. 존재하는 경우 캐시 된 값을 반환합니다. 그렇지 않으면 메소드를 실행하고 결과를 캐시합니다. -
@CachePut
: 항상 메소드를 실행하고 캐시를 업데이트합니다. -
@CacheEvict
: 캐시에서 항목을 제거합니다 (작업 삭제에 유용).
4 단계 : 캐시 만료 및 퇴거를 처리합니다
오래된 데이터를 피하기 위해 TTL (Time-to-Live)을 설정하십시오. 구성에서 전 세계적으로 정의 할 수 있습니다.
@콩 Public readiscacheManager CacheManager (RediscOntectionFactory ConnectionFactory) { readiscacheconfiguration config = readiscacheconfiguration.defaultCacheconFig () .entryttl (duration.ofminutes (10)) // 캐시는 10 분 후 만료됩니다 .SerializeKeysWith (redisserializationContext.SerializationPair.fromserializer (new StringRedisserializer ())) .SerializeValuesSwith (redisserializationContext.SerializationPair.Fromserializer (New Genericjackson2jsonRedisserializer ()); RECONER READISCACHEMANAGER.BUILDER (ConnectionFactory) .cachedefaults (config) .짓다(); }
이를 통해 캐시 된 사용자는 10 분 후에 자동으로 제거됩니다.
5 단계 : 캐시를 모니터링하고 테스트합니다
Redis CLI를 사용하여 캐시 된 데이터를 검사하십시오.
레 디스 클리 > 키 * > "사용자 :: 1"받기
또한 캐싱 동작을 확인하기 위해 단위 테스트를 작성하십시오.
@시험 void dourdcacheuseronfirstcall () { uservice.getUserById (1L); // db 히트 uservice.getUserById (1L); // 캐시해야합니다 // DB가 한 번만 호출됩니다 }
Spring 's CacheManager
또는 로깅과 같은 도구를 사용하여 HITS/MISSES를 확인하십시오.
모범 사례
- 의미있는 캐시 키 사용 : 복잡한 키 또는 긴 키보다
@Cacheable(value = "users", key = "#id")
선호하십시오. - 크거나 민감한 데이터를 캐시하지 마십시오 . 캐시를 가볍고 안전하게 유지하십시오.
- 캐시 미스 계획 : Redis가 다운되었거나 데이터가 캐시되지 않은 경우 앱이 여전히 작동해야합니다.
- 필요한 경우 시작하는 동안 중요한 데이터에 캐시 온난화를 사용하십시오 .
기본적으로 Redis를 Java (특히 Spring Boot 포함)의 캐싱 레이어로 통합하는 것은 간단하며 즉각적인 성능 이득을 제공합니다. 적절한 구성과 주석을 현명하게 사용하면 코드를 복잡하게하지 않고도 대기 시간 및 데이터베이스 압력을 줄일 수 있습니다.
위 내용은 Redis와 함께 Java 응용 프로그램에서 캐싱 레이어 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

해시 맵은 Java의 해시 테이블을 통해 키 값 쌍 스토리지를 구현하며, 그 핵심은 데이터 위치를 빠르게 배치하는 데 있습니다. 1. 먼저 키의 hashcode () 메소드를 사용하여 해시 값을 생성하고 비트 작업을 통해 배열 인덱스로 변환합니다. 2. 다른 객체가 동일한 해시 값을 생성하여 충돌을 일으킬 수 있습니다. 현재 노드는 링크 된 목록의 형태로 장착됩니다. JDK8 후 링크 된 목록이 너무 길고 (기본 길이 8) 효율을 향상시키기 위해 빨간색과 검은 색 트리로 변환됩니다. 3. 사용자 정의 클래스를 키로 사용하는 경우 equals () 및 hashcode () 메소드를 다시 작성해야합니다. 4. 해시 맵은 용량을 동적으로 확장합니다. 요소 수가 용량을 초과하고 하중 계수 (기본 0.75)를 곱하면 확장 및 재사용; 5. 해시 맵은 스레드 안전이 아니며 Multithreaded에서 Concu를 사용해야합니다.

선택 사항은 의도를 명확하게 표현하고 널 판단에 대한 코드 노이즈를 줄일 수 있습니다. 1. 옵션. ofnullable은 null 객체를 다루는 일반적인 방법입니다. 예를 들어, 맵에서 값을 가져올 때 Orelse는 기본값을 제공하는 데 사용하여 논리가 명확하고 간결합니다. 2. 체인 호출 맵을 사용하여 중첩 값을 달성하여 NPE를 안전하게 피하고 링크가 널이면 자동으로 종료되고 기본값을 반환합니다. 3. 필터는 조건부 필터링에 사용될 수 있으며, 조건이 충족되는 경우에만 후속 작업이 계속 수행됩니다. 그렇지 않으면 가벼운 비즈니스 판단에 적합한 Orelse로 직접 이동합니다. 4. 기본 유형이나 간단한 논리와 같은 선택적 사례를 과도하게 사용하는 것은 권장되지 않으므로 복잡성을 증가 시키며 일부 시나리오는 NU로 직접 돌아갑니다.

java.io.notserializableException을 만나기위한 핵심 해결 방법은 직렬화 해야하는 모든 클래스가 직렬화 가능한 인터페이스를 구현하고 중첩 된 객체의 직렬화 지원을 확인하는지 확인하는 것입니다. 1. 메인 클래스에 상해를 추가하십시오. 2. 클래스의 해당 커스텀 필드 클래스가 세련된 세포화 가능하도록하십시오. 3. 직렬화 할 필요가없는 마크 필드에 과도를 사용하십시오. 4. 수집 또는 중첩 된 물체에서 비 시리얼 유형을 점검하십시오. 5. 인터페이스를 구현하지 않는 클래스를 확인하십시오. 6. 키 데이터 저장 또는 직렬화 가능한 중간 구조 사용과 같이 수정할 수없는 클래스의 교체 설계를 고려하십시오. 7. 수정을 고려하십시오

Java의 문자 인코딩 문제를 처리하려면 키는 각 단계에서 사용되는 인코딩을 명확하게 지정하는 것입니다. 1. 텍스트를 읽고 쓰는 시점에 항상 인코딩을 지정하고 InputStreamReader 및 OutputStreamWriter를 사용하고 시스템 기본 인코딩에 의존하지 않도록 명시 적 문자 세트를 전달하십시오. 2. 네트워크 경계에서 문자열을 처리 할 때 양쪽 끝이 일관되도록하고 올바른 컨텐츠 유형 헤더를 설정하고 라이브러리와 인코딩을 명시 적으로 지정하십시오. 3. String.getBytes () 및 Newstring (byte [])을주의해서 사용하고 플랫폼 차이로 인한 데이터 손상을 피하기 위해 항상 Standardcharsets.utf_8을 수동으로 지정하십시오. 요컨대,

Javasocket 프로그래밍은 네트워크 통신의 기초이며, 클라이언트와 서버 간의 데이터 교환은 소켓을 통해 실현됩니다. 1. Java의 소켓은 클라이언트가 사용하는 소켓 클래스와 서버에서 사용하는 서버 소켓 클래스로 나뉩니다. 2. 소켓 프로그램을 작성할 때 먼저 서버 청취 포트를 시작한 다음 클라이언트의 연결을 시작해야합니다. 3. 커뮤니케이션 프로세스에는 연결 설정, 데이터 읽기 및 쓰기 및 스트림 폐쇄가 포함됩니다. 4. 예방 조치에는 포트 충돌을 피하고 IP 주소를 올바르게 구성하고, 자원을 합리적으로 폐쇄하고, 여러 클라이언트를 지원하는 것이 포함됩니다. 이것들을 마스터하면 기본 네트워크 통신 기능을 실현할 수 있습니다.

Java에서는 비교 가능성이 기본 정렬 규칙을 내부적으로 정의하는 데 사용되며 비교기는 여러 정렬 로직을 외부로 정의하는 데 사용됩니다. 1. 클래스 자체가 구현 한 인터페이스입니다. 비교 () 메소드를 다시 작성하여 자연 순서를 정의합니다. 문자열 또는 정수와 같은 고정되고 가장 일반적으로 사용되는 분류 방법이있는 클래스에 적합합니다. 2. 비교기는 외부 정의 된 기능 인터페이스이며, 동일한 클래스에 여러 정렬 방법이 필요한 상황에 적합한 Compare () 메소드를 통해 구현되며, 클래스 소스 코드를 수정할 수 없거나 정렬 로직이 종종 변경됩니다. 둘의 차이점은 비교할 수있는 분류 논리 만 정의 할 수 있으며 클래스 자체를 수정하면서 비교할 필요가 있다는 것입니다.

Java에는지도를 가로 지르는 세 가지 일반적인 방법이 있습니다. 1. Entryset을 사용하여 키와 값을 동시에 얻으십시오. 이는 대부분의 시나리오에 적합합니다. 2. 키즈 또는 값을 사용하여 각각 키 또는 값을 가로 지르십시오. 3. 코드 구조를 단순화하려면 Java8의 foreach를 사용하십시오. Entryset은 모든 키 값 쌍이 포함 된 세트 세트를 반환하고 각 루프는 맵을 가져옵니다. 열 객체는 키와 값에 자주 액세스하기에 적합합니다. 키나 값 만 필요한 경우 각각 Keyset () 또는 values ()를 호출하거나 키를 가로 질러 Map.Get (키)를 통해 값을 얻을 수 있습니다. Java 8은 foreach ((키, 값)-& gt를 사용할 수 있습니다

injava, thestatickeywordmeansamembeLongstotheclassitself, nottoinstances.StaticvariablesAresharedAcrossAllInstances 및 OutObjectCreation, 유용한 ForgloBalTrackingorConstants.StaticMethodsOperateateAteAteClassEvel, canceCcessnon-StaticMbers, statice
