Redis入门学习笔记一

Redis 简要描述:

  1.  Redis 是啥 ?

       Redis 英文名称全称为: Remote Dictionary Server ,中译为远程字典服务器。 是一款区分于磁盘数据库如(Mysql)的采用Key-Value键值对的字典结构的缓存数据库。

  2. Redis有什么作用?

       Redis作为一款内存数据库,其最大的有点就是高速,对于那些高频访问的数据,进行加缓存。Redis加载缓存的时候使用的LRU机制,对于热点数据将会持续保留,其他的将会被淘汰。

Redis涉及到的LRU简要源码解析算法实现:

 1 package com.mysql.jdbc.util;
 2 
 3 import java.util.LinkedHashMap;
 4 import java.util.Map.Entry;
 5 
 6 public class LRUCache extends LinkedHashMap {
 7     private static final long serialVersionUID = 1L;
 8     protected int maxElements;
 9 
10     public LRUCache(int maxSize) {
11         super(maxSize, 0.75F, true);
12         this.maxElements = maxSize;
13     }
14 
15     protected boolean removeEldestEntry(Entry eldest) {
16         return this.size() > this.maxElements;
17     }
18 }

     注解:  Lru算法使用Java jdk提供的LinkedHashMap实现 

 1 package com.hbut.util;
 2 
 3 import java.util.LinkedHashMap;
 4 import java.util.Map;
 5 
 6 /**
 7  * @Author XiJun.Gong
 8  * @DATE 2016/6/11.
 9  * aim:   com.hbut.util
10  */
11 public class Lru extends LinkedHashMap {
12     private static final long serialVersionUID = 1L;
13     private int maxElements = 5; //default size is 5
14 
15     public int getMaxElements() {
16         return maxElements;
17     }
18 
19     public void setMaxElements(int maxElements) {
20         this.maxElements = maxElements;
21     }
22 
23     /**
24      *  if size > maxElements remove this old entry and
25      *  add new entry
26      * @param eldest
27      * @return true or false
28      */
29     protected boolean removeEldestEntry(Map.Entry eldest) {
30 
31         return size() > this.maxElements;
32     }
33 }

 Redis如何使用java是测试用例:

使用Maven配置pom.xml

1    <!--Redis cache -->
2             <dependency>
3                 <groupId>redis.clients</groupId>
4                 <artifactId>jedis</artifactId>
5                 <version>${redis.clients.version}</version>
6                 <type>jar</type>
7                 <scope>compile</scope>
8             </dependency>

window环境下测试流程:

   window Redis版下载环境:   https://github.com/MSOpenTech/redis

    Redis 有五个执行程序:

redis-server

server服务器,需要启动它

redis-client

redis命令行客户端

redis-benchmark

性能测试工具

redis-check-aof/rdb

rdb/aof修复工具,aof ->AppendOnly File

   启动 redis-server服务器,出现如下界面

  java 代码测试

 1 package com.hbut.util;
 2 
 3 import com.google.common.collect.Maps;
 4 import org.junit.Before;
 5 import org.junit.Test;
 6 import redis.clients.jedis.Jedis;
 7 import redis.clients.jedis.JedisPool;
 8 import redis.clients.jedis.JedisPoolConfig;
 9 
10 import java.io.*;
11 import java.util.Iterator;
12 import java.util.List;
13 import java.util.Map;
14 
15 /**
16  * Created by XiJun.Gong on 14-2-28.
17  */
18 public class TestRedis {
19 
20 
21     JedisPool pool;
22     Jedis jedis;
23 
24     /**
25      * connection
26      */
27     @Before
28     public void init() {
29         pool = new JedisPool(new JedisPoolConfig(), "localhost");
30         jedis = pool.getResource();
31         //jedis.auth("*******"); //密码验证
32     }
33 
34 
35     /**
36      * 存储字符串,设置失效时间
37      */
38     @Test
39     public void RedisTest() throws InterruptedException {
40         jedis.set("google", "entry1");
41         System.out.println(jedis.get("google"));
42         jedis.expire("google", 3);  //设置过期时间
43         Thread.sleep(5000);
44         System.out.println(jedis.get("google"));
45     }
46 
47 
48     /**
49      * CRUD for String
50      */
51     @Test
52     public void redisCRUD() {
53         /**add**/
54         jedis.set("key", "google");
55         System.out.println(jedis.get("key"));
56         /**delete**/
57         jedis.del("key");
58         System.out.println(jedis.get("key"));
59         /*modify*/
60         jedis.append("key", "Qunar.com");
61         System.out.println(jedis.get("key"));
62         /**another method**/
63         jedis.set("key", "Tencent");
64         System.out.println(jedis.get("key"));
65 
66         /**Multi value  mapping key**/
67         jedis.mset("key", "google", "tencent", "Qunar");
68         System.out.println(jedis.mget("key", "google"));
69 
70         /*for map*/
71         Map<String, String> user = Maps.newHashMap();
72         user.put("huifeidmeng", "Qunar");
73         jedis.hmset("user", user);
74         List<String> rsmap = jedis.hmget("user", "key");
75         System.out.println(rsmap);
76 
77     }
78 
79 }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏微服务生态

从0到1起步-跟我进入堆外内存的奇妙世界

堆外内存一直是Java业务开发人员难以企及的隐藏领域,究竟他是干什么的,以及如何更好的使用呢?那就请跟着我进入这个世界吧。

962
来自专栏好好学java的技术栈

七夕不送礼,送礼就送HttpServletResponse,一看就懂

Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象、和代表响应的response对象。获取网页提交过来的数据,...

1041
来自专栏JAVA烂猪皮

JVM难学?那是因为你没认真看完这篇文章

JAVA程序运行与虚拟机之上,运行时需要内存空间。虚拟机执行JAVA程序的过程中会把它管理的内存划分为不同的数据区域方便管理。

1103
来自专栏MasiMaro 的技术博文

OLEDB 简单数据查找定位和错误处理

在数据库查询中,我们主要使用的SQL语句,但是之前也说过,SQL语句需要经历解释执行的步骤,这样就会拖慢程序的运行速度,针对一些具体的简单查询,比如根据用户ID...

1662
来自专栏Elasticsearch实验室

Elasitcsearch 底层系列 Lucene 内核解析之 Stored Fields

Lucene 的 stored fields 主要用于行存文档需要保存的字段内容,每个文档的所有 stored fields 保存在一起,在查询请求需要返回字段...

6865
来自专栏Android先生

Android开发者怎么能不会写后台接口呢?

然后在src下创建三个包,一个放Servlet,一个放mysql的工具类,一个放对象;

823
来自专栏JAVA烂猪皮

JVM难学?那是因为你没认真看完这篇文章

JAVA程序运行与虚拟机之上,运行时需要内存空间。虚拟机执行JAVA程序的过程中会把它管理的内存划分为不同的数据区域方便管理。

1064
来自专栏MySQL

JVM难学?那是因为你没认真看完这篇文章

JAVA程序运行与虚拟机之上,运行时需要内存空间。虚拟机执行JAVA程序的过程中会把它管理的内存划分为不同的数据区域方便管理。

1170
来自专栏JavaEdge

Memcached的扩容源码分析

2165
来自专栏Java帮帮-微信公众号-技术文章全总结

Web-第九天 ServletContext&amp;Response&amp;request学习

Web-第九天 ServletContext&Response&request学习

1833

扫码关注云+社区

领取腾讯云代金券