Redis客户端相关
1.redis是什么
redis是一个开源的、使用C语言编写的、支持网络交互的、可基于内存也可持久化的Key-Value数据库。redis的官网地址,非常好记,是redis.io。目前,Vmware在资助着redis项目的开发和维护。
Redis会将所有数据都存放在内存中,所以它的读写性能拾惊人的。
Redis特性:
1)速度快
2)基于键值对的数据结构服务器
3)丰富的功能:提供了键过期功能,可用用来实现缓存。提供了发布订阅功能,用来实现消息系统。支持Lua脚本功能,可以利用Lua创造出新的Redis命令。提供了简单的事务功能,能在一定程度上保证事务特性。提供了流水线(Pipeline)功能,客户端能将一批命令一次性传到Redis,减少网络开销。
4)简单稳定
5)客户端语言多
6)持久化
7)主从复制
8)高可用和分布式
Redis可以做什么:
1)缓存
2)排行榜系统
3)计数器应用
4)社交网络
5)消息队列系统
用好Redis的建议:
1)切勿当做黑盒使用,开发与运维同样重要
2)阅读源码
2.安装redis
从redis.io下载最新版redis-X.Y.Z.tar.gz后解压,然后进入redis-X.Y.Z文件夹后直接make&& make install即可,安装非常简单。make成功后会在src文件夹下产生一些二进制可执行文件,包括redis-server、redis-cli等等:
[root@mysql1 software]# tar xvfz redis-3.2.3.tar.gz
[root@mysql1 software]# cd redis-3.2.3
[root@mysql1 src]# find . -type f -executable
安装Redis:
$ wget http://download.redis.io/releases/redis-3.0.7.tar.gz
$ tar xzf redis-3.0.7.tar.gz
$ ln -s redis-3.0.7 redis
$ cd redis
$ make
$ make install
./redis-trib.rb //用于创建集群,检测及重新分片
./redis-check-rdb //用于修复出问题的rdb文件
./redis-benchmark //用于进行redis性能测试的工具
./redis-server //redis的服务端
./redis-cli //redis的客户端
./mkreleasehdr.sh
./redis-check-aof //用于修复出问题的AOF文件
./redis-sentinel //用于集群管理
请参考一键安装redis脚本,InstallRedis.sh
3.启动redis
启动redis非常简单,直接./redis-server就可以启动服务端了,还可以用下面的方法指定要加载的配置文件:./redis-server ../redis.conf。默认情况下,redis-server会以非daemon的方式来运行,且默认服务端口为6379。
有三种方法启动Redis:
默认配置、运行配置、配置文件启动
默认端口是6379
Redis命令行客户端:
交互式、命令方式
停止Redis服务:
$ redis-cli shutdown
4.使用redis客户端
[root@mysql1 src]# ./redis-cli //启动redis客户端
127.0.0.1:6379> set name "abc" //用set指定来设置key,value
OK
127.0.0.1:6379> get name //来获取name的值
"abc"
127.0.0.1:6379> del name //删除一个键值
(integer) 1
127.0.0.1:6379> ping //用于检测 redis 服务是否启动
PONG
127.0.0.1:6379> shutdown //通过客户端来关闭redis服务端
not connected>
修改redis配置文件,找到
#requirepass foobared
去掉注释,并修改为所需要的密码
requirepass mypass
重启redis服务
在远程服务器上执行命令
$redis-cli -h 127.0.0.1 -p 6379 -a "mypass"
redis 127.0.0.1:6379>
redis 127.0.0.1:6379> PING
redis 127.0.0.1:6379> select index //切换到指定的数据库
redis-cli -r 5 -i 1 ping
redis-cli -r 10 -i 1 info | grep used_memory_human
echo "world" | redis-cli -x set hello -x选项代表从标准输入读取数据作为redis-cli的最后一个参数
redis-cli --latency 可以测试客户端到目标Redis的网络延迟
redis-cli --bigkeys 使用scan命令对Redis的键进行采样,从中找到内存占用比较大的键值,这些键值可能是系统的瓶颈
[p2p@pbp2pap11 ~]$ redis-cli -h 127.0.0.1 -a "redis4p2p" keys "H5_USERIDTOKENMAPPING-*" | xargs redis-cli -h 127.0.0.1 -a "redis4p2p" del
(integer) 433
[p2p@pbp2pap11 ~]$ redis-cli -h 127.0.0.1 -a "redis4p2p" keys "H5_TOKEN-*" | xargs redis-cli -h 127.0.0.1 -a "redis4p2p" del
(integer) 3119
(integer) 3119
(integer) 3119
(integer) 663
Pipeline:将一组Redis命令进行组装,通过一次RTT传输给Redis,再将这组Redis命令的执行结果按顺序返回给客户端
客户端通信协议:TCP,RESP
客户端管理:
对比client list和info clients监控输入缓冲区的优劣势
client list 能精确分析每个客户端来定位问题
info clients 执行速度快,分析过程较为简单
客户端常见异常
客户端案例分析:
Redis内存陂增:注意监控monitor命令的执行
客户端周期性超时:注意监控慢查询
Redis客户端相关的更多相关文章
- Redis客户端管理
1.客户端管理 Redis提供了客户端相关API对其状态进行监控和管理,本节将深入介绍各个API的使用方法以及在开发运维中可能遇到的问题. 1.1 客户端API 1.client list clien ...
- StackExchange.Redis客户端读写主从配置,以及哨兵配置。
今天简单分享一下StackExchange.Redis客户端中配置主从分离以及哨兵的配置. 关于哨兵如果有不了解的朋友,可以看我之前的一篇分享,当然主从复制文章也可以找到.http://www.cnb ...
- 使用StackExchange.Redis客户端进行Redis访问出现的Timeout异常排查
问题产生 这两天业务系统在redis的使用过程中,当并行客户端数量达到200+之后,产生了大量timeout异常,典型的异常信息如下: Timeout performing HVALS Parser2 ...
- Redis客户端之Spring整合Jedis,ShardedJedisPool集群配置
Jedis设计 Jedis作为推荐的java语言redis客户端,其抽象封装为三部分: 对象池设计:Pool,JedisPool,GenericObjectPool,BasePoolableObjec ...
- "Redis客户端连接数一直降不下来"的有关问题解决
[线上问题] "Redis客户端连接数一直降不下来"的问题解决 前段时间,上线了新的 Redis缓存(Cache)服务,准备替换掉 Memcached. 为什么要将 Memcach ...
- redis客户端可以连接集群,但JedisCluster连接redis集群一直报Could not get a resource from the pool
一,问题描述: (如题目)通过jedis连接redis单机成功,使用JedisCluster连接redis集群一直报Could not get a resource from the pool 但是使 ...
- 如何编写入门级redis客户端
概述 Redis是开源的.基于内存的数据结构存储系统,可用作数据库.缓存以及消息代理方面.Redis支持许多种数据结构,并内置了丰富的诸如冗余.脚本.事务.持久化等功能,深受业界喜爱,被各种业务系统广 ...
- Netty开发redis客户端,Netty发送redis命令,netty解析redis消息
关键字:Netty开发redis客户端,Netty发送redis命令,netty解析redis消息, netty redis ,redis RESP协议.redis客户端,netty redis协议 ...
- 4.Redis客户端
4.Redis客户端4.1 客户端通信协议4.2 Java客户端Jedis4.2.1 获取Jedis4.2.2 Jedis的基本使用方法4.2.3 Jedis连接池的使用方法4.2.4 Redis中P ...
随机推荐
- 一 、Linux基础命令及使用帮助
linux的哲学思想: 一切皆文件: 把几乎所有资源,包括硬件设备都组织为文件系统 由众多单一目的小程序组成:一个程序只实现一个功能,而且要做好 组合小程序完成复杂任务 尽量避免跟用户交互 目的:实现 ...
- win10系统配置FTP
FTP是一种远程传输协议,支持这种协议的就是FTP服务器.我们可以在自己的PC机上创建一个.然后通过网页就可以访问FTP服务器下的文件夹. 搭建过程 1.首先需要开启FTP服务.在菜单中打开控制面板. ...
- nginx 错误集锦
1)下载地址 http://nginx.org/en/download.html 找windows的下载. 2)然后解压到自己的一个目录. 3)配置环境变量,将解压到的路径加进去. 4)修改配置文件 ...
- 可插拔式后台管理系统(Django)
1.实现效果 研究了下django admin的功能,自己实现了一个简单的可插拔式后台管理系统,方便自定义特殊的功能,而且作为一个独立单独的django app,可以整体拷贝到其他项目中作为后台数据管 ...
- 性能监控系统 | 从0到1 搭建Web性能监控系统
工具介绍 1. Statsd 是一个使用Node开发网络守护进程,它的特点是通过UDP(性能好,及时挂了也不影响主服务)或者TCP来监听各种数据信息,然后发送聚合数据到后端服务进行处理.常见支持的「G ...
- 009-centos6.6 用户以及组操作
1.查看用户所属组 id admin uid=500(admin) gid=500(admin) 组=500(admin) 2.查看用户信息 用户列表文件:cat /etc/passwd 查看系统中有 ...
- Vue.js父子组件如何传值 通俗易懂
父子组件传值原理图 一般页面的视图App.vue应为这样 一.父组件向子组件传值 1.创建子组件,在src/components/文件夹下新建一个Child.vue 2.Child.vue的中创建pr ...
- 在HbuilderX的Uni-app中引入crypto-js md5
在 hbuilderX的菜单“视图”中选择“显示终端”,在终端中把当前目录定位到uni-app的根目录,这样才可以把crypto-js库安装在正确的位置,在终端中键入:npm install cryp ...
- 来聊聊JavaScript中的防抖和节流
目录 JavaScript防抖和节流 问题还原 防抖 什么是防抖 使用场景 节流 什么是节流 使用场景 JavaScript防抖和节流 问题还原 我们先来通过代码把常见的问题还原: <html& ...
- VMware workstation安装Windows Server 2012 R2步骤详解(附下载链接)
话不多说,直接上链接.所需工具: 1.VMware workstation 14.0(版本无所谓) 附链接:https://pan.baidu.com/s/1CrH ...