真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

redis如何進(jìn)行序列化

redis如何進(jìn)行序列化?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(jiǎn)單易行的方法。

創(chuàng)新互聯(lián)專(zhuān)注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計(jì)、興縣網(wǎng)絡(luò)推廣、成都小程序開(kāi)發(fā)、興縣網(wǎng)絡(luò)營(yíng)銷(xiāo)、興縣企業(yè)策劃、興縣品牌公關(guān)、搜索引擎seo、人物專(zhuān)訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供興縣建站搭建服務(wù),24小時(shí)服務(wù)熱線:18980820575,官方網(wǎng)址:www.cdcxhl.com

序列化最終的目的是為了對(duì)象可以跨平臺(tái)存儲(chǔ),和進(jìn)行網(wǎng)絡(luò)傳輸。而我們進(jìn)行跨平臺(tái)存儲(chǔ)和網(wǎng)絡(luò)傳輸?shù)姆绞骄褪荌O,而我們的IO支持的數(shù)據(jù)格式就是字節(jié)數(shù)組。

通過(guò)上面我想你已經(jīng)知道了凡是需要進(jìn)行“跨平臺(tái)存儲(chǔ)”和”網(wǎng)絡(luò)傳輸”的數(shù)據(jù),都需要進(jìn)行序列化。

本質(zhì)上存儲(chǔ)和網(wǎng)絡(luò)傳輸 都需要經(jīng)過(guò) 把一個(gè)對(duì)象狀態(tài)保存成一種跨平臺(tái)識(shí)別的字節(jié)格式,然后其他的平臺(tái)才可以通過(guò)字節(jié)信息解析還原對(duì)象信息。

redis序列化方式對(duì)比:

redis的默認(rèn)方式是JdkSerializationRedisSerializer

JdkSerializationRedisSerializer: 使用JDK提供的序列化功能。

優(yōu)點(diǎn)是反序列化時(shí)不需要提供類(lèi)型信息(class),但缺點(diǎn)是需要實(shí)現(xiàn)Serializable接口,還有序列化后的結(jié)果非常龐大,是JSON格式的5倍左右,這樣就會(huì)消耗redis服務(wù)器的大量?jī)?nèi)存。

Jackson2JsonRedisSerializer: 使用Jackson庫(kù)將對(duì)象序列化為JSON字符串。

優(yōu)點(diǎn)是速度快,序列化后的字符串短小精悍,不需要實(shí)現(xiàn)Serializable接口。

但缺點(diǎn)也非常致命,那就是此類(lèi)的構(gòu)造函數(shù)中有一個(gè)類(lèi)型參數(shù),必須提供要序列化對(duì)象的類(lèi)型信息(.class對(duì)象)。 通過(guò)查看源代碼,發(fā)現(xiàn)其只在反序列化過(guò)程中用到了類(lèi)型信息。

問(wèn)題:使用默認(rèn)的JDK序列化方式,在RDM工具中查看k-v值時(shí)會(huì)出現(xiàn)“亂碼”,不方便查看。

解決:自定義系列化方式,使用Jackson2JsonRedisSerializer

import com.fasterxml.jackson.annotation.JsonAutoDetect;
import com.fasterxml.jackson.annotation.PropertyAccessor;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
import org.springframework.data.redis.serializer.StringRedisSerializer;

/**
 * Redis配置
 *
 * @author LinJie
 */
@Configuration
public class RedisConfig {

    /**
     * Redis repository redis repository.
     *
     * @param redisTemplate the redis template
     * @return the redis repository
     */
    @Bean
    public RedisRepository redisRepository(RedisTemplate redisTemplate) {
        // 使用Jackson2JsonRedisSerialize 替換默認(rèn)序列化
        Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
        ObjectMapper objectMapper = new ObjectMapper();
        objectMapper.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
        objectMapper.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
        jackson2JsonRedisSerializer.setObjectMapper(objectMapper);
        StringRedisSerializer stringRedisSerializer = new StringRedisSerializer();
        // key采用String的序列化方式
        redisTemplate.setKeySerializer(stringRedisSerializer);
        // hash的key也采用String的序列化方式
        redisTemplate.setHashKeySerializer(stringRedisSerializer);
        // value序列化方式采用jackson
        redisTemplate.setValueSerializer(jackson2JsonRedisSerializer);
        // hash的value序列化方式采用jackson
        redisTemplate.setHashValueSerializer(jackson2JsonRedisSerializer);
        redisTemplate.afterPropertiesSet();
        return new RedisRepository(redisTemplate);
    }
}

關(guān)于redis如何進(jìn)行序列化問(wèn)題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒(méi)有解開(kāi),可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。


分享文章:redis如何進(jìn)行序列化
網(wǎng)站網(wǎng)址:http://weahome.cn/article/jseode.html

其他資訊

在線咨詢(xún)

微信咨詢(xún)

電話咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部