java程序员的redis入门教程

理论了解:
Redis,百度百科中是这样说明的:
Redis(全称:Remote Dictionary Server 远程字典服务)是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。

redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。在此基础上,redis支持各种不同方式的排序。与memcached一样,为了保证效率,数据都是缓存在内存中。区别的是redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步。

Redis 是一个高性能的key-value数据库。 redis的出现,很大程度补偿了memcached这类key/value存储的不足,在部 分场合可以对关系数据库起到很好的补充作用。它提供了Java,C/C++,C#,PHP,JavaScript,Perl,Object-C,Python,Ruby,Erlang等客户端,使用很方便。

Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。这使得Redis可执行单层树复制。存盘可以有意无意的对数据进行写操作。由于完全实现了发布/订阅机制,使得从数据库在任何地方同步树时,可订阅一个频道并接收主服务器完整的消息发布记录。同步对读取操作的可扩展性和数据冗余很有帮助。

redis的官网地址,非常好记,是redis.io。(域名后缀io属于国家域名,是british Indian Ocean territory,即英属印度洋领地)
目前,Vmware在资助着redis项目的开发和维护。
总结下:
1.Redis 是一个高性能的key-value数据库,且是典型的非关系型数据库;
2.可以存储的数据类型包括string(字符串)、list(链表)、set(集合)、zset(sorted set --有序集合)和hash(哈希类型);
3.实现了master-slave(主从)同步

前言
随着项目的需求不断的提高,对于数据量,效率上的需求也是不断的提高;redis可以在数据高并发的读写、海量数据的读写、扩展性要求高的数据等项目进行使用;它可以解决应用服务器的cpu和内存压力、
减少io的读操作,减轻io的压力、易于扩展。
教程start(本教程只讲Linux环境的安装和java语言的使用):
一、Linux版本下载安装
下载地址:http://redis.io/download,下载最新稳定版本

本教程使用的最新文档版本为 2.8.17,下载并安装:

$ wget http://download.redis.io/releases/redis-2.8.17.tar.gz

$ tar xzf redis-2.8.17.tar.gz

$ cd redis-2.8.17

$ make

make完后 redis-2.8.17目录下会出现编译后的redis服务程序redis-server,还有用于测试的客户端程序redis-cli,两个程序位于安装目录 src 目录下:

下面启动redis服务.

$ cd src

$ ./redis-server

注意这种方式启动redis 使用的是默认配置。也可以通过启动参数告诉redis使用指定配置文件使用下面命令启动。

$ cd src

$ ./redis-server ../redis.conf

redis.conf 是一个默认的配置文件。我们可以根据需要使用自己的配置文件。

启动redis服务进程后,就可以使用测试客户端程序redis-cli和redis服务交互了。 比如:

$ cd src

$ ./redis-cli

redis> set foo bar

OK

redis> get foo

"bar"

注:
出现Permission denied的解决办法
解决的办法:
命令:

$ sudo chmod -R 777 某一目录

其中
-R 是指级联应用到目录里的所有子目录和文件
777 是所有用户都拥有最高权限

Java 使用 Redis

· 首先你需要下载驱动包 下载 jedis.ja*,确保下载最新驱动包。
· 在你的 classpath 中包含该驱动包。
本站提供了 2.9.0 jar 版本下载: jedis-2.9.0.jar
或者在maven项目中直接加入以下依赖:

        <!--redis -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.data</groupId>
            <artifactId>spring-data-redis</artifactId>
        </dependency>

连接到 redis 服务

实例

import redis.clients.jedis.Jedis;

public class RedisJava {

public static void main(String[] args)

{

//连接本地的 Redis 服务

Jedis jedis = new Jedis("localhost");

System.out.println("连接成功");

//查看服务是否运行

System.out.println("服务正在运行: "+jedis.ping());

 }

}

编译以上 Java 程序,确保驱动包的路径是正确的。

连接成功服务正在运行: PONG

Redis Java String(字符串) 实例

实例

import redis.clients.jedis.Jedis;
 public class RedisStringJava { 
public static void main(String[] args) { 
//连接本地的 Redis 服务 
Jedis jedis = new Jedis("192.168.3.77");
 System.out.println("连接成功");
 //设置 redis 字符串数据 
jedis.set("runoobkey", "www.baidu.com"); 
// 获取存储的数据并输出 
System.out.println("redis 存储的字符串为: "+ jedis.get("runoobkey")); } }

编译以上程序。
连接成功
redis 存储的字符串为: www.baidu.com

Redis Java List(列表) 实例

实例

import java.util.List; 
import redis.clients.jedis.Jedis; 
public class RedisListJava {
  public static void main(String[] args) {
   //连接本地的 Redis 服务
   Jedis jedis = new Jedis("localhost"); 
    System.out.println("连接成功");
   //存储数据到列表中 jedis.lpush("site-list", "Runoob"); 
    jedis.lpush("site-list", "Google"); 
    jedis.lpush("site-list", "Taobao"); 
    // 获取存储的数据并输出 
    List<String> list = jedis.lrange("site-list", 0 ,2); 
  for(int i=0; i<list.size(); i++) {
     System.out.println("列表项为: "+list.get(i));
     }
   } 
 }

编译以上程序。
连接成功列表项为: Taobao列表项为: Google列表项为: Runoob

Redis Java Keys 实例

实例

import java.util.Iterator; 
import java.util.Set; 
import redis.clients.jedis.Jedis;
 public class RedisKeyJava { 
  public static void main(String[] args) { 
    //连接本地的 Redis 服务 
    Jedis jedis = new Jedis("localhost"); 
    System.out.println("连接成功"); 
    // 获取数据并输出 Set<String> keys = jedis.keys("*");
     Iterator<String> it=keys.iterator() ; 
    while(it.hasNext()){ 
      String key = it.next(); 
      System.out.println(key); 
    } 
  } 
}

编译以上程序。

连接成功
runoobkey
site-list

这才是我觉得最详细:

public class RedisUtil {

    //服务器IP地址

    private static String ADDR = "192.168.41.65";

    //端口

    private static int PORT = 6379;

    //密码

    private static String AUTH = "123456";

    //连接实例的最大连接数

    private static int MAX_ACTIVE = 1024;

    //控制一个pool最多有多少个状态为idle(空闲的)的jedis实例,默认值也是8。

    private static int MAX_IDLE = 200;

    //等待可用连接的最大时间,单位毫秒,默认值为-1,表示永不超时。如果超过等待时间,则直接抛出JedisConnectionException

    private static int MAX_WAIT = 10000;

    //连接超时的时间  

    private static int TIMEOUT = 10000;

    // 在borrow一个jedis实例时,是否提前进行validate操作;如果为true,则得到的jedis实例均是可用的;

    private static boolean TEST_ON_BORROW = true;

    private static JedisPool jedisPool = null;

    //数据库模式是16个数据库 0~15

    public static final int DEFAULT_DATABASE = 0;

    /**

     * 初始化Redis连接池

     */

    static {

        try {

            JedisPoolConfig config = new JedisPoolConfig();

            config.setMaxTotal(MAX_ACTIVE);

            config.setMaxIdle(MAX_IDLE);

            config.setMaxWaitMillis(MAX_WAIT);

            config.setTestOnBorrow(TEST_ON_BORROW);

            jedisPool = new JedisPool(config, ADDR, PORT, TIMEOUT,AUTH,DEFAULT_DATABASE);

        } catch (Exception e) {

            e.printStackTrace();

        }

    }

    /**

     * 获取Jedis实例

     */

    public synchronized static Jedis getJedis() {

        try {

            if (jedisPool != null) {

                Jedis resource = jedisPool.getResource();

                System.out.println("redis--服务正在运行: "+resource.ping());

                return resource;

            } else {

                return null;

            }

        } catch (Exception e) {

            e.printStackTrace();

            return null;

        }

    }

    /***

     *

     * 释放资源

     */

    public static void returnResource(final Jedis jedis) {

            if(jedis != null) {

                jedisPool.returnResource(jedis);

            }

    }}

THAT IS OVER

?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,992评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,212评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,535评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,197评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,310评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,383评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,409评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,191评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,621评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,910评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,084评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,763评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,403评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,083评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,318评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,946评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,967评论 2 351

推荐阅读更多精彩内容