Redis技法篇 - 1. Redis的安装与配置

Python014

Redis技法篇 - 1. Redis的安装与配置,第1张

Redis可以说是除MySQL之外用的最多的一个数据库了!众所周知,它是一个种非关系型数据库(NoSQL),当然它的出现也绝不是为了取代MySQL。非关系型数据库有很多种类型:面向列的NoSQL、基于图的NoSQL、文档型NoSQL ...... Redis是一种Key-Value型的NoSQL。

使用Redis并不难,他和MySQL的关系也不大,甚至我觉得Redis的学习难度要小于MySQL。但是Redis在目前的技术架构中非常常见,它的作用也绝对不仅仅是缓存中间件,所以很显然这是Java从业者的必备技能。Redis在大厂面试中出现的频率非常的高,学好它能帮助你在面试中脱颖而出!

其实在写这份学习资料的时候,我才刚刚毕业,也谈不上多么精通Redis!但是我觉得学习任何一门数据库都是一个循序渐进的过程。先熟练掌握它的使用、然后了解它的底层原理、接着在实践中应用它、最后就是读源码完全吃透它!因为读者水平有限接下来我将推出 「《Java之禅 | Redis篇》」 ,希望能够给苦海中的同学一些指引,其实我觉得学完这两篇再背一下面经就可以和面试官侃侃而谈了!

最重要的事情说三遍: 「一定要多练、多练、多练!照着文档多敲多写,熟能生巧,切忌光看不动手!」

学习Redis一定逃不过黄健宏老师的这本 「《Redis设计与实现》」 ,这本书并不是教你怎么使用Redis的,而是带你深入了解Redis内部原理的!总结起来就是:通俗易懂、恍然大悟!

当然黄老师还有一本 「《Redis使用手册》」 ,这个的热度远远不如前一本,这本书更像是一本工具书,系统化介绍Redis命令和使用。

视频的话其实我觉得做的比较好的是 「尚硅谷的《Redis6入门到精通》和黑马程序员的《Redis入门到实战》」

「《Java之禅 | Redis篇》」 是我接下来要整理并开源的一份资料,我希望它能够以更加通俗易懂地方式教你使用和理解Redis。

写这个的初衷当然是希望后人能够更加顺畅的学习和使用它,我的学习之路其实挺艰难的,感觉很多教学视频讲的都不是太好,然后CSDN博客又有点乱,希望自己能够把我的理解与心得帮助其他人吧!

这份资料全篇分为 「《Redis技法》和《Redis基石》」 两部分。《Redis技法》主要是教你怎么使用,从简单的客户端到Java操作到高级应用,不涉及Redis的原理。《Redis基石》主要是学习Redis的设计思想和内部思路,希望能够窥探到一些Redis的底层实现,帮助大家更好地了解Redis。

作者:一壶漂泊难入喉

原文出处:https://mdnice.com/writing/264777dd98904db580e4c874cb6dcaea

package redis

import java.util.List

import java.util.UUID

import redis.clients.jedis.Jedis

import redis.clients.jedis.ShardedJedis

import redis.clients.util.ShardInfo

/**

* @author Andy

*/

public class RedisMasterSlaveTest {

private static final String HOST = ""

private static final int PORT = 0

/**

* 添加测试数据

*/

private static void setData(Jedis jedis) {

for (int i = 0i <100i++) {

final String a = UUID.randomUUID().toString()

jedis.set(a, a)

}

}

/**

* dbsize 数据库key总数

*/

private static long getDBSize(Jedis jedis) {

return jedis.dbSize()

}

/**

* 查询持久化策略

*/

private static List<String>getSaveConfig(Jedis jedis) {

return jedis.configGet("save")

}

/**

* 设置持久化策略

*/

private static String setSaveConfig(Jedis jedis) {

String celue_1 = "800 1"

String celue_2 = "400 2"

return jedis.configSet("save", celue_1 + " " + celue_2)

}

/**

* 阻塞IO后持久化数据然后关闭redis (shutdown)

*/

private static String shutdown(Jedis jedis) {

return jedis.shutdown()

}

/**

* 将此redis设置为master主库

*/

private static String slaveofNoOne(Jedis jedis) {

return jedis.slaveofNoOne()

}

/**

* 将此redis根据host/port设置为slaveof从库

*/

private static String slaveof(Jedis jedis) {

return jedis.slaveof(HOST, PORT)

}

/**

* 查询redis的info信息

*/

private static String info(Jedis jedis) {

return jedis.info()

}

/**

* select?

*/

private static String select(Jedis jedis) {

return jedis.select(1)

}

}

////不要谢

Redis的配置

daemonize 如果需要在后台运行,把该项改为yes

pidfile 配置多个pid的地址,默认在/var/run/redis.pid

bind 绑定ip,设置后只接受自该ip的请求

port 监听端口,默认为6379

timeout 设置客户端连接时的超时时间,单位为秒

loglevel 分为4级,debug、verbose、notice、warning

logfile 配置log文件地址

databases 设置数据库的个数,默认使用的数据库为0

save 设置redis进行数据库镜像的频率,保存快照的频率,第一个*表示多长时间, 第三个*表示执行多少次写操作。在一定时间内执行一定数量的写操作时,自动保存快照。可设置多个条件。

rdbcompression 在进行镜像备份时,是否进行压缩

Dbfilename 镜像备份文件的文件名

Dir 数据库镜像备份的文件放置路径

Slaveof 设置数据库为其他数据库的从数据库

Masterauth 主数据库连接需要的密码验证

Requirepass 设置登录时需要使用的密码

Maxclients 限制同时连接的客户数量

Maxmemory 设置redis能够使用的最大内存

Appendonly 开启append only模式

appendfsync 设置对appendonly.aof文件同步的频率

vm-enabled 是否虚拟内存的支持

vm-swap-file 设置虚拟内存的交换文件路径

vm-max-memory 设置redis使用的最大物理内存大小

vm-page-size 设置虚拟内存的页大小

vm-pages 设置交换文件的总page数量

vm-max-threads 设置VMIO同时使用的线程数量

glueoutputbuf 把小的输出缓存存放在一起

hash-max-zipmap-entries 设置hash的临界值

activerehashing 重新has