>데이터 베이스 >Redis >SSM 프로젝트에 Redis 지원을 추가하는 방법 소개

SSM 프로젝트에 Redis 지원을 추가하는 방법 소개

尚
앞으로
2019-12-21 17:45:202127검색

SSM 프로젝트에 Redis 지원을 추가하는 방법 소개

SSM 개발 환경을 설정하고 Redis를 먼저 설치해야 합니다. 구체적인 구현 단계는 다음과 같습니다.

1 프로젝트에 jedis 프레임워크 패키지를 도입합니다: jedis-2.8.2.jar, spring-data. -redis- 1.6.2.RELEASE.jar 및 commons-pool-1.6.jar 도입된 jar 버전에 주의하세요. 위에 언급된 버전 조합은 개인 테스트에 사용할 수 있습니다. . Redis 작성을 위한 요구 사항 RedisUtil.java 및 SerializeUtil.java 두 가지 도구 클래스가 사용됩니다

3. org.apache.ibatis.cache.Cache 인터페이스를 구현하기 위해 새로운 캐시 클래스 MybatisRedisCache를 추가합니다

4. 이 프로젝트에서는 mybatis-config.xml 파일을 수정합니다

5. 해당 mapper.xml에 MybatisRedisCache를 추가합니다.

RedisUtil 도구 클래스는 Redis 데이터와 통신하는 데 사용되며 SerializeUtil은 직렬화 도구 클래스는 lang 패키지 도구 아래에 있으며 주로 직렬화 작업에 사용되며 객체 복제 인터페이스도 제공합니다. 구체적인 코드는 다음과 같습니다.

import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

public class RedisUtil {
    private static String ADDR = "127.0.0.1";
    private static int PORT = 6379;
    private static int MAX_ACTIVE = 1024;

    private static int MAX_IDLE = 200;

    private static int MAX_WAIT = 100000;

    private static int TIMEOUT = 10000;

    private static boolean TEST_ON_BORROW = true;

    private static JedisPool jedisPool = null;

    static {
        try{
            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxIdle(MAX_IDLE);
            config.setMaxWaitMillis(MAX_WAIT);
            config.setTestOnBorrow(TEST_ON_BORROW);
            jedisPool = new JedisPool(config,ADDR,PORT,TIMEOUT);
        }catch (Exception e) {
            e.printStackTrace();
        }
    }

    public synchronized static Jedis getJedis(){
        try{
            if(jedisPool != null){
                Jedis jedis = jedisPool.getResource();
                return jedis;
            }else{
                return null;
            }
        }catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }

    public static void returnResource(final Jedis jedis){
        if(jedis != null){
            jedisPool.returnResource(jedis);
        }
    }
}
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;

public class SerializeUtil {
    public static byte[] serialize(Object object) {
        ObjectOutputStream oos = null;
        ByteArrayOutputStream baos = null;
        try {
            // 序列化
            baos = new ByteArrayOutputStream();
            oos = new ObjectOutputStream(baos);
            oos.writeObject(object);
            byte[] bytes = baos.toByteArray();
            return bytes;
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    public static Object unserialize(byte[] bytes) {
        if (bytes == null)
            return null;
        ByteArrayInputStream bais = null;
        try {
            // 反序列化
            bais = new ByteArrayInputStream(bytes);
            ObjectInputStream ois = new ObjectInputStream(bais);
            return ois.readObject();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }

}

import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

import org.apache.ibatis.cache.Cache;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class MybatisRedisCache implements Cache {

    private static Logger logger = LoggerFactory.getLogger(MybatisRedisCache.class); 

    /** The ReadWriteLock. */ 

    private final ReadWriteLock readWriteLock = new ReentrantReadWriteLock();

    private String id;

    public MybatisRedisCache(final String id) {  

        if (id == null) {

            throw new IllegalArgumentException("Cache instances require an ID");

        }

        logger.debug(">>>>>>>>>>>>>>>>>>>>>>>>MybatisRedisCache:id="+id);

        this.id = id;

    }  
    public String getId() {

        return this.id;

    }
    public void putObject(Object key, Object value) {

        logger.debug(">>>>>>>>>>>>>>>>>>>>>>>>putObject:"+key+"="+value);

        RedisUtil.getJedis().set(SerializeUtil.serialize(key.toString()), SerializeUtil.serialize(value));

    }
    public Object getObject(Object key) {

        Object value = SerializeUtil.unserialize(RedisUtil.getJedis().get(SerializeUtil.serialize(key.toString())));

        logger.debug(">>>>>>>>>>>>>>>>>>>>>>>>getObject:"+key+"="+value);

        return value;
    }
    public Object removeObject(Object key) {

        return RedisUtil.getJedis().expire(SerializeUtil.serialize(key.toString()),0);

    }

 public void clear() {

        RedisUtil.getJedis().flushDB();

    }

   public int getSize() {

        return Integer.valueOf(RedisUtil.getJedis().dbSize().toString());

    }

   public ReadWriteLock getReadWriteLock() {

        return readWriteLock;

    }
}

mybatis-config.xml 파일, spring-mybatis.xml 파일에서 전역 로딩 선택:

<!-- 配置mybatis -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="dataSource" ref="dataSource" />
        <!-- 加载mybatis的全局配置文件 -->
        <property name="configLocation" value="classpath:resource/mybatis-config.xml"></property>
        <!-- mapper扫描 -->
        <property name="mapperLocations" value="classpath:resource/mapper/*.xml"></property>
       </bean>

다음은 mybatis-config.xml의 세부 코드입니다.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD SQL Map Config 3.0//EN"  
    "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>

    <settings>
         <!-- 全局映射器启用缓存 -->
        <setting name="cacheEnabled" value="true"/>

        <!-- 查询时,关闭关联对象即时加载以提高性能 -->
        <setting name="lazyLoadingEnabled" value="false"/>

        <!-- 对于未知的SQL查询,允许返回不同的结果集以达到通用的效果 -->
        <setting name="multipleResultSetsEnabled" value="true"/>

        <!-- 允许使用列标签代替列名 -->
        <setting name="useColumnLabel" value="true"/>

        <!-- 不允许使用自定义的主键值(比如由程序生成的UUID 32位编码作为键值),数据表的PK生成策略将被覆盖 -->
        <setting name="useGeneratedKeys" value="false"/>

        <!-- 给予被嵌套的resultMap以字段-属性的映射支持 FULL,PARTIAL -->
        <setting name="autoMappingBehavior" value="PARTIAL"/>

        <!-- 对于批量更新操作缓存SQL以提高性能 BATCH,SIMPLE -->
        <!-- <setting name="defaultExecutorType" value="BATCH" /> -->

        <!-- 数据库超过25000秒仍未响应则超时 -->
        <!-- <setting name="defaultStatementTimeout" value="25000" /> -->

        <!-- Allows using RowBounds on nested statements -->
        <setting name="safeRowBoundsEnabled" value="false"/>

        <!-- Enables automatic mapping from classic database column names A_COLUMN to camel case classic Java property names aColumn. -->
        <setting name="mapUnderscoreToCamelCase" value="true"/>

        <!-- MyBatis uses local cache to prevent circular references and speed up repeated nested queries. By default (SESSION) all queries executed during a session are cached. If localCacheScope=STATEMENT 
            local session will be used just for statement execution, no data will be shared between two different calls to the same SqlSession. -->
        <setting name="localCacheScope" value="SESSION"/>

        <!-- Specifies the JDBC type for null values when no specific JDBC type was provided for the parameter. Some drivers require specifying the column JDBC type but others work with generic values 
            like NULL, VARCHAR or OTHER. -->
        <setting name="jdbcTypeForNull" value="OTHER"/>

        <!-- Specifies which Object&#39;s methods trigger a lazy load -->
        <setting name="lazyLoadTriggerMethods" value="equals,clone,hashCode,toString"/>
          <!-- 打印sql语句 -->
        <setting name="logImpl" value="STDOUT_LOGGING" />  
</settings>

</configuration>

마지막으로, 캐시해야 하는 매핑 파일을 매퍼의 네임스페이스에 추가합니다. 조건부 쿼리의 경우 이때 SQL이 출력되지 않으면 쿼리 결과가 직접 출력됩니다. 데이터베이스에서 쿼리하여 얻은 결과가 아닌 Redis에서 데이터를 읽어 사용자에게 반환합니다. 이 시점에서 구성이 성공적입니다.

물론 Redis 클라이언트와 서버를 열고 Redis 설치 디렉터리에서 redis-cli를 찾아 두 번 클릭하여 열고 키 *를 입력하고 Enter 키를 누르면 Redis가 필요한 키를 얻는 것을 볼 수 있습니다. 키 값을 기준으로 합니다.

실제 작업 과정에서 RedisUtil 도구 클래스에 주의하시기 바랍니다. 설치된 Redis에 비밀번호가 있는 경우에는 AUTH를 추가해야 합니다. 이 항목을 도구 클래스에 추가하지 마세요. null 값을 할당해도 작동하지 않습니다.

한 번 시도해 본 결과: private static String AUTH = " ";

실행 시 다음 예외가 보고되었습니다. jedis.Exceptions.JedisDataException: ERR 클라이언트가 AUTH를 보냈지만 비밀번호가 설정되지 않았습니다.

는 Redis 서버가 비밀번호를 설정하지 않았지만 클라이언트가 AUTH 요청을 보냈음을 의미합니다. 또한 캐시할 클래스는 직렬화 가능을 구현해야 합니다. 설치한 Redis에 문제가 있다고 의심되는 경우 다음 방법을 통해 테스트할 수 있습니다.

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.krk.sxytj.ytj2001.mapper.YTJ2001Mapper" >
  <cache type="com.krk.sxytj.utils.redis.MybatisRedisCache>

더 많은 Redis 지식을 알고 싶다면

redis 데이터베이스 튜토리얼

칼럼을 주목해 주세요.

위 내용은 SSM 프로젝트에 Redis 지원을 추가하는 방법 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 csdn.net에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제