婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > redis 存儲對象的方法對比分析

redis 存儲對象的方法對比分析

熱門標簽:超呼電話機器人 山東外呼銷售系統招商 貴州電銷卡外呼系統 北京400電話辦理收費標準 十堰營銷電銷機器人哪家便宜 鄭州人工智能電銷機器人系統 魔獸2青云地圖標注 日本中國地圖標注 宿遷便宜外呼系統平臺

redis 存儲對象的方法對比

問題背景:

原來項目里面全部是直接redis存儲對象的json數據,需要頻繁的序列化和反序列化,后來考慮更換項目中的redis存儲對象為hash對象存儲的,但是獲取后不能方便的set get操作,很是蛋疼,怎么才能解決這個問題呢?

1.1 直接存儲對象的json

存放redis的時候,直接先用fastJson 或者 jackJson或者Gson把對象序列化為json數據,然后用直接存放,key表示用戶id或許和openid,value則是對象的json數據

public String get(String key) {
Object value = redisTemplate.boundValueOps(key).get();
return (String) value;
}
public void set(String key, String json) {
if (json == null) {
return;
}
redisTemplate.boundValueOps(key).set(json);
}

優點:雖然需要序列化和反序列化,但是可以直接操作對象的方法,方便快捷

缺點:需要序列化和反序列化,并且修改單個字段,需要獲取整個json,修改后,序列化保存,浪費空間,浪費時間,效率低

1.2 采用redis hash key field value 存儲

key代表主鍵,比如用戶id,或者openId,value是一個map,對應各個字段的屬性和值

存放單個字段

public void hset(String key, String field, String obj) {
redisTemplate.boundHashOps(key).put(field,obj);
}

存放整個:

public void hSetMap(String key,MapObject,Object> map){
redisTemplate.boundHashOps(key).putAll(map);
}

優點:存儲方方便,節省內存空間,并且可以直接對單個字段修改,而不用獲取整個對象,效率高

缺點:獲取value后,是個map,不能方便的直接調用(set get)處理,需要手動map.get(filed)或者map.put(field,value)

1.3 如何解決redis hash存儲對象的操作方便性問題

其實關于map和pojo的轉換問題,網上給出了利用反射做的轉換方法,但是加上了轉換和反轉,這和序列化和反序列化的問題一樣了,效率問題,也不敢指直接用,糾結,思考再三,還是先維持代碼不動了,以后考慮好了再說,或者廣發網友有啥好解決方法,請多多指教哈!

Redis存儲對象的三種方式

一、 將對象序列化后保存到Redis

序列化工具類實現

public class SerializeUtil {
    /*
     * 序列化
     * */
    public static byte[] serizlize(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();
        }finally {
            try {
                if(baos != null){
                    baos.close();
                }
                if (oos != null) {
                    oos.close();
                }
            } catch (Exception e2) {
                e2.printStackTrace();
            }
        }
        return null;
    }
    /*
     * 反序列化
     * */
    public static Object deserialize(byte[] bytes){
        ByteArrayInputStream bais = null;
        ObjectInputStream ois = null; 
        try{
            bais = new ByteArrayInputStream(bytes);
            ois = new ObjectInputStream(bais);
            return ois.readObject();
        }catch(Exception e){
            e.printStackTrace();
        }finally {
            try {
 
            } catch (Exception e2) {
                e2.printStackTrace();
            }
        }
        return null;
    }
}

獲取jedis實例

public class RedisConnection {
    private static String HOST = "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 = 10000;
 
    private static JedisPool jedisPool = null;
 
    /*
     * 初始化redis連接池
     * */
    private static void initPool(){
        try {
            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxTotal(MAX_ACTIVE);//最大連接數
            config.setMaxIdle(MAX_IDLE);//最大空閑連接數
            config.setMaxWaitMillis(MAX_WAIT);//獲取可用連接的最大等待時間
 
            jedisPool = new JedisPool(config, HOST, PORT);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
 
    /*
     * 獲取jedis實例
     * */
    public synchronized static Jedis getJedis() {
        try {
            if(jedisPool == null){
                initPool();
            }
            Jedis jedis = jedisPool.getResource();
            jedis.auth("redis");//密碼
            return jedis;
        } catch (Exception e) {
            e.printStackTrace();
            return null;
        }
    }
}

redis操作類

public class RedisOps {
    public static void set(String key,String value){
        Jedis jedis = RedisConnection.getJedis();
        jedis.set(key, value);
        jedis.close();
    }
    public static String get(String key){
        Jedis jedis = RedisConnection.getJedis();
        String value = jedis.get(key);
        jedis.close();
        return value;
    }
    public static void setObject(String key,Object object){
        Jedis jedis = RedisConnection.getJedis();
        jedis.set(key.getBytes(), SerializeUtil.serizlize(object));
        jedis.close();
    }
    public static Object getObject(String key){
        Jedis jedis = RedisConnection.getJedis();
        byte[] bytes = jedis.get(key.getBytes());
        jedis.close();
        return SerializeUtil.deserialize(bytes);
    }
}

User對象

public class User implements Serializable{
    private static final long serialVersionUID = -3210884885630038713L;
    private int id;
    private String name;
    public User(){
 
    }
    public User(int id,String name){
        this.id = id;
        this.name = name;
    }
    //setter和getter方法
}

測試

public class RedisTest {
 
    @Test
    public void testString(){
        RedisOps.set("user:1", "sisu");
        String user = RedisOps.get("user:1");
        Assert.assertEquals("sisu", user);
    }
 
    @Test
    public void testObject(){
        RedisOps.setObject("user:2",new User(2,"lumia"));
        User user = (User)RedisOps.getObject("user:2");
        Assert.assertEquals("lumia", user.getName());
    } 
}

二、將對象用FastJSON轉為JSON字符串后存儲

redis操作類

public class RedisOps {
    public static void setJsonString(String key,Object object){
        Jedis jedis = RedisConnection.getJedis();
        jedis.set(key, JSON.toJSONString(object));
        jedis.close();
    }
    public static Object getJsonObject(String key,Class clazz){
        Jedis jedis = RedisConnection.getJedis();
        String value = jedis.get(key);
        jedis.close();
        return JSON.parseObject(value,clazz);
    }
}

測試

 @Test
    public void testObject2(){
        RedisOps.setJsonString("user:3", new User(3,"xiaoming"));
        User user = (User)RedisOps.getJsonObject("user:3",User.class);
        Assert.assertEquals("xiaoming", user.getName());
    }

三、將對象用Hash數據類型存儲

redis操作類

public class RedisOps {
    public static void hSet(String key,String value){
        Jedis jedis = RedisConnection.getJedis();
        jedis.hSet(key, value);
        jedis.close();
    }
    public static String hGet(String key){
        Jedis jedis = RedisConnection.getJedis();
        String value = jedis.hGet(key);
        jedis.close();
        return value;
    }
}

測試

 @Test
    public void testObject3(){
     //存
        RedisOps.hSet("user:3","id","3");
        RedisOps.hSet("user:3","name","xiaoming");
        
        //取
        String id =  RedisOps..hGet("user:3","id");
        String name = RedisOps.hGet("user:3","name");
        Assert.assertEquals("3", id);
        Assert.assertEquals("xiaoming", name);        
    }

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Redis緩存-序列化對象存儲亂碼問題的解決
  • Redis如何存儲對象與集合示例詳解
  • 淺談Redis存儲數據類型及存取值方法

標簽:果洛 江蘇 楊凌 北京 大慶 朝陽 吉安 臺州

巨人網絡通訊聲明:本文標題《redis 存儲對象的方法對比分析》,本文關鍵詞  redis,存儲,對象,的,方法,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《redis 存儲對象的方法對比分析》相關的同類信息!
  • 本頁收集關于redis 存儲對象的方法對比分析的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    樱花影视一区二区| 亚洲chinese男男1069| 国产精品毛片高清在线完整版| 日本伊人午夜精品| 欧美亚洲国产bt| 亚洲成人精品一区二区| 色综合夜色一区| 亚洲高清久久久| 欧美精品一二三四| 日本在线不卡视频| 欧美电影在线免费观看| 日本午夜一本久久久综合| 久久理论电影网| 成人精品免费视频| 亚洲人成人一区二区在线观看| 91美女视频网站| 亚洲亚洲精品在线观看| 欧美日本韩国一区| 久久成人免费网| 国产欧美日韩激情| 99国产精品久| 亚洲va国产va欧美va观看| 欧美一级电影网站| 国产精品自在欧美一区| 亚洲丝袜另类动漫二区| 日韩一区二区三| 成人动漫一区二区三区| 一区二区三区在线免费| 精品少妇一区二区| 91原创在线视频| 国产一区二区三区免费看| 亚洲女人****多毛耸耸8| 91精品国产91综合久久蜜臀| 成人午夜在线免费| 人人超碰91尤物精品国产| 久久se精品一区精品二区| 久久久久久97三级| 欧美久久久久久久久久| 成人网页在线观看| 麻豆视频观看网址久久| 中文字幕中文在线不卡住| 91精品在线观看入口| 99国产精品99久久久久久| 久久国产夜色精品鲁鲁99| 亚洲摸摸操操av| 久久这里只有精品首页| 欧美在线一二三| 粉嫩av一区二区三区| 美女网站一区二区| 亚洲一区二区三区精品在线| 亚洲国产成人在线| 精品国产乱码久久久久久浪潮 | 黄网站免费久久| 亚洲人精品午夜| 久久综合999| 91精品国产91久久久久久一区二区 | 韩国成人福利片在线播放| 一区二区三区在线观看欧美| 成人高清视频在线| 日韩av一区二区三区四区| 亚洲高清不卡在线观看| 综合亚洲深深色噜噜狠狠网站| 日韩一级完整毛片| 欧美性感一类影片在线播放| 亚洲精品亚洲人成人网在线播放| 一色桃子久久精品亚洲| 久久奇米777| 欧美一区二区在线观看| 欧美一区在线视频| 精品人在线二区三区| 制服丝袜在线91| 欧美日高清视频| 91丨九色丨蝌蚪丨老版| 成人夜色视频网站在线观看| 久久aⅴ国产欧美74aaa| 久久激情五月激情| 青青草国产成人99久久| 日本视频中文字幕一区二区三区| 一区二区三区精品久久久| 亚洲综合无码一区二区| 亚洲成人免费电影| 欧美精品日韩综合在线| 91超碰这里只有精品国产| 欧美一级爆毛片| 2020国产精品| 久久久不卡网国产精品二区| 久久久久久久久久久久电影 | 欧美成人一区二区三区片免费 | 亚洲午夜日本在线观看| 亚洲国产美国国产综合一区二区| 亚洲一区二区三区四区在线观看| 图片区小说区国产精品视频| 激情六月婷婷久久| 成熟亚洲日本毛茸茸凸凹| 91麻豆免费视频| 欧美一区二区三区日韩视频| 久久久久久一二三区| 亚洲蜜桃精久久久久久久| 亚洲在线中文字幕| 久久97超碰国产精品超碰| 不卡av免费在线观看| 欧美日韩国产中文| 久久精品免费在线观看| 亚洲一区二区三区在线看| 久久精品99国产精品日本| www.亚洲人| 欧美浪妇xxxx高跟鞋交| 国产精品传媒入口麻豆| 日本aⅴ亚洲精品中文乱码| 成人免费视频免费观看| 欧美日韩精品免费| 国产精品免费免费| 日本va欧美va精品发布| 成人免费的视频| 欧美蜜桃一区二区三区| 欧美精品一区二区三区四区| 亚洲成人av电影| av在线不卡网| 精品久久国产97色综合| 一区二区三区高清不卡| 国产精品一区二区无线| 日韩一区二区三区免费看| 亚洲美女视频一区| 国产精品一二三在| 91精品在线免费| 亚洲韩国一区二区三区| 色欧美乱欧美15图片| 久久久久久久久久久电影| 日本成人在线一区| 欧美性一区二区| 中文成人av在线| 成人免费视频视频| 国产婷婷色一区二区三区| 日本aⅴ精品一区二区三区 | 蜜桃视频第一区免费观看| 欧美精品第1页| 亚洲免费观看高清完整版在线| 国产高清久久久| 国产日产欧美一区| 成人性生交大片免费看在线播放| 国产喷白浆一区二区三区| 黑人巨大精品欧美黑白配亚洲| 欧美蜜桃一区二区三区| 日韩高清欧美激情| 69久久99精品久久久久婷婷| 久久超碰97中文字幕| 2014亚洲片线观看视频免费| 精品一区免费av| 精品福利视频一区二区三区| 成人中文字幕合集| 亚洲午夜在线视频| 欧美剧情片在线观看| 日本不卡视频一二三区| 日韩欧美国产电影| 国产在线播放一区二区三区| 国产精品国产三级国产普通话三级| 不卡一区二区中文字幕| 成人免费在线视频| 97精品视频在线观看自产线路二| 国产精品午夜在线观看| 99精品视频中文字幕| 亚洲高清免费观看高清完整版在线观看| 欧美三级在线看| 国产老肥熟一区二区三区| 日本一区二区三区免费乱视频| 成人小视频在线观看| 午夜精品久久久久久久99水蜜桃 | 国产精品一区二区x88av| 国产精品久久久久国产精品日日| 91原创在线视频| 久久9热精品视频| 亚洲日本韩国一区| 欧美精品一区二区三区在线| 欧美在线观看一区二区| 国产麻豆视频一区| 亚洲午夜视频在线| 国产欧美精品在线观看| 欧美无砖砖区免费| 国产成人在线看| 婷婷六月综合亚洲| 日韩美女视频19| 久久久久亚洲蜜桃| 宅男在线国产精品| 91高清视频免费看| 成人午夜视频福利| 国产一区在线视频| 日韩黄色片在线观看| 亚洲精品成人天堂一二三| 中文字幕成人网| 久久嫩草精品久久久精品一| 91精品国产乱| 欧美日韩高清一区二区不卡| 99这里只有精品| 国产精品一线二线三线精华| 青青草国产精品97视觉盛宴| 亚洲成人一区在线| 最新热久久免费视频| 国产精品美日韩| 国产精品毛片无遮挡高清| 国产欧美日韩麻豆91|