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