Redis

一.Redis简介

1.Redis(Remote Dictionary Server ):

即远程字典服务,是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。

2.redis是一个基于内存的缓存数据库,不同于mysql,oracle这类关系型数据库,Redis是一个非关系型数据库.

3.特点:

(1)内存作为数据存储介质。1.珍贵,2.读写效率极⾼,远超数据库。需要异步的同步到磁盘
上,所以,持久化⽅式有两种。
(2)⾮关系型数据库,所以KeyValue形式存储,数据类型value有多种,常⻅的有5种。
(3)与 memcache 不同的是,但有持久化操作,可以作为数据库使⽤。持久化⽅式两种:快照
模式,aof⽇志追加模式。
(4)主从模式,主服务器和备服务器,哨兵模式。
(5) 缓存过程:第⼀次取,将数据从数据库读取,都放在内存中的redis中,缓存,第⼆次,直
接从内存的redis去取,节约了应⽤程序服务器和数据库通过io交互的次数。

4.执行redis的指令

//1. 启动redis服务端
redis-server redis.windows.conf
//2. 启动redis客户端
//重启⼀个cmd,之前的不能关,是服务器
redis-cli.exe -p 6379
redis-cli.exe -h localhost -p 6379
//3. 服务器和客户端是否接上头
ping
//4. 设置密码
//服务器不重启⼀直这个密码
config set requirepass abc

5.五大数据类型:

Redis有五大数据类型,分别是:
(1)String
(2)list
(3)hash
(4)set
(5)zset
对应指令:

//选择数据库,默认0-15有16个数据库
 select 2
//1. 设置获取 string
 set hello world
 get hello
//2. 存储 hash 类型,适合存储对象。
 hmset stu sid 02142010 score 99
 hgetall stu
 hget stu sid
//3. lists:(1)重复有序,返回下标索引。(2)redis的list基于链表,查询慢,插⼊删除快。
 //左侧插⼊ 
 lpush subject java
 lpush subject html5
 lpush subject python
 lrange subject 1 100
 //右侧插⼊
 rpush bike hello
 rpush bike ofo
 rpush bike mobike
 lrange bike 0 100
 rpush bike hello
//4. set ⽆序集合,不重复,返回受影响⾏数。
 sadd week monday
 sadd week thuresday
 sadd week Wednesday
 sadd week thrusday
 smembers week
//5. zset 有序集合,不重复。
 zadd java 100 yiyi
 zadd java 100 erer
 zadd java 99 sansan
 zrangebyscore java 0 99
 zrangebyscore java 100 100

6.安全:

redis可以设置密码:

//设置密码,默认没有密码
set requirepass abc
auth abc

二.Jedis

1.简介:

jedis是java用来访问redis数据库的api。

2.引入依赖

本次引入了一个Redis的jar包,

<dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>redis.clients</groupId>
            <artifactId>jedis</artifactId>
            <version>2.8.0</version>
        </dependency>
    </dependencies>

3.测试代码:

TestRedis.java

import org.apache.commons.pool2.impl.GenericObjectPoolConfig;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import redis.clients.jedis.Jedis;
import redis.clients.jedis.JedisShardInfo;
import redis.clients.jedis.ShardedJedis;
import redis.clients.jedis.ShardedJedisPool;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

public class TestJedis {

    Jedis j =null;

    @Before
    public void setUp(){
        j = new Jedis();
    }

    @After
    public void tearDown(){
        if(j != null){
            j.close();
            j = null;
        }
    }
    @Test
    public void test(){
        //j = new Jedis("127.0.0.1",6379);
        System.out.println(j.ping());
    }

    @Test
    public void testString(){
        System.out.println(j.set("aaa","123"));
        System.out.println(j.get("aaa"));
    }

    @Test
    public void testHash(){
        Map<String,String> h1 = new HashMap<>();
        h1.put("jack","jackValue");
        System.out.println(j.hmset("actor",h1));
        System.out.println(j.hgetAll("actor"));
        System.out.println(j.hget("actor", "jack"));
    }

    @Test
    public void testList(){
        System.out.println(j.lpush("person", "wx"));
        System.out.println(j.lpush("person", "hwl"));
        System.out.println(j.lpush("person", "gj", "gx", "wsk"));
        System.out.println(j.lrange("person",0,100));
    }

    @Test
    public void testSet(){
        System.out.println(j.sadd("food", "duck", "beef", "fork"));
        System.out.println(j.smembers("food"));
    }

    @Test
    public void testZSet(){
        System.out.println(j.zadd("fs", 100, "java"));
        System.out.println(j.zadd("fs", 99, "html5"));
        System.out.println(j.zadd("fs", 79, "testing"));
        System.out.println(j.zadd("fs", 59, "python"));
        System.out.println(j.zrangeByScore("fs", 60, 99));
    }

    @Test
    public void testPool(){
        GenericObjectPoolConfig config = new GenericObjectPoolConfig();
        //设置最大的空闲数
        config.setMaxIdle(20);
        //设置最大的连接数
        config.setMaxTotal(50);
        //设置等待时间
        config.setMaxWaitMillis(5000);

        List<JedisShardInfo> shard  = new ArrayList<>();

        shard.add(new JedisShardInfo("localhost","6379"));

        ShardedJedisPool pool = new ShardedJedisPool(config,shard);

        ShardedJedis jedis = pool.getResource();

        System.out.println(jedis.get("aaa"));
    }
}

今天是我在千锋线上学习的第53天,加油!!!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容