redis的安装及使用

来源:互联网 发布:淘宝点击分享怎么点击 编辑:程序博客网 时间:2024/05/16 08:14

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-develyum install -y cyrus-sasl-plain cyrus-sasl-devel cyrus-sasl-gssapiyum -y install libffi-develyum -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”

更多的学习,请参考:
1.菜鸟教程:http://www.runoob.com/redis/redis-tutorial.html
2.推荐的博客:http://blog.csdn.net/eroswang/article/details/7080412

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<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));    }

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

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

$ sudo systemctl stop firewalld.service

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

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

jedis.auth("password");

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

原创粉丝点击