频道栏目
首页 > 网络 > 云计算 > 正文

redis的安装及使用

2017-09-13 08:33:00      个评论    来源:qq_38799155的博客  
收藏   我要投稿

1.redis的简介

1.1 Redis是什么

REmote DIctionary Server(Redis) 是一个由Salvatore Sanfilippo写的key-value存储系统。Redis提供了一些丰富的数据结构,包括 lists, sets, ordered sets 以及 hashes ,当然还有和Memcached一样的 strings结构.Redis当然还包括了对这些数据结构的丰富操作。

1.2 Redis的优点

性能极高 – Redis能支持超过 100K+ 每秒的读写频率。

丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

原子 – Redis的所有操作都是原子性的,同时Redis还支持对几个操作全并后的原子性执行。

丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

2.安装

2.1下载redis

在官网下载redis安装包:http://redis.io/download

下载最新版本,可以在Windows下下载完成,通过xftp上传,也可以在hadoop用户下输入命令

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

注意: 如果没有安装wget,出现如图所示的错误
这里写图片描述
则需要切换到root用户下安装,命令如下:

# yum -y install wget

这里写图片描述

我下载的是redis-4.0.1版本

2.2解压

$ tar -xzf redis-4.0.1.tar.gz

2.3编译
编译,并指定路径

$ cd redis-4.0.1
$ make && make install PREFIX=/home/hadoop/redis

注意: 如果自己是新创建的虚拟机,在安装编译的时候会出现缺少依赖的现象,如果你是centos7的用户,可以执行如下命令:

$ sudo yum install -y gcc libxml2-devel libxslt-devel cyrus-sasl-devel mysql-devel python-devel python-setuptools python-simplejson sqlite-devel ant gmp-devel
yum install -y cyrus-sasl-plain cyrus-sasl-devel cyrus-sasl-gssapi
yum -y install libffi-devel
yum -y install openldap-devel (重新编译)
$ make MALLOC=libc

最后在编译执行$ make && make install PREFIX=/home/hadoop/redis ,出现如下图所示,证明成功
这里写图片描述

$ cd ~
$ ll

这里写图片描述

这里写图片描述

2.4修改配置文件
首先,复制redis.conf 到 /home/hadoop/redis/bin/ 下 ,之后开始修改redis的配置文件

$ cp redis.conf /home/hadoop/redis/bin/

这里写图片描述

$ cd /home/hadoop/redis/bin/
$ vi redis.conf

这里写图片描述

3.启动

到cd /home/hadoop/redis/bin/ 下执行启动redis,命令如下

$ cd /home/hadoop/redis/bin/
$ ./redis-server redis.conf
$ ./redis-cli

这里写图片描述

4.安装遇到的错误

1.redis安装在编译时 zmalloc.h:50:31: 致命错误:jemalloc/jemalloc.h:没有那个文件或目录

这里写图片描述

解决的办法:
执行命令:make MALLOC=libc

$ make MALLOC=libc

5.简单的使用

数据类型

* 5.1 String类型*
Redis能存储二进制安全的字符串,最大长度为1GB

redis 127.0.0.1:6379> SET name “John Doe”
OK
redis 127.0.0.1:6379> GET name
“John Doe”
String类型还支持批量的读写操作

redis 127.0.0.1:6379> MSET age 30 sex “male”
OK
redis 127.0.0.1:6379> MGET age sex
1) “30”
2) “male”
String类型其实也可以用来存储数字,并支持对数字的加减操作。

redis 127.0.0.1:6379> INCR age
(integer) 31
redis 127.0.0.1:6379> INCRBY age 4
(integer) 35
redis 127.0.0.1:6379> GET age
“35”
redis 127.0.0.1:6379> DECR age
(integer) 34
redis 127.0.0.1:6379> DECRBY age 4
(integer) 30
redis 127.0.0.1:6379> GET age
“30”
String类型还支持对其部分的修改和获取操作

redis 127.0.0.1:6379> APPEND name ” Mr.”
(integer) 12
redis 127.0.0.1:6379> GET name
“John Doe Mr.”
redis 127.0.0.1:6379> STRLEN name
(integer) 12
redis 127.0.0.1:6379> SUBSTR name 0 3
“John”
5.2 List类型
Redis能够将数据存储成一个链表,并能对这个链表进行丰富的操作

redis 127.0.0.1:6379> LPUSH students “John Doe”
(integer) 1
redis 127.0.0.1:6379> LPUSH students “Captain Kirk”
(integer) 2
redis 127.0.0.1:6379> LPUSH students “Sheldon Cooper”
(integer) 3
redis 127.0.0.1:6379> LLEN students
(integer) 3
redis 127.0.0.1:6379> LRANGE students 0 2
1) “Sheldon Cooper”
2) “Captain Kirk”
3) “John Doe”
redis 127.0.0.1:6379> LPOP students
“Sheldon Cooper”
redis 127.0.0.1:6379> LLEN students
(integer) 2
redis 127.0.0.1:6379> LRANGE students 0 1
1) “Captain Kirk”
2) “John Doe”
redis 127.0.0.1:6379> LREM students 1 “John Doe”
(integer) 1
redis 127.0.0.1:6379> LLEN students
(integer) 1
redis 127.0.0.1:6379> LRANGE students 0 0
1) “Captain Kirk”
Redis也支持很多修改操作

redis 127.0.0.1:6379> LINSERT students BEFORE “Captain Kirk” “Dexter Morgan”
(integer) 3
redis 127.0.0.1:6379> LRANGE students 0 2
1) “Dexter Morgan”
2) “Captain Kirk”
3) “John Doe”
redis 127.0.0.1:6379> LPUSH students “Peter Parker”
(integer) 4
redis 127.0.0.1:6379> LRANGE students 0 3
1) “Peter Parker”
2) “Dexter Morgan”
3) “Captain Kirk”
4) “John Doe”
redis 127.0.0.1:6379> LTRIM students 1 3
OK
redis 127.0.0.1:6379> LLEN students
(integer) 3
redis 127.0.0.1:6379> LRANGE students 0 2
1) “Dexter Morgan”
2) “Captain Kirk”
3) “John Doe”
redis 127.0.0.1:6379> LREM students 1 “John Doe”
(integer) 1
redis 127.0.0.1:6379> LLEN students
(integer) 1
redis 127.0.0.1:6379> LRANGE students 0 1
1) “Captain Kirk”
5.3 集合(Sets)类型
Redis能够将一系列不重复的值存储成一个集合

redis 127.0.0.1:6379> SADD birds crow
(integer) 1
redis 127.0.0.1:6379> SADD birds pigeon
(integer) 1
redis 127.0.0.1:6379> SADD birds bat
(integer) 1
redis 127.0.0.1:6379> SADD mammals dog
(integer) 1
redis 127.0.0.1:6379> SADD mammals cat
(integer) 1
redis 127.0.0.1:6379> SADD mammals bat
(integer) 1
redis 127.0.0.1:6379> SMEMBERS birds
1) “bat”
2) “crow”
3) “pigeon”
redis 127.0.0.1:6379> SMEMBERS mammals
1) “bat”
2) “cat”
3) “dog”
Sets结构也支持相应的修改操作

redis 127.0.0.1:6379> SREM mammals cat
(integer) 1
redis 127.0.0.1:6379> SMEMBERS mammals
1) “bat”
2) “dog”
redis 127.0.0.1:6379> SADD mammals human
(integer) 1
redis 127.0.0.1:6379> SMEMBERS mammals
1) “bat”
2) “human”
3) “dog”
Redis还支持对集合的子交并补等操作

redis 127.0.0.1:6379> SINTER birds mammals
1) “bat”
redis 127.0.0.1:6379> SUNION birds mammals
1) “crow”
2) “bat”
3) “human”
4) “pigeon”
5) “dog”
redis 127.0.0.1:6379> SDIFF birds mammals
1) “crow”
2) “pigeon”
5.4 有序集合(Sorted Sets)类型
Sorted Sets和Sets结构相似,不同的是存在Sorted Sets中的数据会有一个score属性,并会在写入时就按这个score排好序。

redis 127.0.0.1:6379> ZADD days 0 mon
(integer) 1
redis 127.0.0.1:6379> ZADD days 1 tue
(integer) 1
redis 127.0.0.1:6379> ZADD days 2 wed
(integer) 1
redis 127.0.0.1:6379> ZADD days 3 thu
(integer) 1
redis 127.0.0.1:6379> ZADD days 4 fri
(integer) 1
redis 127.0.0.1:6379> ZADD days 5 sat
(integer) 1
redis 127.0.0.1:6379> ZADD days 6 sun
(integer) 1
redis 127.0.0.1:6379> ZCARD days
(integer) 7
redis 127.0.0.1:6379> ZRANGE days 0 6
1) “mon”
2) “tue”
3) “wed”
4) “thu”
5) “fri”
6) “sat”
7) “sun”
redis 127.0.0.1:6379> ZSCORE days sat
“5”
redis 127.0.0.1:6379> ZCOUNT days 3 6
(integer) 4
redis 127.0.0.1:6379> ZRANGEBYSCORE days 3 6
1) “thu”
2) “fri”
3) “sat”
4) “sun”
5.5 Hash类型
Redis能够存储key对多个属性的数据(比如user1.uname user1.passwd)

redis 127.0.0.1:6379> HKEYS student
1) “name”
2) “age”
3) “sex”
redis 127.0.0.1:6379> HVALS student
1) “Ganesh”
2) “30”
3) “Male”
redis 127.0.0.1:6379> HGETALL student
1) “name”
2) “Ganesh”
3) “age”
4) “30”
5) “sex”
6) “Male”
redis 127.0.0.1:6379> HDEL student sex
(integer) 1
redis 127.0.0.1:6379> HGETALL student
1) “name”
2) “Ganesh”
3) “age”
4) “30”
Hash数据结构能够批量修改和获取

redis 127.0.0.1:6379> HMSET kid name Akshi age 2 sex Female
OK
redis 127.0.0.1:6379> HMGET kid name age sex
1) “Akshi”
2) “2”
3) “Female”

6. java操作redis

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

import javax.sound.midi.Soundbank;
import java.util.*;

/**
 * @author: flychao88
 * Time: 2012.5.7 16:23:15
 */
public class RedisTest {
    JedisPool pool;
    Jedis jedis;
    @Before
    public void setUp() {
        pool = new JedisPool(new JedisPoolConfig(), "172.16.100.184");

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

    /**
     * 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 user=new HashMap();
        user.put("name","minxr");
        user.put("pwd","password");
        jedis.hmset("user",user);
        //取出user中的name,执行结果:[minxr]-->注意结果是一个泛型的List
        //第一个参数是存入redis中map对象的key,后面跟的是放入map中的对象的key,后面的key可以跟多个,是可变参数
        List 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 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));

    }

这边博客中的jar可以自行百度下载,如果会用maven那更好不过,简单配置一下即可。

如果运行代码时,在pool那获取resource报错,请常识关闭linux的防火墙,(centos下)执行如下命令:

$ sudo systemctl stop firewalld.service

关闭防火墙需要root权限,所以命令加上sudo前缀,如果是root用户登录不需要这个sudo

redis默认未开启用户认证,如果运行上面博文的代码时写了下面代码会报错

jedis.auth("password");

需在redis中开启认证,或将这一句注释掉即可,待redis配置和使用熟悉后再设置验证相关配置。

上一篇:kubernetes应用类型
下一篇:数据分析入门之matplotlib
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训

版权所有: 红黑联盟--致力于做实用的IT技术学习网站