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命令,数据备份,缓存有效期等)的更多相关文章

  1. Redis客户端连接以及持久化数据(三)

    0.Redis目录结构 1)Redis介绍及部署在CentOS7上(一) 2)Redis指令与数据结构(二) 3)Redis客户端连接以及持久化数据(三) 4)Redis高可用之主从复制实践(四) 5 ...

  2. Redis 千万不要乱用KEYS命令,不然会挨打的

    Redis现如今使用的场景越来越多?如何批量删除key呢? 有人说用KEYS命令,刚开始学Redis的时候就是用这个命令列出库中键. KEYS命令要谨慎使用. 为何?客观别急,我们先一步步来看. KE ...

  3. Mysql数据库常用的命令 数据备份 恢复 远程

    远程数据库 格式: mysql -h主机地址 -u用户名 -p用户密码数据库 mysql -h 42.51.150.68 -u yang -p discuz mysql设置密码 mysql>us ...

  4. Redis 的 KEYS 命令不能乱用啊

    KESY 命令 时间复杂度: O(N) , 假设Redis中的键名和给定的模式的长度有限的情况下,N为数据库中key的个数. Redis Keys 命令用于查找所有符合给定模式 pattern 的 k ...

  5. redis基础操作~~数据备份与恢复、数据安全、性能测试、客户端连接、分区

    数据备份与恢复 数据备份redis save 命令用于创建当前数据库的备份. redis 127.0.0.1:6379> SAVE OK 该命令将在 redis 安装目录中创建dump.rdb文 ...

  6. Redis 数据备份与恢复,安全,性能测试,客户端连接,管道技术,分区(四)

    Redis 数据备份与恢复 Redis SAVE 命令用于创建当前数据库的备份. 语法 redis Save 命令基本语法如下: redis 127.0.0.1:6379> SAVE 实例 re ...

  7. 【Azure Redis 缓存】Azure Redis出现了超时问题后,记录一步一步的排查出异常的客户端连接和所执行命令的步骤

    问题描述 Azure Redis在使用的过程中,多次无规律的出现超时问题.抓取到客户端的异常错误后,想进一步的分析是何原因导致了如下异常呢? Timeout awaiting response (ou ...

  8. Zookeeper命令行操作(常用命令;客户端连接;查看znode路径;创建节点;获取znode数据,查看节点内容,设置节点内容,删除节点;监听znode事件;telnet连接zookeeper)

    8.1.常用命令 启动ZK服务 bin/zkServer.sh start 查看ZK服务状态 bin/zkServer.sh status 停止ZK服务 bin/zkServer.sh stop 重启 ...

  9. Redis的KEYS命令引起宕机事件

    摘要: 使用 Redis 的开发者必看,吸取教训啊! 原文:Redis 的 KEYS 命令引起 RDS 数据库雪崩,RDS 发生两次宕机,造成几百万的资金损失 作者:陈浩翔 Fundebug经授权转载 ...

随机推荐

  1. jar的打包与共享

    做成jar包的,有个弊处,打包apk时会暴露源码,当然也有解决方案,放在最后讲. 先来解释如何生成jar: 新建工程,将工程编译至无错,右键工程Export... 在弹出的提示框中选择Java文件夹下 ...

  2. 洛谷P4112 最短不公共子串

    题意: 下面,给两个小写字母串A,B,请你计算: (1) A的一个最短的子串,它不是B的子串 (2) A的一个最短的子串,它不是B的子序列 (3) A的一个最短的子序列,它不是B的子串 (4) A的一 ...

  3. 【codevs1048】石子归并(初级版)

    采用动态规划的原因:合并有一定次序,即:只能相邻石子进行合并. 阶段:当前合并了的区间长度 状态:区间的左右端点 状态转移方程:\(dp[l][r]=min\{dp[l][r],dp[l][k]+dp ...

  4. php 防止sql注入的简单方法

    您可以使用PHP的功能,如函数stripslashes()和addslashes(),mysql_real_escape_string()等,使安全的SQL查询. 以下是安全的SQL语句,使用PHP ...

  5. php 字符串截取函数

    php自带的一个截取字符串的函数,只能处理英文,数字的不能截取中文混排的哦,有需要的朋友可以参考,后面的比较好用,第一个主要是给初学者学学用的. php //构造字符串 $str = "AB ...

  6. SQL Server 窗口函数详解:OVER()

    语法 开窗函数支持分区.排序和框架三种元素,其语法格式如下: OVER ( [ <PARTITION BY clause> ] [ <ORDER BY clause> ] [ ...

  7. Simple Question

    一.你会在时间序列数据集上使用什么交叉验证技术?是用k倍? 答:都不是.对于时间序列问题,k倍可能会很麻烦,因为第4年或第5年的一些模式有可能跟第3年的不同,而我们最终可能只是需要对过去几年的进行验证 ...

  8. php7连接 sqlserver踩过的坑,could not find driver解决方式

    最近把环境升级为php7发现在连接sqlser的时候无法使用驱动了 页面错误 后来查看文档发现:php7应该采用Server=xxxx;DataBase=xxxxx 解决方式: DB_DSN_TWO ...

  9. 整理备忘一波liunx命令(持续更新)

    # 分区挂载 查看当前目录下的文件大小 du --max-depth= -h # 文件操作 # 编辑操作 #liunx 字体设置 苹果方字体下载安装 # 网洛端口 netstat命令各个参数说明如下: ...

  10. 一张非常强大的OSI七层模型图解。。。

    源自http://www.colasoft.com.cn/download/protocols_map.php,非常适合小白入门,后面罗列出来方便大家浏览记忆...(不经意间看到的,分享一下) OSI ...