文档章节

Windows下Redis的安装使用

蛙牛
 蛙牛
发布于 2014/02/28 18:41
字数 1410
阅读 61558
收藏 231

0.前言

    因为是初次使用,所以是在windows下进行安装和使用,参考了几篇博客,下面整理一下

1.安装Redis

官方网站:http://redis.io/

官方下载:http://redis.io/download 可以根据需要下载不同版本

windows版:https://github.com/MSOpenTech/redis

github的资源可以ZIP直接下载的(这个是给不知道的同学友情提示下)

下载完成后 可以右键解压到 某个硬盘下 比如D:\Redis\redis-2.6

在D:\Redis\redis-2.6\bin\release下 有两个zip包 一个32位一个64位 

根据自己windows的位数 解压到D:\Redis\redis-2.6 根目录下

2.启动Redis

进入redis目录后 开启服务  (注意加上redis.conf)

redis-server.exe redis.conf

这个窗口要保持开启  关闭时redis服务会自动关闭

redis会自动保存数据到硬盘 所以图中是我第二次开启时 多了一个 DB loaded from disk 

3.测试使用

另外开启一个命令行窗口 进入redis目录下 (注意修改自己的ip)

redis-cli.exe -h 192.168.10.61 -p 6379

4.Java开发包Jedis

Jedis :http://www.oschina.net/p/jedis (Redis的官方首选Java开发包)

<!--Redis -->
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.0.0</version>
            <type>jar</type>
            <scope>compile</scope>
        </dependency>

测试例子原帖:http://flychao88.iteye.com/blog/1527163

package com.lujianing.utils;

import org.junit.Before;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisPool;
import redis.clients.jedis.JedisPoolConfig;

import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
/**
 * Created by lujianing on 14-2-28.
 */
public class JedisUtilTest {



        JedisPool pool;
        Jedis jedis;
        @Before
        public void setUp() {
            pool = new JedisPool(new JedisPoolConfig(), "192.168.10.61");

            jedis = pool.getResource();
         //   jedis.auth("password");
        }


        @Test
        public void testGet(){
            System.out.println(jedis.get("lu"));
        }

        /**
         * Redis存储初级的字符串
         * CRUD
         */
        @Test
        public void testBasicString(){
            //-----添加数据----------
            jedis.set("name","minxr");//向key-->name中放入了value-->minxr
            System.out.println(jedis.get("name"));//执行结果:minxr

            //-----修改数据-----------
            //1、在原来基础上修改
            jedis.append("name","jarorwar");   //很直观,类似map 将jarorwar append到已经有的value之后
            System.out.println(jedis.get("name"));//执行结果:minxrjarorwar

            //2、直接覆盖原来的数据
            jedis.set("name","闵晓荣");
            System.out.println(jedis.get("name"));//执行结果:闵晓荣

            //删除key对应的记录
            jedis.del("name");
            System.out.println(jedis.get("name"));//执行结果:null

            /**
             * mset相当于
             * jedis.set("name","minxr");
             * jedis.set("jarorwar","闵晓荣");
             */
            jedis.mset("name","minxr","jarorwar","闵晓荣");
            System.out.println(jedis.mget("name","jarorwar"));

        }

        /**
         * jedis操作Map
         */
        @Test
        public void testMap(){
            Map<String,String> user=new HashMap<String,String>();
            user.put("name","minxr");
            user.put("pwd","password");
            jedis.hmset("user",user);
            //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
            //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
            List<String> rsmap = jedis.hmget("user", "name");
            System.out.println(rsmap);

            //删除map中的某个键值
//        jedis.hdel("user","pwd");
            System.out.println(jedis.hmget("user", "pwd")); //因为删除了,所以返回的是null
            System.out.println(jedis.hlen("user")); //返回key为user的键中存放的值的个数1
            System.out.println(jedis.exists("user"));//是否存在key为user的记录 返回true
            System.out.println(jedis.hkeys("user"));//返回map对象中的所有key  [pwd, name]
            System.out.println(jedis.hvals("user"));//返回map对象中的所有value  [minxr, password]

            Iterator<String> iter=jedis.hkeys("user").iterator();
            while (iter.hasNext()){
                String key = iter.next();
                System.out.println(key+":"+jedis.hmget("user",key));
            }

        }

        /**
         * jedis操作List
         */
        @Test
        public void testList(){
            //开始前,先移除所有的内容
            jedis.del("java framework");
            System.out.println(jedis.lrange("java framework",0,-1));
            //先向key java framework中存放三条数据
            jedis.lpush("java framework","spring");
            jedis.lpush("java framework","struts");
            jedis.lpush("java framework","hibernate");
            //再取出所有数据jedis.lrange是按范围取出,
            // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有
            System.out.println(jedis.lrange("java framework",0,-1));
        }

        /**
         * jedis操作Set
         */
        @Test
        public void testSet(){
            //添加
            jedis.sadd("sname","minxr");
            jedis.sadd("sname","jarorwar");
            jedis.sadd("sname","闵晓荣");
            jedis.sadd("sanme","noname");
            //移除noname
            jedis.srem("sname","noname");
            System.out.println(jedis.smembers("sname"));//获取所有加入的value
            System.out.println(jedis.sismember("sname", "minxr"));//判断 minxr 是否是sname集合的元素
            System.out.println(jedis.srandmember("sname"));
            System.out.println(jedis.scard("sname"));//返回集合的元素个数
        }

        @Test
        public void test() throws InterruptedException {
            //keys中传入的可以用通配符
            System.out.println(jedis.keys("*")); //返回当前库中所有的key  [sose, sanme, name, jarorwar, foo, sname, java framework, user, braand]
            System.out.println(jedis.keys("*name"));//返回的sname   [sname, name]
            System.out.println(jedis.del("sanmdde"));//删除key为sanmdde的对象  删除成功返回1 删除失败(或者不存在)返回 0
            System.out.println(jedis.ttl("sname"));//返回给定key的有效时间,如果是-1则表示永远有效
            jedis.setex("timekey", 10, "min");//通过此方法,可以指定key的存活(有效时间) 时间为秒
            Thread.sleep(5000);//睡眠5秒后,剩余时间将为<=5
            System.out.println(jedis.ttl("timekey"));   //输出结果为5
            jedis.setex("timekey", 1, "min");        //设为1后,下面再看剩余时间就是1了
            System.out.println(jedis.ttl("timekey"));  //输出结果为1
            System.out.println(jedis.exists("key"));//检查key是否存在
            System.out.println(jedis.rename("timekey","time"));
            System.out.println(jedis.get("timekey"));//因为移除,返回为null
            System.out.println(jedis.get("time")); //因为将timekey 重命名为time 所以可以取得值 min

            //jedis 排序
            //注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的)
            jedis.del("a");//先清除数据,再加入数据进行测试
            jedis.rpush("a", "1");
            jedis.lpush("a","6");
            jedis.lpush("a","3");
            jedis.lpush("a","9");
            System.out.println(jedis.lrange("a",0,-1));// [9, 3, 6, 1]
            System.out.println(jedis.sort("a")); //[1, 3, 6, 9]  //输入排序后结果
            System.out.println(jedis.lrange("a",0,-1));

        }


}

Redis会定时 保存数据到硬盘上

© 著作权归作者所有

共有 人打赏支持
蛙牛

蛙牛

粉丝 529
博文 46
码字总数 48937
作品 1
朝阳
程序员
私信 提问
加载中

评论(27)

b
bluesnail95
想问问有没有win32的2.7+的版本
蚂蚁-Declan
蚂蚁-Declan
学习了、、谢谢分享!
f-dd
f-dd
学习了感谢!!
郁极风
郁极风
写的很好,感谢LZ。
迷彩风情
迷彩风情
写的非常不错!
ardorleo
ardorleo
来学习了!
大木马
大木马
79
一一叶
一一叶

引用来自“黄开源中国”的评论

看到题目才发现自己一直用的都是linux下的。。。13

唉,
黄勇
黄勇
祝贺!祝贺!今天上“每日一搏”了!
黄开源中国
黄开源中国
看到题目才发现自己一直用的都是linux下的。。。13
windows下scrapy-redis如何为redis配置密码

windows下scrapy-redis如何为redis配置密码 1. 环境 系统:win7 scrapy-redis redis 3.0.5 python 3.6.1 2. 为redis-server配置密码并启动 redis在windows下的安装与配置,请参考这篇文章:h...

zwq912318834
2017/12/27
0
0
redis数据库在windows下的安装,配置与使用

redis数据库在windows下的安装,配置与使用 1. 背景。 因为分布式爬虫搭建的需要,会使用到Scrapy-redis实现分布式爬虫。 Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持...

zwq912318834
2017/12/11
0
0
Redis进阶实践之三如何在Windows系统上安装安装Redis

Redis进阶实践之三如何在Windows系统上安装安装Redis 一、Redis的简介 Redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、s...

morpheusWB
09/13
0
0
redis&memcached for windows 安装与使用

redis for windows 很简单只需要3步,主要是安装redis和安装php的redis扩展两个方面(安装玩之后应该进行一定配置 1.Windows安装包下载地址:https://github.com/ServiceStack/redis-windows...

梦梦阁
10/11
0
0
Redis 安装(一)

一、前言 安装 是开始 Redis 学习之旅的第一步,安装之前先来个简单的介绍。 1. 版本规则 Redis 约定次版本号(即第一个小数点后的数字)为偶数的版本是稳定版,如:2.6,2.8;奇数版本是非稳...

天秤vs永恒
2016/11/21
12
0

没有更多内容

加载失败,请刷新页面

加载更多

Mariadb二进制包安装,Apache安装

安装mariadb 下载二进制包并解压 [root@test-a src]# wget https://downloads.mariadb.com/MariaDB/mariadb-10.2.6/bintar-linux-glibc_214-x86_64/mariadb-10.2.6-linux-glibc_214-x86_64.t......

野雪球
今天
3
0
ConcurrentHashMap 高并发性的实现机制

ConcurrentHashMap 的结构分析 为了更好的理解 ConcurrentHashMap 高并发的具体实现,让我们先探索它的结构模型。 ConcurrentHashMap 类中包含两个静态内部类 HashEntry 和 Segment。HashEnt...

TonyStarkSir
今天
3
0
大数据教程(7.4)HDFS的java客户端API(流处理方式)

博主上一篇博客分享了namenode和datanode的工作原理,本章节将继前面的HDFS的java客户端简单API后深度讲述HDFS流处理API。 场景:博主前面的文章介绍过HDFS上存的大文件会成不同的块存储在不...

em_aaron
昨天
4
0
聊聊storm的window trigger

序 本文主要研究一下storm的window trigger WindowTridentProcessor.prepare storm-core-1.2.2-sources.jar!/org/apache/storm/trident/windowing/WindowTridentProcessor.java public v......

go4it
昨天
7
0
CentOS 生产环境配置

初始配置 对于一般配置来说,不需要安装 epel-release 仓库,本文主要在于希望跟随 RHEL 的配置流程,紧跟红帽公司对于服务器的配置说明。 # yum update 安装 centos-release-scl # yum ins...

clin003
昨天
11
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部