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实现

 package com.hbut.util;

 import java.util.LinkedHashMap;
import java.util.Map; /**
* @Author XiJun.Gong
* @DATE 2016/6/11.
* aim: com.hbut.util
*/
public class Lru extends LinkedHashMap {
private static final long serialVersionUID = 1L;
private int maxElements = 5; //default size is 5 public int getMaxElements() {
return maxElements;
} public void setMaxElements(int maxElements) {
this.maxElements = maxElements;
} /**
* if size > maxElements remove this old entry and
* add new entry
* @param eldest
* @return true or false
*/
protected boolean removeEldestEntry(Map.Entry eldest) { return size() > this.maxElements;
}
}

 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 }

Redis入门学习笔记一的更多相关文章

  1. Redis——入门学习笔记

    Redis学习 说到前面:这篇笔记只是我作为一个Redis新手,从0到认知的一个过程.后续会持续深入学习. 学习初衷和计划 学习Redis,因为这是热门技术,必须掌握的技术,别人都会我不会.就这一点就 ...

  2. 【原创】SpringBoot & SpringCloud 快速入门学习笔记(完整示例)

    [原创]SpringBoot & SpringCloud 快速入门学习笔记(完整示例) 1月前在系统的学习SpringBoot和SpringCloud,同时整理了快速入门示例,方便能针对每个知 ...

  3. Redis:学习笔记-01

    Redis:学习笔记-01 该部分内容,参考了 bilibili 上讲解 Redis 中,观看数最多的课程 Redis最新超详细版教程通俗易懂,来自 UP主 遇见狂神说 1. Redis入门 2.1 ...

  4. Hadoop入门学习笔记---part4

    紧接着<Hadoop入门学习笔记---part3>中的继续了解如何用java在程序中操作HDFS. 众所周知,对文件的操作无非是创建,查看,下载,删除.下面我们就开始应用java程序进行操 ...

  5. Hadoop入门学习笔记---part3

    2015年元旦,好好学习,天天向上.良好的开端是成功的一半,任何学习都不能中断,只有坚持才会出结果.继续学习Hadoop.冰冻三尺,非一日之寒! 经过Hadoop的伪分布集群环境的搭建,基本对Hado ...

  6. PyQt4入门学习笔记(三)

    # PyQt4入门学习笔记(三) PyQt4内的布局 布局方式是我们控制我们的GUI页面内各个控件的排放位置的.我们可以通过两种基本方式来控制: 1.绝对位置 2.layout类 绝对位置 这种方式要 ...

  7. PyQt4入门学习笔记(一)

    PyQt4入门学习笔记(一) 一直没有找到什么好的pyqt4的教程,偶然在google上搜到一篇不错的入门文档,翻译过来,留以后再复习. 原始链接如下: http://zetcode.com/gui/ ...

  8. Hadoop入门学习笔记---part2

    在<Hadoop入门学习笔记---part1>中感觉自己虽然总结的比较详细,但是始终感觉有点凌乱.不够系统化,不够简洁.经过自己的推敲和总结,现在在此处概括性的总结一下,认为在准备搭建ha ...

  9. Hadoop入门学习笔记---part1

    随着毕业设计的进行,大学四年正式进入尾声.任你玩四年的大学的最后一次作业最后在激烈的选题中尘埃落定.无论选择了怎样的选题,无论最后的结果是怎样的,对于大学里面的这最后一份作业,也希望自己能够尽心尽力, ...

随机推荐

  1. next([expr]) 取得一个包含匹配的元素集合中每一个元素紧邻的后面同辈元素的元素集合。

    描述: 找到每个段落的后面紧邻的同辈元素. HTML 代码: <p>Hello</p><p>Hello Again</p><div>< ...

  2. catalina

    用catalina启动tomcat容器,将项目放到tomcat中,通过cmd:启动:catalina,相当于本地的测试环境.

  3. angularJS——模块

    一.在讲angularjs的模块之前,我们先介绍一下angular的一些知识点: AngularJS是纯客户端技术,完全用Javascript编写的.它使用的是网页开发的常规技术(HTML,CSS,J ...

  4. linux date时区修改

    # vi /etc/sysconfig/clock ZONE=Asia/Shanghai(查/usr/share/zoneinfo下面的文件)   [root@localhost ~]# dateFr ...

  5. JavaScript---function、this关键字相关习题

    1. 请看下列代码: function F( ){ function C( ){ return this; } return C(); } var o=new F( ); 请问上面的this值指向的是 ...

  6. poj 1626

    传送门:http://poj.org/problem?id=1636 题意:有两个监狱,每个监狱有n个人,有m种关系,表示A监狱第i个人不能跟B监狱第j个人在一个监狱,问你最多能换几组人(从A,B监狱 ...

  7. xampp修改mysql默认密码详解

    在这里介绍xampp修改mysql默认密码的大概过程是先利用xampp的phpmyadmin进入修改mysql密码,修改之后我们再修改xampp中phpmyadmin的密码,这样就完整的修改mysql ...

  8. Bootstrap学习(2)--表单

    Bootstrap里的role属性,增强标签的语义化,提高识别力,  如:<form role="form"> input.select.textarea等元素,在Bo ...

  9. Glide 图片加载库

    compile 'com.github.bumptech.glide:glide:3.7.0' Glide.with(context) //图片url .load("http://www.b ...

  10. Life is short

    相信不少码农曾看过类似“life is short, use Python”等之类略带调侃意味的小段子(譬如我),而其也并非不无道理.每门编程语言都是合理的存在,都有它们的优点,及缺陷. 码农们也大多 ...