Redis自动化安装及集群实现搭建过程
发表于:2025-01-23 作者:千家信息网编辑
千家信息网最后更新 2025年01月23日,Redis实例安装安装说明:自动解压缩安装包,按照指定路径编译安装,复制配置文件模板到Redis实例路的数据径下,根据端口号修改配置文件模板配置文件,当前shell脚本,安装包参数1:basedir,
千家信息网最后更新 2025年01月23日Redis自动化安装及集群实现搭建过程
Redis实例安装
安装说明:自动解压缩安装包,按照指定路径编译安装,复制配置文件模板到Redis实例路的数据径下,根据端口号修改
配置文件模板
配置文件,当前shell脚本,安装包
参数1:basedir,redis安装包路径
参数2:安装实例路径
参数3:安装包名称
参数4:安装实例的端口号
#!/bin/bashset -eif [ $# -lt 4 ]; then echo "$(basename $0): Missing script argument" echo "$(installdir $0) [installfilename] [port] " exit 9fiPotInUse=`netstat -anp | awk '{print $4}' | grep $4 | wc -l`if [ $PotInUse -gt 0 ];then echo "ERROR" $4 "Port is used by another process!" exit 9fibasedir=$1installdir=$2installfilename=$3port=$4cd $basedirtar -zxvf $installfilename.tar.gz >/dev/null 2>&1 &cd $installfilenamemkdir -p $installdirmake PREFIX=$installdir installsleep 1s cp $basedir/redis.conf $installdirsed -i "s/instance_port/$port/g" $installdir/redis.confsleep 1s cd $installdir./bin/redis-server redis.conf >/dev/null 2>&1 &
配置文件模板
################################## INCLUDES #################################### include /path/to/local.conf# include /path/to/other.conf################################## MODULES ###################################### loadmodule /path/to/my_module.so# loadmodule /path/to/other_module.so################################## NETWORK #####################################bind 127.0.0.1 & your ipport instance_porttcp-backlog 511timeout 0tcp-keepalive 300################################# GENERAL #####################################daemonize yessupervised nopidfile ./redis_instance_port.pidloglevel noticelogfile ./redis_log.logdatabases 16always-show-logo yes################################ SNAPSHOTTING ################################save 900 1save 300 10save 60 10000stop-writes-on-bgsave-error yesrdbcompression yesrdbchecksum yesdbfilename dump.rdbdir ./################################# REPLICATION ################################## masterauthreplica-serve-stale-data yesreplica-read-only yesrepl-diskless-sync norepl-diskless-sync-delay 5repl-disable-tcp-nodelay noreplica-priority 100################################## SECURITY ###################################requirepass your_passwrod################################### CLIENTS ##################################### maxclients 10000############################## MEMORY MANAGEMENT ################################# maxmemory # maxmemory-policy noeviction# maxmemory-samples 5# replica-ignore-maxmemory yes############################# LAZY FREEING ####################################lazyfree-lazy-eviction nolazyfree-lazy-expire nolazyfree-lazy-server-del noreplica-lazy-flush no############################## APPEND ONLY MODE ###############################appendonly noappendfilename "appendonly.aof"# appendfsync alwaysappendfsync everysec# appendfsync nono-appendfsync-on-rewrite noauto-aof-rewrite-percentage 100auto-aof-rewrite-min-size 64mbaof-load-truncated yesaof-use-rdb-preamble yes################################ LUA SCRIPTING ###############################lua-time-limit 5000################################ REDIS CLUSTER ###############################cluster-enabled yes# cluster-replica-validity-factor 10# cluster-require-full-coverage yes# cluster-replica-no-failover no########################## CLUSTER DOCKER/NAT support ########################################################## SLOW LOG ###################################slowlog-log-slower-than 10000slowlog-max-len 128################################ LATENCY MONITOR ##############################latency-monitor-threshold 0############################# EVENT NOTIFICATION ##############################notify-keyspace-events ""############################### ADVANCED CONFIG ###############################hash-max-ziplist-entries 512hash-max-ziplist-value 64list-max-ziplist-size -2list-compress-depth 0set-max-intset-entries 512zset-max-ziplist-entries 128zset-max-ziplist-value 64hll-sparse-max-bytes 3000stream-node-max-bytes 4096stream-node-max-entries 100activerehashing yesclient-output-buffer-limit normal 0 0 0client-output-buffer-limit replica 256mb 64mb 60client-output-buffer-limit pubsub 32mb 8mb 60# client-query-buffer-limit 1gb# proto-max-bulk-len 512mbhz 10dynamic-hz yesaof-rewrite-incremental-fsync yesrdb-save-incremental-fsync yes########################### ACTIVE DEFRAGMENTATION ######################## Enabled active defragmentation# activedefrag yes# Minimum amount of fragmentation waste to start active defrag# active-defrag-ignore-bytes 100mb# Minimum percentage of fragmentation to start active defrag# active-defrag-threshold-lower 10# Maximum percentage of fragmentation at which we use maximum effort# active-defrag-threshold-upper 100# Minimal effort for defrag in CPU percentage# active-defrag-cycle-min 5# Maximal effort for defrag in CPU percentage# active-defrag-cycle-max 75# Maximum number of set/hash/zset/list fields that will be processed from# the main dictionary scan# active-defrag-max-scan-fields 1000
安装示例
sh redis_install.sh /usr/local/redis/ /usr/local/redis5/redis9008/ redis-5.0.4 9008
Redi实例的目录结构
基于Python的Redis自动化集群实现
基于Python的自动化集群实现,初始化节点为node_1~node_6,节点实例需要为集群模式,三主三从,自动化集群,分配slots,加入从节点,3秒钟左右完成
import redis#masternode_1 = {'host': '127.0.0.1', 'port': 9001, 'password': '***'}node_2 = {'host': '127.0.0.1', 'port': 9002, 'password': '***'}node_3 = {'host': '127.0.0.1', 'port': 9003, 'password': '***'}#slavenode_4 = {'host': '127.0.0.1', 'port': 9004, 'password': '***'}node_5 = {'host': '127.0.0.1', 'port': 9005, 'password': '***'}node_6 = {'host': '127.0.0.1', 'port': 9006, 'password': '***'}redis_conn_1 = redis.StrictRedis(host=node_1["host"], port=node_1["port"], password=node_1["password"])redis_conn_2 = redis.StrictRedis(host=node_2["host"], port=node_2["port"], password=node_2["password"])redis_conn_3 = redis.StrictRedis(host=node_3["host"], port=node_3["port"], password=node_3["password"])# cluster meetredis_conn_1.execute_command("cluster meet {0} {1}".format(node_2["host"],node_2["port"]))redis_conn_1.execute_command("cluster meet {0} {1}".format(node_3["host"],node_3["port"]))print('#################flush slots #################')redis_conn_1.execute_command('cluster flushslots')redis_conn_2.execute_command('cluster flushslots')redis_conn_3.execute_command('cluster flushslots')print('#################add slots#################')for i in range(0,16383+1): if i <= 5461: try: redis_conn_1.execute_command('cluster addslots {0}'.format(i)) except: print('cluster addslots {0}'.format(i) +' error') elif 5461 < i and i <= 10922: try: redis_conn_2.execute_command('cluster addslots {0}'.format(i)) except: print('cluster addslots {0}'.format(i) + ' error') elif 10922 < i: try: redis_conn_3.execute_command('cluster addslots {0}'.format(i)) except: print('cluster addslots {0}'.format(i) + ' error')print()print('#################cluster status#################')print()print('##################'+str(node_1["host"])+':'+str(node_1["port"])+'##################')print(str(redis_conn_1.execute_command('cluster info'), encoding = "utf-8").split("\n")[0])print('##################'+str(node_2["host"])+':'+str(node_2["port"])+'##################')print(str(redis_conn_1.execute_command('cluster info'), encoding = "utf-8").split("\n")[0])print('##################'+str(node_3["host"])+':'+str(node_3["port"])+'##################')print(str(redis_conn_1.execute_command('cluster info'), encoding = "utf-8").split("\n")[0])#slave cluster meetredis_conn_1.execute_command("cluster meet {0} {1}".format(node_4["host"],node_4["port"]))redis_conn_2.execute_command("cluster meet {0} {1}".format(node_5["host"],node_5["port"]))redis_conn_3.execute_command("cluster meet {0} {1}".format(node_6["host"],node_6["port"]))#cluster nodesprint(str(redis_conn_1.execute_command('cluster nodes'), encoding = "utf-8"))
示例
这样一个Redis的集群,从实例的安装到集群的安装,环境依赖本身没有问题的话,基本上1分钟之内可以完成这个搭建过程。
总结
以上所述是小编给大家介绍的Redis自动化安装及集群实现搭建过程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
集群
实例
自动化
参数
文件
utf-8
配置
模板
节点
路径
过程
口号
示例
帮助
出处
名称
数据
模式
环境
疑问
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
上海高科技互联网数据服务价目表
2021年网络安全宣传短片
2019网络安全小主播
服务器z
安全接入服务器地址在哪找
北仑计算机软件开发平台
银行业网络安全审计报告
网络安全技能大赛 原题
创业板软件开发类上市公司
ip代理服务器软件
移动公司网络技术工程师
海南三亚什么是软件开发
开展网络安全倡议新闻稿
本地https服务器搭建
电脑显示无网络安全
计算机网络技术的国企
软件开发学哪个软件好
银行网络安全培训总结报告
北邮网络技术研究院张淼垚
互联网 智能科技 ceo
银行卡归属地数据库安全吗
网络安全填空题及答案解析
医院网络安全排查整治情况
公司网络安全保卫部职责
北京八零网络技术有限公司
软件开发方法的展望
泰州泰达网络技术有限公司
查询td数据库字符集
网络安全基础知识的培训
网络技术设置pc
- 上一篇
MySQL 5.5初始化数据库报错FATAL ERROR: Could not find my_print_defaults怎么办
这篇文章给大家分享的是有关MySQL 5.5初始化数据库报错FATAL ERROR: Could not find my_print_defaults怎么办的内容。小编觉得挺实用的,因此分享给大家做个
- 下一篇
怎么解决SQLServer报错消息 7347,级别 16
这篇文章主要介绍"怎么解决SQLServer报错消息 7347,级别 16",在日常操作中,相信很多人在怎么解决SQLServer报错消息 7347,级别 16问题上存在疑惑,小编查阅了各式资料,整理