redis拾趣(客户端连接,keys命令,数据备份,缓存有效期等)
1.客户端连接
为了安全保护,redis支持绑定IP跟端口,这个通过conf配置文件中的bind跟port来设置。
绑定后登录client控制台时就需要写明ip(或者hostname)跟端口了,如:
./redis_cli -h 10.137.19.19 -p 6389
redis_cli客户端支持远程登录,所以在集群环境中我们不需要切换机器,直接
./redis_cli -h hostname -p 端口 就可以登录到任何一台主机。
另外它还带有循环执行命令等各种有用的功能,可以./redis-cli --help看到
2.用keys命令查找
我们知道keys * ,是显示当前库下所有的keys。
另外keys命令还支持模糊查询:
如:
keys 28*43
会显示如下的key列表
1) "285143"
2) "286043"
keys 2??3??
显示如下:
1) "295313"
2) "295328"
3) "295332"
4) "295375"
5) "287360"
?是长度匹配,*是全局匹配。
另外想知道key的数量我们可以输入:
dbsize
3.redis的数据备份
redis是自带备份功能的,原先是通过设置配置文件中的:
save 900 1
save 300 10
save 60 10000
这样我们就可以把redis当成一个数据库来用。
但是目前为了性能需要,取消了自动备份数据功能,完全当做一个缓存数据库来用。
这样给性能测试带来也很多不便,每次都要刷数据,好在redis自带了数据备份功能:
在redis客户端上输:SAVE或者BGSAVE即可完成备份。
推荐使用BGSAVE,redis会启动一个单独的线程完成备份,而SAVE命令则不会。
数据会备份在redis的db目录下。这个是通过设置conf中的dbfilename参数来指定的。
这样下次redis重启时所有的数据都不会丢失,redis会自动去目录下读取备份文件启动。
实测了一下,启动时redis读取3G的备份文件只需要十秒左右,还是相当快的。
4.缓存有效期的设置
我们通过expire命令设置一对k—v的有效期,如:
EXPIRE key seconds
然后通过TTL命令就可以看到这个key还有多久就过期了:
TTL key
如果想这个key没有过期时间,可以这样:
PERSIST key
当然,当数据满时,redis会根据算法剔除相应的键值对,目前支持这么多方式剔除:
# volatile-lru -> remove the key with an expire set using an LRU algorithm
# allkeys-lru -> remove any key accordingly to the LRU algorithm
# volatile-random -> remove a random key with an expire set
# allkeys->random -> remove a random key, any key
# volatile-ttl -> remove the key with the nearest expire time (minor TTL)
# noeviction -> don't expire at all, just return an error on write operations
xmpp目前采用allkeys-lru,这个通过设置maxmemory-policy来确定。
5.info命令
客户端输info能显示redis目前的运行情况。
是监测时常用的一个命令。通常跟
redis_cli -r 循环次数 -i 循环时间
配合使用
如需要监视redis每秒有多少对KV由于内存满了被驱逐出去,可以这样写:
./redis-cli -r 10 -i 1 info | grep evicted_keys
6.redis内存占用
redis的内存占用在info里面可以看到:
used_memory:8536027504
used_memory_human:7.95G
used_memory_rss:8537772032
mem_fragmentation_ratio:1.00
use_tcmalloc:0
used_memory代表redis占用内存。包括redis自身程序占用的内存。
used_memory_human代表KV数据占据的内存。
used_memory_rss代表涵盖内存碎片的内存。
redis在分配内存的时候采用了malloc,类似于java的new。
目前支持三种内存分配器:tcmalloc,jemalloc和libc
对于2.2.14版本来说如果没有安装tcmalloc,jemalloc就会默认使用libc。
这个可以通过use_tcmalloc来看到使用了哪种。
mem_fragmentation_ratio则代表了分配器碎片率。(原来使用C也会产生内存碎片。。。。。。。。)
通过这几个参数基本能看到目前redis的内存情况,但是这个不是最准确的,最准确的话还是结合shell命令(如ps,top)看比较好,不过通常没有太大误差。
redis拾趣(客户端连接,keys命令,数据备份,缓存有效期等)的更多相关文章
- Redis客户端连接以及持久化数据(三)
0.Redis目录结构 1)Redis介绍及部署在CentOS7上(一) 2)Redis指令与数据结构(二) 3)Redis客户端连接以及持久化数据(三) 4)Redis高可用之主从复制实践(四) 5 ...
- Redis 千万不要乱用KEYS命令,不然会挨打的
Redis现如今使用的场景越来越多?如何批量删除key呢? 有人说用KEYS命令,刚开始学Redis的时候就是用这个命令列出库中键. KEYS命令要谨慎使用. 为何?客观别急,我们先一步步来看. KE ...
- Mysql数据库常用的命令 数据备份 恢复 远程
远程数据库 格式: mysql -h主机地址 -u用户名 -p用户密码数据库 mysql -h 42.51.150.68 -u yang -p discuz mysql设置密码 mysql>us ...
- Redis 的 KEYS 命令不能乱用啊
KESY 命令 时间复杂度: O(N) , 假设Redis中的键名和给定的模式的长度有限的情况下,N为数据库中key的个数. Redis Keys 命令用于查找所有符合给定模式 pattern 的 k ...
- redis基础操作~~数据备份与恢复、数据安全、性能测试、客户端连接、分区
数据备份与恢复 数据备份redis save 命令用于创建当前数据库的备份. redis 127.0.0.1:6379> SAVE OK 该命令将在 redis 安装目录中创建dump.rdb文 ...
- Redis 数据备份与恢复,安全,性能测试,客户端连接,管道技术,分区(四)
Redis 数据备份与恢复 Redis SAVE 命令用于创建当前数据库的备份. 语法 redis Save 命令基本语法如下: redis 127.0.0.1:6379> SAVE 实例 re ...
- 【Azure Redis 缓存】Azure Redis出现了超时问题后,记录一步一步的排查出异常的客户端连接和所执行命令的步骤
问题描述 Azure Redis在使用的过程中,多次无规律的出现超时问题.抓取到客户端的异常错误后,想进一步的分析是何原因导致了如下异常呢? Timeout awaiting response (ou ...
- Zookeeper命令行操作(常用命令;客户端连接;查看znode路径;创建节点;获取znode数据,查看节点内容,设置节点内容,删除节点;监听znode事件;telnet连接zookeeper)
8.1.常用命令 启动ZK服务 bin/zkServer.sh start 查看ZK服务状态 bin/zkServer.sh status 停止ZK服务 bin/zkServer.sh stop 重启 ...
- Redis的KEYS命令引起宕机事件
摘要: 使用 Redis 的开发者必看,吸取教训啊! 原文:Redis 的 KEYS 命令引起 RDS 数据库雪崩,RDS 发生两次宕机,造成几百万的资金损失 作者:陈浩翔 Fundebug经授权转载 ...
随机推荐
- 在Android中afinal框架下實現sqlite數據庫版本升級的辦法
public abstract void onUpgrade(SQLiteDatabase db,int oldVersion,int new Version) 這個方法在實現時需要重寫. pub ...
- 如何将Anaconda更新到想要的python版本
最近用Anaconda比较多,因为它里面的包很全啊.如果下个原生的python,要用的时候得自己一个个装. 但是有些包又互相依赖,一个个装的时候实在很抓狂.懒人就想到了anaconda这种套装集合了. ...
- Solr7.1---Getting Start
目前最新版的Solr是7.1.0 有个我还不清楚的地方是,为何5.5.X或者6.6.X版本还在更新,给我的感觉好像每一个大版本都有自己的维护团队.不管了. 首先-系统要求 JDK1.8+ 解压Solr ...
- 网络编程基础【day09】:实现简单地ssh(四)
本节内容 概述 简单ssh socket接收大数据的困惑 一.概述 我们用过linux的就知道什么是ssh,它是一种客户端和服务端交互返回的一个解决,输入一个命令,给我返回什么,接下来我们说一说,如何 ...
- Tomcat服务启动成功,但访问index.jsp出错 (jspInit)【转】
本文引用自 --> http://zhouhaitao.iteye.com/blog/1164736 Tomcat服务启动成功,但访问index.jsp出错 环境:Tomcat6 + jdk6 ...
- golang锁
golang锁包:https://studygolang.com/pkgdoc sync.Mutex是一个互斥锁 var lock sync.Mutex 加锁段在中 lock.lock() lock. ...
- synchronized实现原理
线程安全是并发编程中的重要关注点,应该注意到的是,造成线程安全问题的主要诱因有两点,一是存在共享数据(也称临界资源),二是存在多条线程共同操作共享数据.因此为了解决这个问题,我们可能需要这样一个方案, ...
- 同步、异步、阻塞、非阻塞与future
前言 随着移动互联网的蓬勃发展,手机App层出不穷,其业务也随之变得错综复杂.针对于开发人员来说,可能之前的一个业务只需要调取一次第三方接口以获取数据,而如今随着需求的增加,该业务需调取多个不同的第三 ...
- cdqz2017-test8-Tree(点分树)
n个点的带点权带边权的树,设点权为a[i],边权为b[i] 一棵树有n*(n-1)/2个点对, 定义这棵树的价值为任意两点对的(a[x]^a[y])*dis(x,y) 有m次修改一个点的点权的操作 输 ...
- 枚举专项练习_Uva725(Division)_Uva11059(Maximun Product)
//Uva725 #include <iostream> #include <cstring> #include <cstdlib> #include <cs ...