redis随记——应用

redis随记——应用,第1张

配置

①只支持bytes,大小写不敏感
②includes:可以包含別的公用的配置文件
③bind 127.0.0.1默认只能本机访问,不写不限制ip访问
④protected-mode yes:本机访问保护模式,在没有设bind ip和密码的情况下,Redis只允许接受本机的响应
⑤rcp-backlog:连接队列(完成+未完成三次握手的连接),高并发下需要高值来避免客户端连接慢的问题;注意:Linux内核会将这个值减小到/proc/sys/net/core/somaxconn的值(128),所以需要确认增大/proc/sys/net/core/somaxconn和/proc/sys/net/ipv4/tcp_max_syn_backlog(128)两个值来达到想要的效果
⑥timeout:一个空闲的客户端维持多少秒会关闭,0永不关闭
⑦tcp-keepalive:对访问客户端的心跳检测,n秒检测一次,0不会进行检测,建议设置成60
⑧daemonize:设置为yes,守护进程,后台启动
⑨pidfile:存放pid文件的位置,每个实例会产生一个不同的pid文件
⑩databases 16:设定库的数量 默认16,默认数据库为0,可以使用SELECT 命令在连接上指定数据库id
①requirepass foobared:设置密码,在控制台设置重启后就会失效
②maxclients:设置最大客户端连接数,默认情况下为10000个客户端。


如果达到了此限制,redis则会拒绝新的连接请求,并且向这些连接请求方发出“max number of clients reached”以作回应
③maxmemory :设置最大可用内存,必须设置,否则内存占满会造成服务器宕机。


一旦到达内存使用上限,redis将会试图移除内部数据,移除规则可以通过maxmemory-policy来指定。


如果redis无法根据移除规则来移除内存中的数据,或者设置了“不允许移除”,那么redis则会针对那些需要申请内存的指令返回错误信息,比如SET、LPUSH等
④maxmemory-policy:移除规则
Øvolatile-lru:使用LRU算法移除key,只对设置了过期时间的键;(最近最少使用)
Øallkeys-lru:在所有集合key中,使用LRU算法移除key
Øvolatile-random:在过期集合中移除随机的key,只对设置了过期时间的键
Øallkeys-random:在所有集合key中,移除随机的key
Øvolatile-ttl:移除那些TTL值最小的key,即那些最近要过期的key
Ønoeviction:不进行移除。


针对写 *** 作,只是返回错误信息
⑤maxmemory-samples:设置样本数量,LRU算法和最小TTL算法都并非是精确的算法,而是估算值,所以你可以设置样本的大小,redis默认会检查这么多个key并选择其中LRU的那个。


一般设置3到7的数字,数值越小样本越不准确,但性能消耗越小。


发布和订阅

①subscribe channel1订阅channel1频道,publish channel1 hello向频道发送hello

新数据类型

①Bitmaps: *** 作位
②HyperLogLog:大数据量下基数问题的计算统计 *** 作
③Geospatial:经纬度或地理位置的 *** 作(范围查询、距离查询等),两极无法直接添加,一般会下载城市数据直接通过JAVA程序一次性导入,有效的经度从-180到180度,有效纬度从-85.05112878到85.05112878,不能重复添加已添加的

Jedis

①jedis是redis的客户端,java可以通过它 *** 作redis,类似JDBC的作用
②Jedis jedis= new Jedis(ip,port);jedis.ping();测试是否能连通
③ *** 作方法基本与Linux上一致
④模拟验证码
Random生成6位数字
把验证码放redis里,设置过期时间120秒
从redis获取验证码进行比较
每个手机每天只能发送3次验证码:incr每次发送后+1,大于2的时候,不能再发送

经典应用

①验证码
②秒杀
③分布锁

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/584548.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-04-12
下一篇 2022-04-12

发表评论

登录后才能评论

评论列表(0条)

保存