<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
redis支援哪些語言可以操作 (去redis官網查詢)
(1)新增jedis依賴
<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <!--只能在測試類中使用--> <scope>test</scope> </dependency> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>3.6.0</version> </dependency>
(2)程式碼測試
public class TestJedis { @Test public void test01(){ //連線redis--必須保證你的redis服務執行遠端連線 //該物件把每個redis命令封裝成對應的方法 //注意埠號 //xshell中的redis要執行起來,注意防火牆釋放埠號,注意組態檔的修改 Jedis jedis=new Jedis("192.168.1.16",6379); //對於字串操作的命令 String set = jedis.set("k1", "v1"); System.out.println(set); String set1 = jedis.set("k2", "v2"); System.out.println(set1); String set2 = jedis.set("k3", "v3"); System.out.println(set2); //對於hash的操作 jedis.hset("k4","name","小花"); Long hset = jedis.hset("k4", "age", "18"); System.out.println(hset); Map<String ,String> map=new HashMap<>(); map.put("name","小明"); map.put("age","20"); Long k = jedis.hset("k5", map); System.out.println(k); jedis.close(); } }
@Test public void test02(){ //建立連線池的設定類 JedisPoolConfig jedisPoolConfig=new JedisPoolConfig(); jedisPoolConfig.setMaxIdle(20); jedisPoolConfig.setMinIdle(5); jedisPoolConfig.setMaxWait(Duration.ofMillis(3000)); JedisPool jedisPool=new JedisPool(jedisPoolConfig,"192.168.1.16",6379); long start = System.currentTimeMillis(); for (int i = 0; i < 1000; i++) { //從jedis連線池獲取資源 Jedis jedis=jedisPool.getResource(); String ping = jedis.ping(); jedis.close();//是否關閉池子 } long end=System.currentTimeMillis(); //是為了比較使用池子還是不使用快,結論是使用池子快 System.out.println("總耗時:"+(end-start)); }
連線叢集時要保證叢集裡面沒有存值, 要是存值需要刪除之前生成的檔案(注意刪除乾淨)
還有就是放行對應的埠:6001、6002、6003、6004、6005、6006,因為之前放行的實在10000埠,注意以上兩點,才可以使用idea建立成功。
@Test public void test03(){ Set<HostAndPort> nodes=new HashSet<>(); nodes.add(new HostAndPort("192.168.227.175",6001)); nodes.add(new HostAndPort("192.168.227.175",6002)); nodes.add(new HostAndPort("192.168.227.175",6003)); nodes.add(new HostAndPort("192.168.227.175",6004)); nodes.add(new HostAndPort("192.168.227.175",6005)); nodes.add(new HostAndPort("192.168.227.175",6006)); JedisCluster jedisCluster=new JedisCluster(nodes); jedisCluster.set("k6", "小老虎和小兔子"); jedisCluster.close(); }
springboot對redis的操作封裝了兩個StringRedisTemplate和RedisTemplate類,StringRedisTemplate是RedisTemplate的子類,StringRedisTemplate它只能儲存字串型別,無法儲存物件型別。要想用StringRedisTemplate儲存物件必須把物件轉為json字串。
springboot整合redis時提供了兩個模板工具類,StringRedisTemplate和RedisTemplate。
(1) 引入相關的依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-data-redis</artifactId> </dependency>
(2)注入StringRedisTemplate該類物件
@Autowired private StringRedisTemplate redisTemplate;
(3)使用StringRedisTemplate
該類把對每種資料型別的操作,單獨封了相應的內部類。
此處不會有亂碼,因為已經給它序列化方式和反序列化方式換成為String型。
@Autowired private StringRedisTemplate stringRedisTemplate; @Test public void test01(){ //對hash型別的操作 HashOperations<String, Object, Object> forHash = stringRedisTemplate.opsForHash(); forHash.put("k1","name","張三"); forHash.put("k1","age","15"); Map<String,String> map=new HashMap<>(); map.put("name","李四"); map.put("age","25"); forHash.putAll("k36",map); Object o = forHash.get("k1", "name"); System.out.println(o); Set<Object> k1 = forHash.keys("k1"); System.out.println(k1); List<Object> k11 = forHash.values("k1"); System.out.println(k11); //獲取k1對於的所有的field和value Map<Object, Object> k12 = forHash.entries("k1"); System.out.println(k12); } @Test void contextLoads() { //刪除指定的key // stringRedisTemplate.delete("k"); //檢視所有的key //stringRedisTemplate.keys("k"); //是否存在指定的key //stringRedisTemplate.hasKey("k"); //對字串資料型別的操作ValueOperations ValueOperations<String, String> forValue = stringRedisTemplate.opsForValue(); //儲存字串型別--key value long uint setex() forValue.set("k1","張三",30, TimeUnit.SECONDS); //等價於setnx 存入成功返回true ,失敗返回false Boolean absent = forValue.setIfAbsent("k11", "李四", 30, TimeUnit.SECONDS); System.out.println(absent); //append拼接 Integer append = forValue.append("k11", "真好看"); String k11 = forValue.get("k11"); System.out.println(k11); }
此處會有亂碼,因為它序列化方式和反序列化方式預設為JDK。
@SpringBootTest class SbredisApplicationTests02 { //當你儲存的value型別為物件型別使用redisTemplate //儲存的value型別為字串。StringRedisTemplate 驗證碼 @Autowired private RedisTemplate redisTemplate; @Test public void test01(){ //必須認為指定序列化方式 redisTemplate.setKeySerializer(new StringRedisSerializer()); redisTemplate.setValueSerializer(new Jackson2JsonRedisSerializer<Object>(Object.class)); //對String型別操作類 ValueOperations forValue = redisTemplate.opsForValue(); //redis中key和value都變成了亂碼 //key和value都沒有指定序列化方式,預設採用jdk的序列化方式 forValue.set("k1","張三"); //value預設採用jdk,類必須實現序列化介面 forValue.set("k44",new User(1,"haha",12)); } }
上面的RedisTemplate需要每次都指定key value以及field的序列化方式,能不能搞一個設定類,已經為RedisTemplate指定好序列化。以後再用就無需指定。
@Configuration public class RedisConfig { @Bean public RedisTemplate<String, Object> redisTemplate(RedisConnectionFactory factory) { RedisTemplate<String, Object> template = new RedisTemplate<>(); RedisSerializer<String> redisSerializer = new StringRedisSerializer(); Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class); ObjectMapper om = new ObjectMapper(); om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY); om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL); jackson2JsonRedisSerializer.setObjectMapper(om); template.setConnectionFactory(factory); //key序列化方式 template.setKeySerializer(redisSerializer); //value序列化 template.setValueSerializer(jackson2JsonRedisSerializer); //value hashmap序列化 filed value template.setHashValueSerializer(jackson2JsonRedisSerializer); template.setHashKeySerializer(redisSerializer); return template; } }
到此這篇關於Java與SpringBoot對redis的使用方式的文章就介紹到這了,更多相關Java redis 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45