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

 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 }
时间: 2024-11-05 04:40:07

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

Hadoop入门学习笔记---part4

紧接着<Hadoop入门学习笔记---part3>中的继续了解如何用java在程序中操作HDFS. 众所周知,对文件的操作无非是创建,查看,下载,删除.下面我们就开始应用java程序进行操作,前提是按照<Hadoop入门学习笔记---part2>中的已经在虚拟机中搭建好了Hadoop伪分布环境:并且确定现在linux操作系统中hadoop的几个进程已经完全启动了. 好了,废话不多说!实际的例子走起. 在myeclipse中新建一个java工程: 在项目工程中新建一个lib包用于存放

Hadoop入门学习笔记---part1

随着毕业设计的进行,大学四年正式进入尾声.任你玩四年的大学的最后一次作业最后在激烈的选题中尘埃落定.无论选择了怎样的选题,无论最后的结果是怎样的,对于大学里面的这最后一份作业,也希望自己能够尽心尽力,好好做.正是因为选题和hadoop有关,现在正式开始学习hadoop.将笔记整理于此,希望与志同道合的朋友共同交流. 作者:itRed 邮箱:[email protected] 个人博客链接:http://www.cnblogs.com/itred 好了,废话不多说.进入正题!开始hadoop的学习

汇编入门学习笔记 (六)—— si、di,双重循环

疯狂的暑假学习之  汇编入门学习笔记 (六)-- si.di,双重循环 参考: <汇编语言> 王爽 第7章 1. and和or指令,与[bx+idata] and和or,就不多说了. [bx+idata] 这样写是可以的,某些情况下,比较方便. [bx+idata] 也可以写成 idata[bx] 直接见例子: 把'ABcde' 跟 'fGHig' 都改成大写(ASCII中大写字母与小写字母二进制中,只有第五位不同,大写字母是0,小写字母是1) assume cs:code,ds:data d

汇编入门学习笔记 (八)—— 转移指令

疯狂的暑假学习之  汇编入门学习笔记 (八)--  转移指令 參考: <汇编语言> 王爽 第9章 能够改动ip或者同一时候改动cs和ip的指令统称为转移指令. 8086CPU转移行为分为: 段内转移:仅仅改动ip 段间转移:同一时候改动cs和ip 段内转移按ip改动的范围可分为: 短转移:ip改动范围 -128~127 近转移:ip改动范围 -32768~32767 转移指令分为: 无条件转移指令.如 jmp 条件转移指令 循环指令.如 loop 过程. 中断. 1. offset,nop指令

Hadoop入门学习笔记---part3

2015年元旦,好好学习,天天向上.良好的开端是成功的一半,任何学习都不能中断,只有坚持才会出结果.继续学习Hadoop.冰冻三尺,非一日之寒! 经过Hadoop的伪分布集群环境的搭建,基本对Hadoop有了一个基础的了解.但是还是有一些理论性的东西需要重复理解,这样才能彻底的记住它们.个人认为重复是记忆之母.精简一下: NameNode:管理集群,并且记录DataNode文件信息: SecondaryNameNode:可以做冷备份,对一定范围内的数据作快照性备份: DataNode:存储数据:

汇编入门学习笔记 (三) —— 第一个程序

疯狂的暑假学习之  汇编入门学习笔记 (三)-- 第一个程序 参考:<汇编语言> 王爽  第四章 1.一个源程序从写到执行的过程 第一步:编写汇编源程序 第二步:对源程序进行编译连接 第三步:在操作系统中执行 2.源程序 代码: assume cs:first first segment start: mov ax,2 add ax,ax add ax,ax mov ax,4C00H int 21H first ends end start 代码解释: assume .segment.ends

Python 实现 CNKI批量下载 和FireFox Extension 入门学习笔记

?                                 Python 实现 CNKI批量下载 和FireFox Extension 入门学习笔记? 由于需要也是为了督促自己学习新的东西,我原本想要尝试着写一个爬虫程序,能够在cnki上自动得将论文进行批量下载,学习过程中遇到了诸多情况,cnki也真是专业,不得不佩服cnki的强大. 下面进入正题: 学习.实验环境:ubuntu 14.04 工具:Eclipse ,  FireFox, FireBug,HttpFox 编程语言:pyth

汇编入门学习笔记 (十四)—— 直接定址表

疯狂的暑假学习之  汇编入门学习笔记 (十四)-- 直接定址表 参考: <汇编语言> 王爽 第16章 1. 描述单元长度的标号 普通的标号:a,b assume cs:code code segment a:db 1,2,3,4,5,6,7,8 b:dw 0 start: mov si,offset a mov di,offset b mov ah,0 mov cx,8 s: mov al,cs:[si] add cs:[di],ax inc si loop s mov ax,4c00h in

汇编入门学习笔记 (四)—— [BX] 和 loop指令

疯狂的暑假学习之  汇编入门学习笔记 (四)-- [BX]  和 loop指令 参考:<汇编语言> 王爽 第5章 1.[BX] mov al,[1] 在debug中,会把bs:1 中数据赋给al,但在在masm中不会把bs:1 中数据赋给al,而是把 [1] 认为是 1 赋给al. 如果要实现在debug中的mov al,[1],在masm中就需要[bx] 如: mov bx,1 mov al,[bx] 还可以用 bs:[1] 的方式 如: mov al,bs:[1] 2.loop 循环 要使