redis 系列19 客户端

原文:redis 系列19 客户端

一. 概述

  Redis服务器是可以与多个客户端建立网络连接,每个客户端可以向服务器发送命令请求,而服务器则接收并处理客户端发送的命令请求,并向客户端返回命令回复。通过使用I/O多路复用技术实现的文件事件处理器,Redis服务器使用单进程单线程的方式来处理命令请求,并与多个客户端进行网络通信。

  1.1 伪客户端和普通客户端

    对于每个与服务器进行连接的客户端,服务器都为这些客户端建立了相应的redis.h/redisClient结构(客户端状态),这个结构保存了客户端当前的状态信息。根据客户端类型的不同,分为伪客户端和普通客户端。伪客户端处理的命令请求来源于AOF文件或者Lua脚本,而不是网络,这种客户端不需要套接字连接。普通客户端使用套接字与服务器进行通信,下面脚本显示了全部的普通客户端:

    127.0.0.1:6379> client list
    id=2 addr=127.0.0.1:45090 fd=8 name= age=95 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=32768 obl=0 oll=0 omem=0 events=r cmd=client
    id=3 addr=127.0.0.1:45092 fd=9 name= age=3 idle=3 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=0 obl=0 oll=0 omem=0 events=r cmd=command

  上面脚本,当fd为-1时,就是一个伪客户端。普通客户端的fd都大于0。name代表客户端名称,默认为空,可以用client setname命令来设置一个客户端的名字,例如给当前客户端设置名称,以下脚本:

    127.0.0.1:6379> client setname client1
    OK
    127.0.0.1:6379> client list
    id=2 addr=127.0.0.1:45090 fd=8 name=client1 age=414 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=32768 obl=0 oll=0 omem=0    events=r cmd=client
    id=3 addr=127.0.0.1:45092 fd=9 name= age=322 idle=322 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=0 obl=0 oll=0 omem=0   events=r cmd=command

  

  1.2  flags标志

    flags记录了客户端的角色(role),以及客户端目前所处的状态,flags属性的值可以是单个标志,也可以是多个标志的二进制。客户端 flag 可以由以下部分组成:


属性值


描述


O


客户端是 MONITOR 模式下的附属节点(slave)


S


客户端是一般模式下(normal)的附属节点


M


客户端是主节点(master)


x


客户端正在执行事务


b


客户端正在等待阻塞事件


i


客户端正在等待 VM I/O 操作(已废弃


c


在将回复完整地写出之后,关闭链接


u


客户端未被阻塞(unblocked)


N


未设置任何 flag


r


客户端套接字(在事件 loop 中)是可读的(readable)


w


客户端套接字(在事件 loop 中)是可写的(writeable)

  

  1.3 输入缓冲区qbuf 与输出缓冲区 obl  

    (1)客户端状态的输入缓冲区用于保存客户端发送的命令请求,如set key value, 输入缓冲区的大小会根据输入内容动态地缩小或扩大,但它的最大空间不超过1GB,否则服务器将关闭这个客户端。

    (2)当服务端执行命令回复,会被保存在客户端状态的输出缓冲区中,每个客户端都有两个输出缓冲区可用,一个缓冲区大小是固定的,另一个缓冲区的大小是可变的。固定大小的缓冲区用于保存回复信息长度比较小的,比如OK,简短的字符串值,整数值,错误回复等。可变大小的缓冲区用于保存长度比较大的,比如一个非常长的字符串值,或一个由很多项组成的列表,或一个包含了很多元素的集合等。 固定大小的缓冲区默认为16kb。可变大小缓冲区不能超过服务器设置的硬性限制值,本篇最后client-output-buffer-limit时有讲。 omem表示输出缓存的内存占用量。

  

  1.4 身份验证

    客户端状态的authenticated属性用于记录客户端是否通过了身份验证,当redisClinet结构下的authenticated属性为值0时,代表客户端未通过身份验证,安装redis服务后,默认是没有密码,也就是不需要身份验证,通过设置config set requirepass  xxx 来设置密码。通过auth  xx来验证密码是否正确。下面脚本是设置密码和验证密码是否正确:

    127.0.0.1:6379> config set requirepass 123456
    OK
    127.0.0.1:6379> auth 123456
    OK

    当没有通过验证时,使用ping命令显示信息如下, 退出客户端,重启登录使用-a 参数输入密码,再次使用ping命令,验证成功,如下脚本:

    127.0.0.1:6379> ping
    (error) NOAUTH Authentication required.
    [[email protected] ~]# redis-cli -a 123456
    127.0.0.1:6379> ping
    PONG

  1.5 时间

    客户端还有几个和时间有关的属性,一是age属性,它记录了创建客户端的时间,这个时间可以用来计算客户端与服务器已经连接了多少秒。二是idle空转时间,即客户端与服务器最后一次进行互动以来,已经过去了多少秒。

  1.6 客户端的创建与关闭

    如果客户端是通过网络连接与服务器进行连接的普通客户端,那么在客户端使用connect函数连接到服务器时,服务器就会调用连接事件处理器(上篇简单讲到的文件事件处理器),为客户端创建相应的客户端状态,并将这个新状态添加到服务器状态结构reddisServer结构的clients数组链表的末尾。对于关闭普通客户端,人为可以使用clinet kill命令,来关闭,如下脚本所示:

    127.0.0.1:6379> client list
    id=4 addr=127.0.0.1:45094 fd=8 name= age=6141 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=32768 obl=0 oll=0 omem=0 events=r cmd=client
    id=6 addr=127.0.0.1:45098 fd=9 name= age=5966 idle=22 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=0 obl=0 oll=0 omem=0 events=r cmd=client
    127.0.0.1:6379> client kill id 6
    (integer) 1
    127.0.0.1:6379> client list
    id=4 addr=127.0.0.1:45094 fd=8 name= age=6179 idle=0 flags=N db=0 sub=0 psub=0 multi=-1 qbuf=0 qbuf-free=32768 obl=0 oll=0 omem=0 events=r cmd=client 

    如果用户为服务器设置了timeout选项,那么当客户端的空转时间(idle)超过timeout选项设置的值时,客户端将关闭。如果输入缓冲区占用空间超过1GB时,客户端将关闭。

    对于输出缓冲区的大小,达到限制时,客户端也将关闭。为了避免客户端的回复过大,占用过多的服务器资源,服务器会时刻检查客户端的输出缓冲区的大小,并在缓冲区的大小超出范围时,执行相应的限制操作。服务器使用两种模式来限制客户端输出缓冲区的大小:

    (1) 硬性限制(hard limit):如果输出缓冲区的大小超过了硬性限制所设置的大小,那么服务器立即关闭客户端。

    (2) 软性限制(soft limit): 如果输出缓冲区的大小超出了软性限制所设置的大小,并且占用的时长大于> 设置的总时长,那么服务器将关闭客户端。

    使用client-output-buffer-limit选项可以为普通客户端,从服务器客户端,执行发布订阅功能的客户端分别设置不同的软性限制和硬性限制,默认设置如下:

1) "client-output-buffer-limit"
2) "normal 0 0 0 slave 268435456 67108864 60 pubsub 33554432 8388608 60"

    normal是普通客户端:软性限制和硬性限制都没有限制。

    slave是从服务器客户端:硬性限制是268435456, 软性限制是67108864 并且时长为60秒。

    pubsub是发布订阅功能的客户端: 硬性限制是33554432, 软性限制是8388608并且时长为60秒。

  1.7  伪客户端的创建与关闭

    对于Lua脚本的伪客户端,在服务器初始化时创建,这个伪客户端在服务器运行的整个生命期中会一直存在,只有服务器关闭时,这个客户端才会被关闭。

    对于AOF文件的伪客户端,服务器在载入AOF文件时,会创建伪客户端,并在载入完成之后,关闭这个伪客户端。

原文地址:https://www.cnblogs.com/lonelyxmas/p/10230771.html

时间: 2024-11-08 17:28:35

redis 系列19 客户端的相关文章

Redis系列(1)之安装

Redis系列(1)之安装 由于项目的需要,最近需要研究下Redis.Redis是个很轻量级的NoSql内存数据库,它有多轻量级的呢,用C写的,源码只有3万行,空的数据库只占1M内存.它的功能很丰富,可以将其用作缓存,队列系统等.我们的项目就是用其作为缓存系统.关于Redis的介绍这里就不多说,刚上手完了一会,感觉还不错.那么熟悉Redis就从安装开始. 1. Redis 单机的安装 相比于Hbase的安装,Redis的安装非常简单. 首先从官网上下载安装包,注意Redis的版本规则是次版本(即

Redis系列-配置文件小结

如果不指定配置文件,Redis也可以启动,此时,redis使用默认的内置配置.不过在正式环境,常常通过配置文件[通常叫redis.conf]来配置redis. redis.conf配置格式如下: [plain] view plain copy keyword argument1 argument2 ... argumentN redis.conf配置参数: 1)daemonize on|yes redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes时,启用守护进程 2)pidf

redis 系列25 哨兵Sentinel (高可用演示 下)

一. Sentinel 高可用环境准备 1.1 Sentinel 集群环境 环境 说明 操作系统版本 CentOS  7.4.1708  IP地址 172.168.18.200 网关Gateway 172.168.18.1 DNS 172.168.16.11 三个sentinel服务端口 26379,26380,26381 Sentinel密码 无 不设置 是否RDB持久化 不支持 是否 AOF持久化 不支持 1.2 Redis主库库环境,主从库搭建在(redis 系列22 复制Replicat

Redis系列(2)之数据类型

Redis系列(2)之数据类型 <Redis系列(1)之安装>中介绍了Redis支持以下几种数据类型,那么本节主要介绍学习下这几种数据类型的基本操作 字符串类型,string 散列类型,hash 列表类型,list 集合类型,set 有序集合类型,zset 1. 字符串类型 赋值与取值 SET 与 GET. 当键不存在时候返回为空. 1 127.0.0.1:6379> set key hello 2 OK 3 127.0.0.1:6379> get key 4 "hell

Redis系列(一)--安装、helloworld以及读懂配置文件

再开个redis系列,本系列打算不详细讲一系列的命名的了(会推荐别人写的,人家写的够详细了),我直接就是做redis方案提供,当然一开始还是讲下helloworld和配置文件好了.会逐步更新,欢迎关注. 文章结构:(1)安装:(2)helloworld:(3)解析配置文件(一一罗列方便复习):(4)重点配置 一.安装:把到官网下载好的redis压缩包放置到你想要的位置.并解压. 然后进入redis-3.0.4目录,执行make命令 jackfrost@jackfrost-pc:~/MyResou

C#中使用Redis学习一 windows安装redis服务器端和客户端

学习背景 今天是2015年1月2日,新年刚开始的第二天,先祝大家元旦快乐啦(迟到的祝福吧^_^).前段时间一直写Jquery插件开发系列博文,这个系列文章暂停一段时间,最近一直在看redis,我将把redis作为一个系列写一下我的学习历程.正好现在项目中使用了redis,本着学习探索的精神,准备写一下我对redis的一个学习历程和自己的一点感悟.在学习过程中也走了很多弯路,希望能对看这篇博文的朋友们带来点帮助.也算是写这边博文的最大目的了. 我在认识redis之前没有接触过任何NoSql思想.对

Redis 系列 - 1 【简要介绍】 - 它是什么?它用来做什么?它的优势与短板如何?

1.0 前提 阅读目的: 对什么是内存型数据库有概念性的认知.? 阅读需知:有关Redis系列的博文,大致有以下的5篇博文.本ID将陆续补充. 本ID  Redis系列 1 . 0 :首先,这是您在Redis的官方网站: http://www.redis.cn/ 1.1      您需要成功的下载,安装,并且配置好Redis. 有关过程请参考本ID的另外的一篇博文: Redis 系列 - 2 [安装与配置] 1.2     如果您需要了解Redis的设计与实现,请参考本ID博文: Redis 系

redis系列:redis介绍与安装

前言 这个redis系列的文章将会记录博主学习redis的过程.基本上现在的互联网公司都会用到redis,所以学习这门技术于你于我都是有帮助的. 博主在写这个系列是用的是目前最新版本4.0.10,虚拟机装的是4.0.10,为了方便window也安装了(版本3.2.100).后续命令会采用命令行,jedis和spring集成jedis这三种方式进行操作. 在这片博文的开始,可以先试着问几个问题,带着问题看博文,或许能更有收获. 什么是redis? 为什么要使用redis? 如何搭建redis环境?

Redis系列--内存淘汰机制(含单机版内存优化建议)

https://blog.csdn.net/Jack__Frost/article/details/72478400?locationNum=13&fps=1 每台redis的服务器的内存都是有限的,而且也不是所有的内存都用来存储信息.而且redis的实现并没有在内存这块做太多的优化,所以实现者为了防止内存过于饱和,采取了一些措施来管控内存. 文章结构:(1)内存策略:(2)内存释放机制原理:(3)项目中如何合理应用淘汰策略:(4)单机版Redis内存优化注意点. 一.内存策略:先来吃份官方文档