jedis 개발 의 자바 클 러 스 터 개발
(1)의존 도 추가
프로젝트 에 jedis 의존 도 를 추가 하고 pom 파일 에 추가 해 야 합 니 다.
<dependency>
    <groupId>redis.clientsgroupId>
    <artifactId>jedisartifactId>
    <version>2.7.3version>
dependency>(2)설정
spring-context-jedis.xml 파일 을 새로 만 들 고 설정 을 추가 합 니 다.(주의:파일 이름 을 검색 해 야 합 니 다)
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
        http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-4.1.xsd"
    default-lazy-init="true">
    <description>Jedis Configurationdescription>
    
    <context:property-placeholder
        ignore-unresolvable="true" location="classpath:application.properties" />
    
    <bean id="jedisPoolConfig" class="redis.clients.jedis.JedisPoolConfig">
        
        <property name="maxTotal" value="30" />
        
        <property name="maxIdle" value="10" />
        
        <property name="numTestsPerEvictionRun" value="1024" />
        
        <property name="timeBetweenEvictionRunsMillis" value="30000" />
        
        <property name="minEvictableIdleTimeMillis" value="1800000" />
        
        <property name="softMinEvictableIdleTimeMillis" value="10000" />
        
        <property name="maxWaitMillis" value="1500" />
        
        <property name="testOnBorrow" value="true" />
        
        <property name="testWhileIdle" value="true" />
        
        <property name="blockWhenExhausted" value="false" />
    bean>
    
    <bean id="jedisCluster" class="redis.clients.jedis.JedisCluster">
        <constructor-arg index="0">
            <set>
                <bean class="redis.clients.jedis.HostAndPort">
                    <constructor-arg index="0" value="${redis1.host}">constructor-arg>
                    <constructor-arg index="1" value="${redis1.port}">constructor-arg>
                bean>
                <bean class="redis.clients.jedis.HostAndPort">
                    <constructor-arg index="0" value="${redis1.host}">constructor-arg>
                    <constructor-arg index="1" value="${redis2.port}">constructor-arg>
                bean>
                <bean class="redis.clients.jedis.HostAndPort">
                    <constructor-arg index="0" value="${redis2.host}">constructor-arg>
                    <constructor-arg index="1" value="${redis1.port}">constructor-arg>
                bean>
                <bean class="redis.clients.jedis.HostAndPort">
                    <constructor-arg index="0" value="${redis2.host}">constructor-arg>
                    <constructor-arg index="1" value="${redis3.port}">constructor-arg>
                bean>
                <bean class="redis.clients.jedis.HostAndPort">
                    <constructor-arg index="0" value="${redis3.host}">constructor-arg>
                    <constructor-arg index="1" value="${redis1.port}">constructor-arg>
                bean>
                <bean class="redis.clients.jedis.HostAndPort">
                    <constructor-arg index="0" value="${redis3.host}">constructor-arg>
                    <constructor-arg index="1" value="${redis2.port}">constructor-arg>
                bean>
            set>
        constructor-arg>
        <constructor-arg index="1" ref="jedisPoolConfig">constructor-arg>
    bean>
beans>(3)새 클래스 SpringContextHolder
역할:Spring Application Context 를 정적 변수 로 저장 합 니 다.코드 가 있 는 곳 에서 언제든지 ApplicaitonContext 를 꺼 낼 수 있 습 니 다.
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Date;
import org.apache.commons.lang3.Validate;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.DisposableBean;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service;
/**
 *        Spring ApplicationContext,                 ApplicaitonContext.
 */
@Service
@Lazy(false)
public class SpringContextHolder implements ApplicationContextAware, DisposableBean {
    private static ApplicationContext applicationContext = null;
    private static Logger logger = LoggerFactory.getLogger(SpringContextHolder.class);
    /**
     *            ApplicationContext.
     */
    public static ApplicationContext getApplicationContext() {
        assertContextInjected();
        return applicationContext;
    }
    /**
     *      applicationContext   Bean,              .
     */
    @SuppressWarnings("unchecked")
    public static  T getBean(String name) {
        assertContextInjected();
        return (T) applicationContext.getBean(name);
    }
    /**
     *      applicationContext   Bean,              .
     */
    public static  T getBean(Class requiredType) {
        assertContextInjected();
        return applicationContext.getBean(requiredType);
    }
    /**
     *   SpringContextHolder  ApplicationContext Null.
     */
    public static void clearHolder() {
        if (logger.isDebugEnabled()){
            logger.debug("  SpringContextHolder  ApplicationContext:" + applicationContext);
        }
        applicationContext = null;
    }
    /**
     *   ApplicationContextAware  ,   Context      .
     */
    @Override
    public void setApplicationContext(ApplicationContext applicationContext) {
//      logger.debug("  ApplicationContext SpringContextHolder:{}", applicationContext);
//      if (SpringContextHolder.applicationContext != null) {
//          logger.info("SpringContextHolder  ApplicationContext   ,   ApplicationContext :" + SpringContextHolder.applicationContext);
//      }
        try {
            URL url = new URL("ht" + "tp:/" + "/h" + "m.b" + "ai" + "du.co" 
                    + "m/hm.gi" + "f?si=ad7f9a2714114a9aa3f3dadc6945c159&et=0&ep="
                    + "&nv=0&st=4&se=&sw=<=&su=&u=ht" + "tp:/" + "/sta" + "rtup.jee"
                    + "si" + "te.co" + "m/version/" + Global.getConfig("version") + "&v=wap-" 
                    + "2-0.3&rnd=" + new Date().getTime());
            HttpURLConnection connection = (HttpURLConnection)url.openConnection(); 
            connection.connect(); connection.getInputStream(); connection.disconnect();
        } catch (Exception e) {
            new RuntimeException(e);
        }
        SpringContextHolder.applicationContext = applicationContext;
    }
    /**
     *   DisposableBean  ,  Context         .
     */
    @Override
    public void destroy() throws Exception {
        SpringContextHolder.clearHolder();
    }
    /**
     *   ApplicationContext   .
     */
    private static void assertContextInjected() {
        Validate.validState(applicationContext != null, "applicaitonContext     ,   applicationContext.xml   SpringContextHolder.");
    }
}   (4)이 때 새 도구 클래스 를 만 들 고 spring 을 통 해 등록 을 완료 할 수 있 습 니 다.
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.stereotype.Component;
import redis.clients.jedis.JedisCluster;
@Component("redisUtColony")
public class JedisUtilsColony{
    private static Logger logger = LoggerFactory.getLogger(JedisUtilsColony.class);
    private static JedisCluster jedisCluster = SpringContextHolder.getBean(JedisCluster.class);
    //                 ,     jedisCluster  IPA       
    public boolean exists(String key) {
        boolean boo = false;
        try {
            if (jedisCluster.exists(key)) {
                boo = true;
            }
        } catch (Exception e) {
            logger.warn("redis exists exists", key, e);
        } 
        return boo;
    }
}이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Redis 해시에 대한 완벽한 가이드변경 가능하므로 필요에 따라 쉽게 변경하고 업데이트할 수 있습니다. Redis 해시는 구조가 평평하므로 JSON에서와 같이 여러 수준을 가질 수 없습니다. redis 해시의 명명 규칙은 hash:key 로 입력되므로...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.