二十三、redis

本文介绍了Redis的基础知识,包括其概念、下载与安装、主要数据结构如string、hash、list、set和sortedset的操作,以及持久化方法RDB和AOF。此外,还详细讲解了Java操作Redis的工具Jedis,包括快速入门、各种命令操作示例及连接池的使用。最后,文章提供了一个使用Redis进行缓存优化的案例分析。
摘要由CSDN通过智能技术生成

概述:

1. redis
	1. 概念
	2. 下载安装
	3. 命令操作
		1. 数据结构
	4. 持久化操作
	5. 使用Java客户端操作redis

1、redis概念

在这里插入图片描述
当数据庞大的时候,如果在关系型数据库里检索数据,那么会非常耗时间,检索耗时,加载进内存耗时。
但,如果在内存中开辟一个空间来缓存无关系的数据,那么数据就不需要加载进内存,直接在用就好了(因为在内存里),而且不需要进行关系查询。

2、下载&安装

2. 下载安装
	1. 官网:https://redis.io
	2. 中文网:http://www.redis.net.cn/
	3. 解压直接可以使用:
		* redis.windows.conf:配置文件
		* redis-cli.exe:redis的客户端
		* redis-server.exe:redis服务器端

先打开服务器端,再打开客户端即可。

3、数据结构介绍【敲黑板】

3. 命令操作
	1. redis的数据结构:
		* redis存储的是:key,value格式的数据,其中key都是字符串,value有5种不同的数据结构
			* value的数据结构:
				1) 字符串类型 string
				2) 哈希类型 hash : map格式  
				3) 列表类型 list : linkedlist格式。支持重复元素
				4) 集合类型 set  : 不允许重复元素
				5) 有序集合类型 sortedset:不允许重复元素,且元素有顺序

在这里插入图片描述
下面的命令操作都是在redis数据库客户端上操作的,不是java客户端(Java客户端需要数据库连接对象)

4、命令操作:string&hash

2. 字符串类型 string
		1. 【存储】: set key value
			127.0.0.1:6379> set username zhangsan
		2. 【获取】: get key
			127.0.0.1:6379> get username
		3. 【删除】: del key
			127.0.0.1:6379> del age
	3. 哈希类型 hash
		1. 【存储】: hset key field value
			127.0.0.1:6379> hset myhash username lisi
			127.0.0.1:6379> hset myhash password 123
		2. 【获取】: 
			* hget key field: 获取指定的field对应的值
				127.0.0.1:6379> hget myhash username
			* hgetall key:获取所有的field和value
				127.0.0.1:6379> hgetall myhash
		3. 【删除】: hdel key field
			127.0.0.1:6379> hdel myhash username

field是哈希的value的字段。(这个字段又是另一个key)

5、命令操作:list

4. 列表类型 list:可以添加一个元素到列表的头部(左边)或者尾部(右边)
		1. 【添加】:
			1. lpush key value: 将元素加入列表左表
				
			2. rpush key value:将元素加入列表右边
				
				127.0.0.1:6379> lpush myList a
				127.0.0.1:6379> lpush myList b
				127.0.0.1:6379> rpush myList c
		2. 【获取】:
			* lrange key start end :范围获取
				127.0.0.1:6379> lrange myList 0 -1 【获取全部】
				1) "b"
				2) "a"
				3) "c"
		3. 【删除】:
			* lpop key: 删除列表最左边的元素,并将元素返回
			* rpop key: 删除列表最右边的元素,并将元素返回

流程图:
在这里插入图片描述

6、命令操作:set&sortedset

set

5. 集合类型 set : 不允许重复元素,(无序的,无论取出还是存储)
		1. 【存储:sadd key value】
			127.0.0.1:6379> sadd myset a
			(integer) 1
			127.0.0.1:6379> sadd myset a
			(integer) 0
		2. 【获取:smembers key:获取set集合中所有元素】
			127.0.0.1:6379> smembers myset
			1) "a"
		3. 【删除:srem key value:删除set集合中的某个元素】	
			127.0.0.1:6379> srem myset a
			(integer) 1

sortedset

6. 有序集合类型 sortedset:不允许重复元素,且元素有顺序.

		1. 【存储:zadd key score value】
			127.0.0.1:6379> zadd mysort 60 zhangsan
			(integer) 1
			127.0.0.1:6379> zadd mysort 50 lisi
			(integer) 1
			127.0.0.1:6379> zadd mysort 80 wangwu
			(integer) 1
		2. 【获取:zrange key start end [withscores]127.0.0.1:6379> zrange mysort 0 -1
			1) "lisi"
			2) "zhangsan"
			3) "wangwu"

			127.0.0.1:6379> zrange mysort 0 -1 withscores
			1) "zhangsan"
			2) "60"
			3) "wangwu"
			4) "80"
			5) "lisi"
			6) "500"
		3. 【删除:zrem key value】
			127.0.0.1:6379> zrem mysort lisi
			(integer) 1

为什么是sortedset有序的?

因为sortedset添加元素的时候,每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。(设置分数,再对分数进行排序)

sortedset一般用在搞【排行榜】业务那里。

7、命令操作:通用命令

7. 通用命令
		1. keys * : 查询所有的键
		2. type key : 获取键对应的value的类型
		3. del key:删除指定的key value

持久化

RDB性能会比AOF好点。
因为RDB是按时间的间隔,并判断key是否变化指定次数才把数据存进硬盘里,而AOF是是操作一下就保存一下,就行MySQL一样
但是,使用RDB只能保证大部分数据不丢失,为了解决这种不安全性,redis和关系型的数据库进行配合。

8、持久化:RDB

2. AOF:日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据
			1. 编辑redis.windwos.conf文件
				appendonly no(关闭aof) --> appendonly yes (开启aof)
				
				# appendfsync always : 每一次操作都进行持久化
				appendfsync everysec : 每隔一秒进行一次持久化(默认)
				# appendfsync no	 : 不进行持久化
4. 持久化
	1. redis是一个内存数据库,当redis服务器重启,或者电脑重启,数据会丢失,我们可以将redis内存中的数据持久化保存到硬盘的文件中。
	2. redis持久化机制:
		1. RDB:默认方式,不需要进行配置,默认就使用这种机制
			* 在一定的间隔时间中,检测key的变化情况,然后持久化数据
			1. 【编辑redis.windwos.conf文件】
				#   after 900 sec (15 min) if at least 1 key changed
				save 900 1
				#   after 300 sec (5 min) if at least 10 keys changed
				save 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值