빠른 시작: Java에서 Redisson Redis 클라이언트와 Azure Cache for Redis 사용
이 빠른 시작에서는 Redisson Redis 클라이언트와 JCP 표준 JCache API를 사용하여 Java 앱에 Azure Cache for Redis를 통합합니다. 이러한 서비스를 통해 Azure 내의 모든 애플리케이션에서 액세스할 수 있는 안전한 전용 캐시에 액세스할 수 있습니다. 이 문서에서는 Redis 연결에 사용할 Azure ID를 선택하는 두 가지 옵션을 제공합니다.
GitHub의 코드로 건너뛰기
이 빠른 시작에서는 Maven 아키타입 기능을 사용하여 앱 스캐폴딩을 생성합니다. 빠른 시작에서는 생성된 코드를 수정하여 작업 샘플 앱에 도달하도록 안내합니다. 완료된 코드로 바로 건너뛰려면 GitHub의 Java 빠른 시작을 참조하세요.
필수 조건
- Azure 구독 - 체험 구독 만들기
- 캐시 인증에 Microsoft Entra ID 사용
- Apache Maven
Azure Cache for Redis 만들기
캐시를 만들려면 Azure Portal에 로그인합니다. 포털 메뉴에서 리소스 만들기를 선택합니다.
시작 창의 검색 창에서 Aure Cache for Redis를 입력합니다. 검색 결과에서 Azure Cache for Redis를 찾은 다음, 만들기를 선택합니다.
새 Redis Cache 창의 기본 탭에서 캐시에 대해 다음 설정을 구성합니다.
설정 작업 설명 구독 Azure 구독을 선택합니다. Azure Cache for Redis의 새 인스턴스를 만드는 데 사용할 구독. 리소스 그룹 리소스 그룹을 선택하거나 새로 만들기를 선택하고 새 리소스 그룹 이름을 입력합니다. 캐시 및 기타 리소스를 만들 리소스 그룹의 이름. 모든 앱 리소스를 하나의 리소스 그룹에 배치하면 앱 리소스를 쉽게 관리하거나 삭제할 수 있습니다. DNS 이름 고유한 이름을 입력합니다. 캐시 이름은 숫자, 문자 및 하이픈만 포함하는 1~63자의 문자열이어야 합니다. 이름은 숫자 또는 문자로 시작하고 끝나야 하며 연속 하이픈을 포함할 수 없습니다. 캐시 인스턴스의 호스트 이름은 \<DNS name>.redis.cache.windows.net
입니다.위치 위치를 선택합니다. 캐시를 사용하는 다른 서비스 근처에 있는 Azure 지역. 캐시 SKU SKU를 선택합니다. SKU는 캐시에 사용할 수 있는 크기, 성능 및 기능 매개 변수를 결정합니다. 자세한 내용은 Azure Cache for Redis 개요를 참조하세요. 캐시 크기 캐시 크기를 선택합니다. 자세한 내용은 Azure Cache for Redis 개요를 참조하세요. 네트워킹 탭을 선택하거나 다음: 네트워킹을 선택합니다.
네트워킹 탭에서 캐시에 사용할 연결 방법을 선택합니다.
고급 탭을 선택하거나 다음: 고급을 선택합니다.
고급 창에서 다음 정보에 따라 인증 방법을 확인하거나 선택합니다.
- 기본적으로 새 기본, 표준 또는 프리미엄 캐시의 경우 Microsoft Entra 인증이 활성화되고 액세스 키 인증이 비활성화됩니다.
- 기본 또는 표준 캐시의 경우 비 TLS 포트 선택 영역을 선택/해제할 수 있습니다.
- 표준 및 프리미엄 캐시의 경우 가용성 영역을 사용하도록 선택할 수 있습니다. 캐시를 만든 후에는 가용성 영역을 비활성화할 수 없습니다.
- 프리미엄 캐시의 경우 비 TLS 포트, 클러스터링, 관리 ID 및 데이터 지속성에 대한 설정을 구성합니다.
Important
최적의 보안을 위해 관리 ID와 함께 Microsoft Entra ID를 사용하여 가능한 경우 캐시에 대한 요청에 권한을 부여하는 것이 좋습니다. Microsoft Entra ID 및 관리 ID를 사용한 인증은 공유 액세스 키 인증에 비해 뛰어난 보안과 사용 편의성을 제공합니다. 캐시에서 관리 ID를 사용하는 방법에 대한 자세한 내용은 캐시 인증을 위한 Microsoft Entra ID 사용을 참조하세요.
(선택 사항) 태그 탭을 선택하거나 다음: 태그를 선택합니다.
(선택 사항) 태그 탭에서 캐시 리소스를 분류하려는 경우 태그 이름과 값을 입력합니다.
검토 + 만들기 단추를 선택합니다.
검토 + 만들기 탭에서 Azure는 자동으로 구성의 유효성을 검사합니다.
녹색 유효성 검사 통과 메시지가 표시되면 만들기를 선택합니다.
새 캐시 배포는 몇 분 동안 발생합니다. Azure Cache for Redis 개요 창에서 배포 진행률을 모니터링할 수 있습니다. 상태가 실행 중으로 표시되면 캐시를 사용할 준비가 된 것입니다.
Azure Portal에서 호스트 이름, 포트 및 액세스 키를 검색합니다.
Azure Cache for Redis 서버를 연결하려면 캐시 클라이언트에 캐시에 대한 호스트 이름, 포트 및 키가 필요합니다. 일부 클라이언트는 약간 다른 이름으로 이러한 항목을 참조할 수 있습니다. Azure Portal에서 호스트 이름, 포트 및 키를 가져올 수 있습니다.
액세스 키를 가져오려면 리소스 메뉴에서 인증을 선택합니다. 그런 다음 액세스 키 탭을 선택합니다.
캐시의 호스트 이름과 포트를 확인하려면 리소스 메뉴에서 개요를 선택합니다. 호스트 이름은 <DNS name>.redis.cache.windows.net 형식입니다.
작업 환경 설정
이 섹션의 단계에서는 Redis 연결에 사용되는 Azure ID를 선택하는 방법에 대한 두 가지 옵션을 설명합니다. 샘플 코드는 AUTH_TYPE
환경 변수의 값을 살펴보고 값에 따라 작업을 수행합니다.
ID 옵션 1: Redis 키를 사용한 인증
운영 체제에 따라 캐시의 호스트 이름 및 기본 액세스 키에 대한 환경 변수를 추가합니다. 명령 프롬프트 또는 터미널 창을 열고 다음 값을 설정합니다.
export REDIS_CACHE_HOSTNAME=<your-host-name>.redis.cache.windows.net
export REDIS_CACHE_KEY=<your-primary-access-key>
export AUTH_TYPE=RedisKey
자리 표시자를 다음 값으로 바꿉니다.
<your-host-name>
: Azure Portal에 있는 Azure Cache for Redis 리소스의 속성 섹션에서 가져온 DNS 호스트 이름입니다.<your-primary-access-key>
: Azure Portal에 있는 Azure Cache for Redis 리소스의 액세스 키 섹션에서 가져온 기본 액세스 키입니다.
ID 옵션 2: Microsoft Entra ID를 사용한 인증
운영 체제에 따라 캐시의 호스트 이름 및 사용자 이름에 대한 환경 변수를 추가합니다. 명령 프롬프트 또는 터미널 창을 열고 다음 값을 설정합니다.
export REDIS_CACHE_HOSTNAME=<your-host-name>.redis.cache.windows.net
export USER_NAME=<user-name>
export AUTH_TYPE=MicrosoftEntraID
자리 표시자를 다음 값으로 바꿉니다.
<your-host-name>
:Azure Portal에 있는 Azure Cache for Redis 리소스의 속성 섹션에서 가져온 DNS 호스트 이름입니다.<user-name>
: 관리 ID 또는 서비스 사용자의 개체 ID입니다.
새 Java 앱 만들기
Maven을 사용하여 새 빠른 시작 앱을 생성합니다.
mvn archetype:generate \
-DarchetypeGroupId=org.apache.maven.archetypes \
-DarchetypeArtifactId=maven-archetype-quickstart \
-DarchetypeVersion=1.3 \
-DinteractiveMode=false \
-DgroupId=example.demo \
-DartifactId=redis-redisson-test \
-Dversion=1.0
새로운 redis-redisson-test 프로젝트 디렉터리로 변경합니다.
pom.xml 파일을 열고 Redisson에 대한 종속성을 추가합니다.
<dependency>
<groupId>com.azure</groupId>
<artifactId>azure-identity</artifactId>
<version>1.8.2</version>
</dependency>
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson</artifactId>
<version>3.24.3</version>
</dependency>
pom.xml 파일을 저장합니다.
App.java를 열고 코드를 다음 코드로 바꿉니다.
package example.demo;
import com.azure.core.credential.TokenRequestContext;
import com.azure.identity.DefaultAzureCredential;
import com.azure.identity.DefaultAzureCredentialBuilder;
import org.redisson.Redisson;
import org.redisson.api.RedissonClient;
import org.redisson.config.Config;
import org.redisson.jcache.configuration.RedissonConfiguration;
import javax.cache.Cache;
import javax.cache.CacheManager;
import javax.cache.Caching;
import javax.cache.configuration.Configuration;
import javax.cache.configuration.MutableConfiguration;
import java.time.LocalDateTime;
/**
* Redis test
*
*/
public class App {
public static void main(String[] args) {
Config redissonconfig = getConfig();
RedissonClient redissonClient = Redisson.create(redissonconfig);
MutableConfiguration<String, String> jcacheConfig = new MutableConfiguration<>();
Configuration<String, String> config = RedissonConfiguration.fromInstance(redissonClient, jcacheConfig);
// Perform cache operations using JCache
CacheManager manager = Caching.getCachingProvider().getCacheManager();
Cache<String, String> map = manager.createCache("test", config);
// Simple get and put of string data into the cache
System.out.println("\nCache Command : GET Message");
System.out.println("Cache Response : " + map.get("Message"));
System.out.println("\nCache Command : SET Message");
map.put("Message",
String.format("Hello! The cache is working from Java! %s", LocalDateTime.now()));
// Demonstrate "SET Message" executed as expected
System.out.println("\nCache Command : GET Message");
System.out.println("Cache Response : " + map.get("Message"));
redissonClient.shutdown();
}
private static Config getConfig(){
if ("MicrosoftEntraID".equals(System.getenv("AUTH_TYPE"))) {
System.out.println("Auth with Microsoft Entra ID");
return getConfigAuthWithAAD();
} else if ("RedisKey".equals(System.getenv("AUTH_TYPE"))) {
System.out.println("Auth with Redis key");
return getConfigAuthWithKey();
}
System.out.println("Auth with Redis key");
return getConfigAuthWithKey();
}
private static Config getConfigAuthWithKey() {
// Connect to the Azure Cache for Redis over the TLS/SSL port using the key
Config redissonconfig = new Config();
redissonconfig.useSingleServer().setPassword(System.getenv("REDIS_CACHE_KEY"))
.setAddress(String.format("rediss://%s:6380", System.getenv("REDIS_CACHE_HOSTNAME")));
return redissonconfig;
}
private static Config getConfigAuthWithAAD() {
//Construct a Token Credential from Identity library, e.g. DefaultAzureCredential / ClientSecretCredential / Client CertificateCredential / ManagedIdentityCredential etc.
DefaultAzureCredential defaultAzureCredential = new DefaultAzureCredentialBuilder().build();
// Fetch a Microsoft Entra token to be used for authentication.
String token = defaultAzureCredential
.getToken(new TokenRequestContext()
.addScopes("acca5fbb-b7e4-4009-81f1-37e38fd66d78/.default")).block().getToken();
// Connect to the Azure Cache for Redis over the TLS/SSL port using the key
Config redissonconfig = new Config();
redissonconfig.useSingleServer()
.setAddress(String.format("rediss://%s:6380", System.getenv("REDIS_CACHE_HOSTNAME")))
.setUsername(System.getenv("USER_NAME")) // (Required) Username is Object ID of your managed identity or service principal
.setPassword(token); // Microsoft Entra access token as password is required.
return redissonconfig;
}
}
이 코드는 Redisson 클라이언트 라이브러리의 JCache API 지원과 함께 Microsoft Entra ID를 사용하여 Azure Cache for Redis 인스턴스에 연결하는 방법을 설명합니다. 코드는 또한 캐시에 문자열 값을 저장하고 검색합니다. JCache에 대한 자세한 내용은 JCache 사양을 참조하세요.
App.java를 저장합니다.
앱 빌드 및 실행
다음 Maven 명령을 실행하여 앱을 빌드 및 실행합니다.
다음 출력에서 이전에 Message
키에는 마지막 실행에서 설정된 캐시된 값이 있었음을 확인할 수 있습니다. 앱에서 캐시된 값을 업데이트했습니다.
Cache Command : GET Message
Cache Response : Hello! The cache is working from Java! 2023-12-05T15:13:11.398873
Cache Command : SET Message
Cache Command : GET Message
Cache Response : Hello! The cache is working from Java! 2023-12-05T15:45:45.748667
리소스 정리
다음 자습서로 계속 진행할 계획이라면 이 빠른 시작에서 만든 리소스를 유지하여 다시 사용할 수 있습니다.
그렇지 않고, 빠른 시작 샘플 애플리케이션 사용이 끝나면 이 빠른 시작에서 만든 Azure 리소스를 삭제하여 요금이 청구되는 것을 방지할 수 있습니다.
Important
리소스 그룹 삭제는 취소할 수 없으며 해당 리소스 그룹 및 해당 그룹 안에 있는 모든 리소스는 영구적으로 삭제됩니다. 잘못된 리소스 그룹 또는 리소스를 자동으로 삭제하지 않도록 해야 합니다. 유지하려는 리소스가 포함된 기존 리소스 그룹 내에서 이 샘플을 호스팅하는 리소스를 만든 경우 리소스 그룹을 삭제하는 대신, 각 리소스를 개별적으로 삭제할 수 있습니다.
Azure Portal에 로그인하고 리소스 그룹을 선택합니다.
이름을 기준으로 필터링 텍스트 상자에 리소스 그룹의 이름을 입력합니다. 이 문서의 지침에서는
TestResources
라는 리소스 그룹을 사용했습니다. 결과 목록의 리소스 그룹에서 테스트 리소스와 리소스 그룹 삭제를 차례로 선택합니다.리소스 그룹의 이름을 입력하여 삭제를 확인한 다음 삭제를 선택합니다.
잠시 후, 리소스 그룹 및 해당 그룹에 포함된 모든 리소스가 삭제됩니다.
다음 단계
이 빠른 시작에서는 Redisson Redis 클라이언트와 JCache를 사용하여 Java 애플리케이션에서 Azure Cache for Redis를 사용하는 방법을 알아보았습니다. ASP.NET 웹앱에서 Azure Cache for Redis를 사용하려면 다음 빠른 시작으로 계속 진행하세요.