redis单机多实例
Redis的网络模型是一个单线程 Epoll 的模型,你可以理解为它是一个单线程的服务器,如果你的机器为24核,
那么启动一个实例相当于只会占用1核,所以当然是会启动多个实例来跑满CPU
多个项目应用部署在通一台服务器上,且彼此数据不共享,对redis有不同的配置需求
单机多实例配置
1、创建不同实例的数据存放目录
mkdir -p /data/redis/638{0…2}
2、在 6380下编写一个配置文件redis.conf
例:
vim redis.conf
bind 0.0.0.0
protected-mode no
port 6380 #修改端口
tcp-backlog 511
timeout 0
tcp-keepalive 300
daemonize yes
supervised no
pidfile "/var/run/redis_6380.pid" #修改进程名
loglevel notice
logfile "/data/redis/6380/redis_6380.log" #修改日志名
databases 16
always-show-logo yes
save 900 1
save 300 10
save 60 10000
stop-writes-on-bgsave-error yes
rdbcompression yes
rdbchecksum yes
dbfilename "dump.rdb"
dir "/data/redis/6380" #修改目录位置
masterauth "123123"
replica-serve-stale-data yes
replica-read-only yes
repl-diskless-sync no
repl-diskless-sync-delay 5
repl-disable-tcp-nodelay no
replica-priority 100
requirepass "123123"
lazyfree-lazy-eviction no
lazyfree-lazy-expire no
lazyfree-lazy-server-del no
replica-lazy-flush no
appendonly no
appendfilename "appendonly.aof"
appendfsync everysec
no-appendfsync-on-rewrite no
auto-aof-rewrite-percentage 100
auto-aof-rewrite-min-size 64mb
aof-load-truncated yes
aof-use-rdb-preamble yes
lua-time-limit 5000
slowlog-log-slower-than 10000
slowlog-max-len 128
latency-monitor-threshold 0
notify-keyspace-events ""
hash-max-ziplist-entries 512
hash-max-ziplist-value 64
list-max-ziplist-size -2
list-compress-depth 0
set-max-intset-entries 512
zset-max-ziplist-entries 128
zset-max-ziplist-value 64
hll-sparse-max-bytes 3000
stream-node-max-bytes 4096
stream-node-max-entries 100
activerehashing yes
client-output-buffer-limit normal 0 0 0
client-output-buffer-limit replica 256mb 64mb 60
client-output-buffer-limit pubsub 32mb 8mb 60
hz 10
dynamic-hz yes
aof-rewrite-incremental-fsync yes
rdb-save-incremental-fsync yes
#rename-command FLUSHALL ""
#rename-command FLUSHDB ""
#rename-command KEYS ""
3、在其他实例目录创建或复制上述配置
cp /data/redis/6380/redis.conf /data/redis/6381/redis.conf
cp /data/redis/6380/redis.conf /data/redis/6382/redis.conf
4、修改81和82的配置文件,替换端口
vim /data/redis/6381/redis.conf /data/redis/6382/redis.conf
:1,KaTeX parse error: Expected 'EOF', got '#' at position 23: …6381/g :wn #̲写入并并编辑下一个 :1,s/6380/6382/g
:wq
5、分别启动实例
redis-server /data/redis/6380/conf/redis.conf
redis-server /data/redis/6381/conf/redis.conf
redis-server /data/redis/6382/conf/redis.conf
6、查看端口并使用redis.cli测试结果
多实例启动完成