标签:扩展 运行 private beijing write 官网 exce 分数 内存
Redis是一个使用ANSI C编写的开源、支持网络、基于内存、可选持久性的键值对存储数据库 ——维基百科
可以简单的说,Redis就是一款高性能的NoSQL数据库
我们前面所学习的MySQL数据库是典型的的SQL数据库也就是传统的关系型数据库,而我们今天学习的Redis数据库则是一款NoSQL数据库,也叫作非关系型数据库,它与我们熟悉的MySQL等的概念完全是不一样的,它是一项全新的数据库理念,我们帖一组百度百科的解释
NoSQL,泛指非关系型的数据库。随着互联网web2.0网站的兴起,传统的关系数据库在处理web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,出现了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题 ——百度百科
说明:我们现在所看到的的博客,RSS,P2P,微博,抖音等均属于 Web2.0的产物,Web2.0相比较过去的Web1.0更加注重于用户的交互,用户不仅可以浏览,还可以上传一些资源到网站上,例如图片文字或者说短视频等,使得用户也参与到了网站内容的制造中去了
有人会说,NoSQL = Not SQL ,但是我更倾向这样理解 NoSQL = Not only SQL ,我们不能以一个绝对的结论来判定两项技术的好坏,每一项技术的产生都有其特定的原因,在我看来,NoSQL更适合作为SQL数据库的补充,由于海量数据的出现,性能的要求高了起来,而NoSQL这种产物,对于结构简单但是数据量大的数据处理起来要比传统的SQL快很多,但是同样的,其逻辑运算就必须很简单,否则它也是力不从心的
在我看来,可以简单的说,NoSQL就是以功能换取性能,但是需要处理复杂的业务逻辑还需要使用关系型数据库,所以说想要在模型中完全用NoSQL替代SQL是不现实的,两者更像是互补的关系
SQL的好处:
市面上的NoSQL产品非常多,我们今天所要介绍的就是其中一款基于键值存储的数据库——Redis
我们在一开始提到了,Redis就是一款高性能的NoSQL数据库,那么它的应用场景是什么呢?
任务队列,例如:秒杀,12306
在线好友列表
应用、网站访问统计排行
由于其基于键值存储,那么可以支持的存储的类型有什么呢?
字符串类型 - String
列表 - list:linkedlist
集合 - set
有序集合 - sortedset
哈希 - hash:map
由于官网访问速度过慢,我们可以访问对应的中文网:http://www.redis.net.cn
下载,解压,编译:
$ wget http://download.redis.io/releases/redis-5.0.4.tar.gz
$ tar xzf redis-5.0.4.tar.gz
$ cd redis-5.0.4
$ make
二进制文件是编译完成后在src目录下. 运行如下:
$ src/redis-server
你能使用Redis的内置客户端进行进行redis代码的编写,例如我们存入一个键值 name-zhangsan
$ src/redis-cli
redis> set name zhangsan
OK
redis> get name
"zhangsan"
我们可以去github中寻找windows版本,不过版本会有所滞后
https://github.com/microsoftarchive/redis/releases
解压即可用
redis-server.exe:redis服务器端
redis.windows.conf:配置文件
- 127.0.0.1:6379> set address beijing
- OK
- 127.0.0.1:6379> get address
- “beijing”
- 127.0.0.1:6379> del address
- (integer) 1
添加一个元素到列表的头部(左边)或者尾部(右边)
127.0.0.1:6379> lpush listDemo zhangsan
(integer) 1
127.0.0.1:6379> lpush listDemo lisi
(integer) 2
127.0.0.1:6379> rpush listDemo wangwu
(integer) 3
1) "lisi"
2) "zhangsan"
3) "wangwu"
set:String 类型的无序集合,且元素不能重复
127.0.0.1:6379> sadd setDemo aaa
(integer) 1
127.0.0.1:6379> sadd setDemo aaa
(integer) 0
127.0.0.1:6379> smembers setDemo
1) "aaa“
127.0.0.1:6379> srem setDemo aaa
(integer) 1
sortedset 和 set 一样也是 string 类型元素的集合,且不允许重复的元素
不同的是每个元素都会关联一个double类型的分数,redis正是通过分数来为集合中的成员进行从小到大的排序
有序集合的成员是唯一,但分数(score)却可以重复
127.0.0.1:6379> zadd sortedsetDemo 20 zhangsan
(integer) 1
127.0.0.1:6379> zadd sortedsetDemo 10 lisi
(integer) 1
127.0.0.1:6379> zadd sortedsetDemo 60 wangwu
(integer) 1
127.0.0.1:6379> zrange sortedsetDemo 0 -1
1) "lisi"
2) "zhangsan"
3) "wangwu"
127.0.0.1:6379> zrem sortedsetDemo wangwu
(integer) 1
127.0.0.1:6379> hset hashDemo username admin
(integer) 1
127.0.0.1:6379> hset hashDemo password admin
(integer) 1
127.0.0.1:6379> hget hashDemo password
"admin"
127.0.0.1:6379> hgetall hashDemo
1) "username"
2) "admin"
3) "password"
4) "admin"
127.0.0.1:6379> hdel hashDemo username
(integer) 1
开篇已经讲过,Redis是一个内存数据库,也就是说,我们的数据全部存储在内存中,而我们常见的MySQL和Oracle等SQL数据库会将数据存储到硬盘中,凡事都是有利有弊,虽然内存数据库读写速度要比在硬盘中读写的数据库快的多,但是却出现了一个很麻烦的问题,也就是说,当 Redis 服务器重启或者宕机后,内存中的数据会全部丢失,为了解决这个问题,Redis提供了一种持久化的技术,也就是将内存中的数据存储到硬盘中去,日后方便我们使用这些文件恢复数据库中的数据
RDB:一定的时间内,检测key的变化情况,然后持久化数据
我们想要配置它,需要编辑 redis.windows.conf 配置文件
# Save the DB on disk:
#
# save <seconds> <changes>
#
# Will save the DB if both the given number of seconds and the given
# number of write operations against the DB occurred.
#
# In the example below the behaviour will be to save:
# after 900 sec (15 min) if at least 1 key changed
# after 300 sec (5 min) if at least 10 keys changed
# after 60 sec if at least 10000 keys changed
# ......省略部分
save 900 1
save 300 10
save 60 10000
我们需要修改的就是最后三行,前面的说明的意思是,如果给定的秒数和给定的对数据库的写操作数同时发生,那么将保存数据库,也就是说,它的配置是根据save后面的两个数字,根据说明可知,第一个数字代表间隔时间,第二个数代表操作数据的数量
例如第一个 save 900 1 ,就是说每900秒且,至少一个 key 被改变则保存数据
我们根据自己具体项目的需要设置好后,需要重新启动Redis的服务器,并且我们需要指定配置文件,我们先指向到Redis指定目录下, 然后输入命令 redis-server.exe redis.windows.conf
例如我本地:D:\Tools\Redis-x64-3.2.100>redis-server.exe redis.windows.conf
AOF:每一次操作后,就持久化数据
我们同样可以在 redis.windows.conf 文件配置
我们找到这一行
appendonly no
no代表关闭aof,改为yes代表开启
还有这一行
# appendfsync no
:不进行持久化
我们可以修改 no 位置的值
Jedis is a blazingly small and sane Redis java client.
Jedis was conceived to be EASY to use.
Jedis 是一款可以让我们在java中操作redis数据库的工具,下载其jar包导入即可,使用还是非常简单的
//获取连接,空构造代表默认值 "localhost",6379端口
Jedis jedis = new Jedis();
//存储
jedis.set("address","beijing");
//获取
String address = jedis.get("address");
//关闭连接
jedis.close();
补充:setex() 方法可以存储数据,并且指定过期时间
//将aaa-bbb存入,且10秒后过期
jedis.setex("aaa",10,"bbb")
//获取连接,空构造代表默认值 "localhost",6379端口
Jedis jedis = new Jedis();
//存储
jedis.lpush("listDemo","zhangsan","lisi","wangwu");//从左
jedis.rpush("listDemo","zhangsan","lisi","wangwu");//从右
//获取
List<String> mylist = jedis.lrange("listDemo", 0, -1);
//删除,并且返回元素
String e1 = jedis.lpop("listDemo");//从左
String e2 = jedis.rpop("listDemo");//从右
//关闭连接
jedis.close();
//获取连接,空构造代表默认值 "localhost",6379端口
Jedis jedis = new Jedis();
//存储
jedis.sadd("setDemo","zhangsan","lisi","wangwu");
//获取
Set<String> setDemo = jedis.smembers("setDemo");
//关闭连接
jedis.close();
//获取连接,空构造代表默认值 "localhost",6379端口
Jedis jedis = new Jedis();
//存储
jedis.zadd("sortedsetDemo",20,"zhangsan");
jedis.zadd("sortedsetDemo",10,"lisi");
jedis.zadd("sortedsetDemo",60,"wangwu");
//获取
Set<String> sortedsetDemo = jedis.zrange("sortedsetDemo", 0, -1);
//关闭连接
jedis.close();
//获取连接,空构造代表默认值 "localhost",6379端口
Jedis jedis = new Jedis();
//存储
jedis.hset("hashDemo","name","lisi");
jedis.hset("hashDemor","age","20");
//获取
String name = jedis.hget("hashDemo", "name");
//获取所有数据
Map<String, String> user = jedis.hgetAll("hashDemo");
Set<String> keySet = user.keySet();
for (String key : keySet) {
//获取value
String value = user.get(key);
System.out.println(key + ":" + value);
}
//关闭连接
jedis.close();
为什么我们要使用连接池呢?
我们要使用Jedis,必须建立连接,我们每一次进行数据交互的时候,都需要建立连接,Jedis虽然具有较高的性能,但建立连接却需要花费较多的时间,如果使用连接池则可以同时在客户端建立多个连接并且不释放,连接的时候只需要通过一定的方式获取已经建立的连接,用完则归还到连接池,这样时间就大大的节省了
//创建一个配置对象
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxIdle(10);
//创建Jedis连接池对象
JedisPool jedisPool = new JedisPool(config,"localhost",6379);
//获取连接
Jedis jedis = jedisPool.getResource();
//使用
jedis.set("setDemo","zhangsan");
//关闭 归还到连接池中
jedis.close();
public class JedisPoolUtils {
private static JedisPool jedisPool;
//静态代码初始化池配置
static{
//创建Properties对象
Properties pro = new Properties();
//读取配置文件
InputStream is = JedisPoolUtils.class.getClassLoader().getResourceAsStream("jedis.properties");
//关联文件
try {
pro.load(is);
} catch (IOException e) {
e.printStackTrace();
}
//获取数据,配置到JedisPoolConfig
JedisPoolConfig config = new JedisPoolConfig();
config.setMaxTotal(Integer.parseInt(pro.getProperty("maxTotal")));
config.setMaxIdle(Integer.parseInt(pro.getProperty("maxIdle")));
//实例化JedisPool
jedisPool = new JedisPool(config,pro.getProperty("host"),Integer.parseInt(pro.getProperty("port")));
}
/**
* 获取连接
*/
public static Jedis getJedis(){
return jedisPool.getResource();
}
}
如果文章中有什么不足,或者错误的地方,欢迎大家留言分享想法,感谢朋友们的支持!
如果能帮到你的话,那就来关注我吧!如果您更喜欢微信文章的阅读方式,可以关注我的公众号
在这里的我们素不相识,却都在为了自己的梦而努力 ?
一个坚持推送原创开发技术文章的公众号:理想二旬不止
标签:扩展 运行 private beijing write 官网 exce 分数 内存
原文地址:https://www.cnblogs.com/ideal-20/p/11621567.html