Redis部署
部署Redis需要先进行集群定义,本文介绍了几类Redis集群的定义方式。
与PostgreSQL类似,部署Redis同样需要两个步骤:
Redis集群定义
下面给出了三个Redis集群的精简定义,包括:
- 一个1节点,3实例的Redis Sentinel集群
redis-sentinel
- 一个2节点,12实例的的Redis Cluster集群
redis-cluster
- 一个1节点,一主两从的Redis Standalone集群
redis-standalone
您需要在节点上为Redis实例分配唯一的端口号。
Redis Sentinel集群定义
#----------------------------------#
# redis sentinel example #
#----------------------------------#
redis-meta:
hosts:
10.10.10.10:
redis_node: 1
redis_instances: { 6001 : {} ,6002 : {} , 6003 : {} }
vars:
redis_cluster: redis-meta
redis_mode: sentinel
redis_max_memory: 128MB
Redis原生集群定义
#----------------------------------#
# redis cluster example #
#----------------------------------#
redis-test:
hosts:
10.10.10.11:
redis_node: 1
redis_instances: { 6501 : {} ,6502 : {} ,6503 : {} ,6504 : {} ,6505 : {} ,6506 : {} }
10.10.10.12:
redis_node: 2
redis_instances: { 6501 : {} ,6502 : {} ,6503 : {} ,6504 : {} ,6505 : {} ,6506 : {} }
vars:
redis_cluster: redis-test # name of this redis 'cluster'
redis_mode: cluster # standalone,cluster,sentinel
redis_max_memory: 64MB # max memory used by each redis instance
redis_mem_policy: allkeys-lru # memory eviction policy
Redis普通主从实例定义
#----------------------------------#
# redis standalone example #
#----------------------------------#
redis-common:
hosts:
10.10.10.13:
redis_node: 1
redis_instances:
6501: {}
6502: { replica_of: '10.10.10.13 6501' }
6503: { replica_of: '10.10.10.13 6501' }
vars:
redis_cluster: redis-common # name of this redis 'cluster'
redis_mode: standalone # standalone,cluster,sentinel
redis_max_memory: 64MB # max memory used by each redis instance
创建Redis集群
使用剧本redis.yml
创建Redis实例/集群
./redis.yml -l redis-sentinel
./redis.yml -l redis-cluster
./redis.yml -l redis-standalone
此外,您还可以针对单个节点或单个Redis实例进行操作:
./redis.yml -l 10.10.10.10 # 创建单个节点 10.10.10.13
./redis.yml -l 10.10.10.13 -p 6501 # 创建单个实例 10.10.10.13:6501
其他注意事项
尽管这样做并不是推荐的行为,您可以将PostgreSQL与Redis进行混合部署,以充分利用机器资源。
redis.yml
剧本会在机器上同时部署Redis监控Exporter,包括redis_exporter
与node_exporter
(可选)
在此过程中,如果机器的node_exporter
存在,将会被重新部署。
Prometheus默认会使用”多目标抓取”模式,使用节点上9121端口的Redis Exporter抓取该节点上所有的Redis实例。
查阅Redis监控
目前Pigsty提供了3个Redis监控面板,作为一个独立监控应用 REDIS
的组成部分,分别为:
- Redis Overview:提供整个环境中Redis的全局概览, Demo
- Redis Cluster: 关注单个Redis业务集群的监控信息, Demo
- Redis Instance:关注单个Redis实例的详细监控信息, Demo
您可以使用自带的 redis-benchmark 进行测试,生成一些测试流量:
redis-benchmark -h 10.10.10.13 -p 6501
最后修改 2022-05-27: init commit (1e3e284)