[Redis] Configuración de instalación y tipo de datos

Configuración y tipo de datos de la instalación de Redis



Redis, un lenguaje ANSI C de uso de código abierto, soporte de red, la memoria también puede basarse en el tipo de registro persistente, la base de datos de valor clave y proporciona una API multilingüe;

Redis es como un HashMap, pero no se ejecuta en la JVM, sino que se ejecuta como un proceso separado.

La velocidad de acceso a los datos es más rápida que la de la base de datos (Mysql) y generalmente se usa como caché, por lo que los datos de uso común se pueden considerar aquí para mejorar el rendimiento .

Instalación de Redis

Instalación de ventana

dirección de instalación de la ventana

El Redis descargado admite 32 bits y 64 bits. Elija según su situación real, agregue el contenido de 64 bits cp al directorio de instalación de la letra de unidad personalizada y asígnele el nombre redis. Como G: \ redis.
1. Abra redis-server.exe en el directorio raíz en ejecución , mantenga abierta la ventana en ejecución, no la cierre.

Si quiere ser conveniente, puede agregar la ruta de redis a las variables de entorno del sistema, para que no tenga que perder la ruta.

Inserte la descripción de la imagen aquí
2. Abra redis-cli.exe en el directorio o ejecute el comando: redis-cli.exe -h 127.0.0.1 -p 6379
Inserte la descripción de la imagen aquí

Configuración de Redis

El archivo de configuración de Redis se encuentra en el directorio de instalación de Redis y el nombre del archivo es redis.conf

Ver y establecer elementos de configuración a través del comando CONFIG

1. Ver la configuración

Formato de comando:

redis 127.0.0.1:6379> CONFIG GET CONFIG_SETTING_NAME

Ejemplo:

redis 127.0.0.1:6379> CONFIG GET loglevel

1) "loglevel"
2) "notice"

Utilice el símbolo * para obtener todos los elementos de configuración

2. Modificar la configuración

Formato de comando:

redis 127.0.0.1:6379> CONFIG SET CONFIG_SETTING_NAME NEW_CONFIG_VALUE

Ejemplo:

redis 127.0.0.1:6379> CONFIG SET loglevel "notice"
OK
redis 127.0.0.1:6379> CONFIG GET loglevel

1) "loglevel"
2) "notice"

3. Descripción de los parámetros del elemento de configuración

  1. daemonize: Redis no se ejecuta como un demonio de forma predeterminada. Puede cambiar este elemento de configuración a sí para habilitar el demonio.

    Cuando redis se ejecuta como un demonio, redis escribirá el pid en el archivo /var/run/redis.pid por defecto, que puede ser especificado por pidfile:

    pidfile /var/run/redis.pid
    
  2. puerto: especifique el puerto de escucha de reids, el puerto predeterminado es 6379.

  3. enlazar: enlazar la dirección del host, por defecto 127.0.0.1

  4. timeout: cuánto tiempo el cliente está inactivo para cerrar la conexión, si es 0, significa cerrar la función

  5. loglevel: nivel de registro.

    Redis admite un total de cuatro niveles: depuración, detallado, aviso, advertencia, el predeterminado es detallado

  6. bases de datos: establezca el número de bases de datos, el valor predeterminado es 0, puede usar el comando SELECT <dbid> para especificar la identificación de la base de datos en la conexión

  7. save <seconds> <changes>: Indica cuánto tiempo (en s) hay varias operaciones de actualización para sincronizar los datos con el archivo de datos.

    Se proporcionan tres condiciones en el archivo de configuración predeterminado en redis:

    • guardar 900 1
    • ahorra 300 10
    • guardar 60 10000
  8. rdbcompression: especifique si desea comprimir los datos al almacenarlos en la base de datos local. El valor predeterminado es yes.

    Redis usa compresión LZF. Si desea ahorrar tiempo de CPU, puede desactivar esta opción, pero hará que el tamaño del archivo de la base de datos sea muy grande.

  9. dbfilename: especifique el nombre del archivo de la base de datos local, el valor predeterminado es dump.rdb

  10. dir: especifique el directorio de almacenamiento de la base de datos local

  11. esclavo de <masterip> <masterport> :

    Configure cuando la máquina es el servicio esclavo, configure la dirección IP y el puerto del servicio maestro, cuando se inicie redis, sincronizará automáticamente los datos del maestro

  12. masterauth <master-password>: cuando el servicio maestro está configurado en protección con contraseña, la contraseña para que el servicio esclavo se conecte al maestro.

  13. requirepass foobared:

    Establezca la contraseña de conexión de redis. Si se establece la contraseña de conexión, el cliente debe proporcionar la contraseña a través del comando AUTH <contraseña> al conectarse a redis. El valor predeterminado es no

  14. maxclients 128 :

    Establezca el número máximo de conexiones de clientes al mismo tiempo. De forma predeterminada, no hay límite.

    El número de conexiones de cliente que Redis puede abrir al mismo tiempo es el número máximo de descriptores de archivo que puede abrir el proceso de Redis. Si maxclients 0 se establece, significa que no hay límite .

    Cuando el número de conexiones de clientes alcance el límite, Redis cerrará la nueva conexión y devolverá un mensaje de error de número máximo de clientes alcanzados al cliente.

  15. maxmemory <bytes>: especifica el límite máximo de memoria de Redis

    Redis cargará los datos en la memoria cuando se inicie. Una vez que se alcanza la memoria máxima, Redis primero intentará borrar las claves caducadas o a punto de caducar. Después de que se procese este método, la configuración de memoria máxima aún se alcanza, y no más Se pueden realizar escrituras Operación, pero la operación de lectura aún se puede realizar.

    El nuevo mecanismo vm de Redis almacenará la clave en la memoria y el valor se almacenará en el área de intercambio.

  16. appendonly no: especifique si desea iniciar sesión después de cada operación de actualización, el valor predeterminado es no

    Redis escribe datos en el disco de forma asincrónica de forma predeterminada. Si no está encendido, puede causar la pérdida de datos durante un período de tiempo cuando la energía está apagada.

    Debido a que el propio redis sincroniza los archivos de datos de acuerdo con las condiciones de guardado anteriores, algunos datos solo existirán en la memoria durante un período de tiempo.

  17. appendfilename appendonly.aof: especifique el nombre del archivo de registro de actualización, el valor predeterminado es appendonly.aof

  18. appendfsync everysec: especifique las condiciones del registro de actualización.

    Hay tres valores opcionales:

    • no: significa esperar a que el sistema operativo sincronice la caché de datos con el disco (rápido)
    • siempre: indica que se llama manualmente a fsync () para escribir datos en el disco después de cada operación de actualización (lenta, segura)
    • everysec: significa sincronizar una vez por segundo (compromiso, predeterminado)
  19. vm-enabled no: especifique si desea habilitar el mecanismo de memoria virtual, el valor predeterminado es no

    El mecanismo de VM almacena los datos en páginas, y Redis intercambia las páginas a las que se accede menos, es decir, los datos fríos, al disco, y las páginas a las que se accede más se intercambian automáticamente del disco a la memoria.

  20. vm-swap-file /tmp/redis.swap: ruta del archivo de memoria virtual, el valor predeterminado es /tmp/redis.swap, no se pueden compartir varias instancias de redis.

  21. vm-max-memory 0: almacena todos los datos más grandes que vm-max-memory en la memoria virtual, el valor predeterminado es 0.

    Todos los datos del índice de Redis (claves) se almacenan en la memoria, independientemente del valor de vm-max-memory.

    Cuando vm-max-memory se establece en 0, todos los valores existen realmente en el disco.

  22. vm-page-size 32: especifique el tamaño de página en el archivo de intercambio, el valor predeterminado es 32 bytes.

    Los archivos de intercambio de Redis se dividen en varias páginas. Un objeto puede almacenarse en varias páginas, pero una página no puede ser compartida por varios objetos.

    vm-page-size debe establecerse de acuerdo con el tamaño de los datos almacenados. Si almacena muchos objetos pequeños, el tamaño de la página se establece mejor en 32 o 64 bytes; si almacena objetos grandes, puede usar una página más grande, si no seguro, solo usa el valor predeterminado

  23. vm-pages 134217728: especifique el número de páginas en el archivo de intercambio. El tamaño predeterminado es 2 27 o 134217728.

  24. vm-max-threads 4: establece el número de subprocesos que acceden al archivo de intercambio, el valor predeterminado es 4.

    Es mejor no exceder el número de núcleos de la máquina, si se establece en 0, entonces todas las operaciones en el archivo de intercambio son en serie, lo que puede causar un retraso relativamente largo.

  25. glueoutputbuf yes: establezca si desea combinar paquetes más pequeños en un paquete y enviarlo cuando desee que el cliente responda. El valor predeterminado está activado.

  26. hash-max-zipmap-entries 64: especifica el uso de un algoritmo hash especial cuando se excede un cierto número

  27. hash-max-zipmap-value 512: especifica que se usa un algoritmo hash especial cuando el elemento más grande excede un cierto valor crítico

  28. activerehashing yes: especifique si desea activar el hash de restablecimiento, el valor predeterminado es yes

  29. include /path/to/local.conf: especifique para incluir otros archivos de configuración. Puede usar el mismo archivo de configuración entre varias instancias de redis en el mismo host, y cada instancia también tiene su propio archivo de configuración específico.

Tipos de datos de Redis

Hay 5 tipos de datos en Redis:

  • Cuerda
  • Lista
  • Diccionario hash
  • Colocar
  • Conjunto ordenado

Los diferentes tipos de datos tienen diferentes métodos de comando.

Comandos relacionados con cadenas

set (key) (value)			设置key = value
append (key) (value2)		在key对应的value尾部追加value2
get	(key)					获取key对应的value
incr (key)				将key对应的value加1
incrby (key) (value1)		将key对应的value加上value1
ttl (key)					获取key到期的剩余时间
rename (key) (key_new)		对key重命名

SET key value                   设置key=value
GET key                         或者键key对应的值
GETRANGE key start end          得到字符串的子字符串存放在一个键
GETSET key value                设置键的字符串值,并返回旧值
GETBIT key offset               返回存储在键位值的字符串值的偏移
MGET key1 [key2..]              得到所有的给定键的值
SETBIT key offset value         设置或清除该位在存储在键的字符串值偏移
SETEX key seconds value         键到期时设置值
SETNX key value                 设置键的值,只有当该键不存在
SETRANGE key offset value       覆盖字符串的一部分从指定键的偏移
STRLEN key                      得到存储在键的值的长度
MSET key value [key value...]   设置多个键和多个值
MSETNX key value [key value...] 设置多个键多个值,只有在当没有按键的存在时
PSETEX key milliseconds value   设置键的毫秒值和到期时间
INCR key                        增加键的整数值一次
INCRBY key increment            由给定的数量递增键的整数值
INCRBYFLOAT key increment       由给定的数量递增键的浮点值
DECR key                        递减键一次的整数值
DECRBY key decrement            由给定数目递减键的整数值
APPEND key value                追加值到一个键
DEL key                         如果存在删除键
DUMP key                        返回存储在指定键的值的序列化版本
EXISTS key                      此命令检查该键是否存在
EXPIRE key seconds              指定键的过期时间
EXPIREAT key timestamp          指定的键过期时间。在这里,时间是在Unix时间戳格式
PEXPIRE key milliseconds        设置键以毫秒为单位到期
PEXPIREAT key milliseconds-timestamp        设置键在Unix时间戳指定为毫秒到期
KEYS pattern                    查找与指定模式匹配的所有键
MOVE key db                     移动键到另一个数据库
PERSIST key                     移除过期的键
PTTL key                        以毫秒为单位获取剩余时间的到期键。
TTL key                         获取键到期的剩余时间。
RANDOMKEY                       从Redis返回随机键
RENAME key newkey               更改键的名称
RENAMENX key newkey             重命名键,如果新的键不存在
TYPE key                        返回存储在键的数据类型的值。

Lista

lpush (listkey) (value)			给listkey列表添加(一个或多个)元素(在前面添加)
rpush (listkey) (value)			给listkey列表添加(一个或多个)元素(在后面添加)
llen (listkey)					获取listkey的长度
lrange (listkey) (start) (end)	从start位置至end位置获取其中的元素

BLPOP key1 [key2 ] timeout 取出并获取列表中的第一个元素,或阻塞,直到有可用
BRPOP key1 [key2 ] timeout 取出并获取列表中的最后一个元素,或阻塞,直到有可用
BRPOPLPUSH source destination timeout 从列表中弹出一个值,它推到另一个列表并返回它;或阻塞,直到有可用
LINDEX key index 从一个列表其索引获取对应的元素
LINSERT key BEFORE|AFTER pivot value 在列表中的其他元素之后或之前插入一个元素
LLEN key 获取列表的长度
LPOP key 获取并取出列表中的第一个元素
LPUSH key value1 [value2] 在前面加上一个或多个值的列表
LPUSHX key value 在前面加上一个值列表,仅当列表中存在
LRANGE key start stop 从一个列表获取各种元素
LREM key count value 从列表中删除元素
LSET key index value 在列表中的索引设置一个元素的值
LTRIM key start stop 修剪列表到指定的范围内
RPOP key 取出并获取列表中的最后一个元素
RPOPLPUSH source destination 删除最后一个元素的列表,将其附加到另一个列表并返回它
RPUSH key value1 [value2] 添加一个或多个值到列表
RPUSHX key value 添加一个值列表,仅当列表中存在

Diccionario hash, tabla hash

hset person (key) (value)		设置person哈希表中的key键对应值为value
hgetall person					显示person哈希表中所有的key和value
hkeys person					显示person哈希表中所有的keys
hvals person					


HDEL key field[field...] 删除对象的一个或几个属性域,不存在的属性将被忽略
HEXISTS key field 查看对象是否存在该属性域
HGET key field 获取对象中该field属性域的值
HGETALL key 获取对象的所有属性域和值
HINCRBY key field value 将该对象中指定域的值增加给定的value,原子自增操作,只能是integer的属性值可以使用
HINCRBYFLOAT key field increment 将该对象中指定域的值增加给定的浮点数
HKEYS key 获取对象的所有属性字段
HVALS key 获取对象的所有属性值
HLEN key 获取对象的所有属性字段的总数
HMGET key field[field...] 获取对象的一个或多个指定字段的值
HSET key field value 设置对象指定字段的值
HMSET key field value [field value ...] 同时设置对象中一个或多个字段的值
HSETNX key field value 只在对象不存在指定的字段时才设置字段的值
HSTRLEN key field 返回对象指定field的value的字符串长度,如果该对象或者field不存在,返回0.
HSCAN key cursor [MATCH pattern] [COUNT count] 类似SCAN命令

Establecer colección

SADD key member [member ...] 	添加一个或者多个元素到集合(set)里
SCARD key 						获取集合里面的元素数量
SDIFF key [key ...] 			获得队列不存在的元素
SDIFFSTORE destination key [key ...] 获得队列不存在的元素,并存储在一个关键的结果集
SINTER key [key ...] 			获得两个集合的交集
SINTERSTORE destination key [key ...] 获得两个集合的交集,并存储在一个集合中
SISMEMBER key member 			确定一个给定的值是一个集合的成员
SMEMBERS key 					获取集合里面的所有key
SMOVE source destination member 移动集合里面的一个key到另一个集合
SPOP key [count] 				获取并删除一个集合里面的元素
SRANDMEMBER key [count] 		从集合里面随机获取一个元素
SREM key member [member ...] 	从集合里删除一个或多个元素,不存在的元素会被忽略
SUNION key [key ...] 			添加多个set元素
SUNIONSTORE destination key [key ...] 合并set元素,并将结果存入新的set里面
SSCAN key cursor [MATCH pattern] [COUNT count] 迭代set里面的元素

Conjunto ordenado

 
ZADD key score1 member1 [score2 member2] 
							添加一个或多个成员到有序集合,或者如果它已经存在更新其分数
ZCARD key 					得到的有序集合成员的数量
ZCOUNT key min max 			计算一个有序集合成员与给定值范围内的分数
ZINCRBY key increment member 在有序集合增加成员的分数
ZINTERSTORE destination numkeys key [key ...] 
							多重交叉排序集合,并存储生成一个新的键有序集合。
ZLEXCOUNT key min max 		计算一个给定的字典范围之间的有序集合成员的数量
ZRANGE key start stop [WITHSCORES] 由索引返回一个成员范围的有序集合(从低到高)
ZRANGEBYLEX key min max [LIMIT offset count]返回一个成员范围的有序集合(由字典范围)
ZRANGEBYSCORE key min max [WITHSCORES] [LIMIT] 
							返回有序集key中,所有 score 值介于 min 和 max 之间(包括等于 min 或 max )的成员,有序集成员按 score 值递增(从小到大)次序排列
ZRANK key member 			确定成员的索引中有序集合
ZREM key member [member ...] 从有序集合中删除一个或多个成员,不存在的成员将被忽略
ZREMRANGEBYLEX key min max 	删除所有成员在给定的字典范围之间的有序集合
ZREMRANGEBYRANK key start stop 在给定的索引之内删除所有成员的有序集合
ZREMRANGEBYSCORE key min max 在给定的分数之内删除所有成员的有序集合
ZREVRANGE key start stop [WITHSCORES] 
							返回一个成员范围的有序集合,通过索引,以分数排序,从高分到低分
ZREVRANGEBYSCORE key max min [WITHSCORES] 
							返回一个成员范围的有序集合,以socre排序从高到低
ZREVRANK key member 		确定一个有序集合成员的索引,以分数排序,从高分到低分
ZSCORE key member 			获取给定成员相关联的分数在一个有序集合
ZUNIONSTORE destination numkeys key [key ...] 
							添加多个集排序,所得排序集合存储在一个新的键
ZSCAN key cursor [MATCH pattern] [COUNT count] 增量迭代排序元素集和相关的分数

Supongo que te gusta

Origin blog.csdn.net/weixin_40849588/article/details/98262447
Recomendado
Clasificación