redis缓存服务

1.mysql把数据存在硬盘上,持久化。

缓存的目的:读取数据更快,数据存在内存中。内存成本较高

mysql在读取写入频率更高的时候,会产生问题。内存被占满时,程序会假死,服务崩溃。

缓存只能临时存储数据,不能存储持久化数据。

缓存更新:当数据库更新了,缓存要同步更新。1)直接操作缓存服务。2)调用接口。(缓存端提供接口给业务端调用)3)发消息(消息队列,完全解耦,不用等待处理。数据强一致时会出现问题)。

常用的远程缓存框架:1)memcache:多线程 2)redis:单线程,支持简单的事务,支持集群

​ 性能不分上下,存储在memcache中的数据不能持久化,只能存内存。而redis既支持硬盘,又支持内存,持久化,相当于非关系型数据库。

3)本地缓存:效率高,但是小(使用的是jvm的堆内存),珍贵

2.缓存的实现原理:数据库->硬盘;缓存->内存

3.redis安装:redis-server.exe—>redis服务的启动文件;redis-cl.exe—>redis客户端的启动文件,使用前先手动启动

4.redis数据结构:string,list,hash,set,zset

string(应用较多):

string存储键值对,用set(中文乱码),使用相同的key,set name时是更新操作。

getset name abc:把当前name读取出来,再get name得到的是abc.

strlen:查看 对应值长度

incr:递增 incr count,只能用于整数类型

decr:递减,(incr,decr不能规定一次增多少,在java程序里可以)通常当作计数器,统计网站请求次数

append:追加数据,在当前字符串的基础上

mset:添加数据,键值对,mset k1 v1 k2 v2 k3 v3,批量插入,可以单条读取,也可以批量读取

del:删除key

keys *:查看当前redis服务中有哪些key 。

2)list:

lpush mylist abc:从左侧,在mylist中插入abc。

lrange mylist 0 10:从0开始查询10个数据,新的数据在前面

rpush my 1:从右侧

lrange mylist 0 10:从0开始查询10个数据,新的数据在后面

lindex my 1:通过下标找到对应数据

ltrim my 1 2:从下标是1的位置开始,截取两条数据

lpop my:从左侧弹出数据,没有数据返回nil

rpop my:从右侧弹出数据 ,没有数据返回nil

3)hash:可以压缩数据结构,更紧凑,节省内存空间

hset myhash k1 v1:存放键值对,k1,v1

hget myhash k1:v1

hexist myhash k2: 返回0代表不存在,返回1代表存在

hdel myhash k2:返回1,删除成功

hlen myhash:查看数据数量

hkeys myhash:查看所有的键

hvals myhash:查看所有的值

hgetall myhash:查看所有键值对

set和zset用的较少,了解即可。

5.使用java程序连接redis数据库:

Maven项目,导入jedis的jar包

<dependencies>
    <dependency>
        <groupId>redis.clients</groupId>
        <artifactId>jedis</artifactId>
        <version>2.9.0</version>
    </dependency>
</dependencies>

创建Jedis对象,配置ip和端口号:

package com.haina.redis;

import redis.clients.jedis.Jedis;

import java.util.List;

public class RedisTest {
public static void main(String[] args) {
String ip = “127.0.0.1”;
int port = 6379;

    //通过ip和端口号,创建redis连接对象
    Jedis jedis = new Jedis(ip, port);

   // jedis.set("java","测试");
    //给缓存设置过期时间,剩余有效期,可以使用ttl命令查看
    jedis.setex("exp",30,"test expire");
    jedis.mset("k11","v11","k22","v22");
    List<String> mget = jedis.mget("k11", "k22");
    System.out.println(mget);

    for (int i=0;i<10;i++) {
        jedis.incr("count");
    }
    String count = jedis.get("count");
    System.out.println(count);
    jedis.incrBy("count",20);
   count=jedis.get("count");
    System.out.println(count);
    //获取exp的剩余有效期,如果是持久存储的,则返回-1
    Long exp = jedis.ttl("k11");
    System.out.println(exp);

    jedis.hset("myhash","java","test");
    jedis.close();

}

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值