当前位置: 首页 > article >正文

CentOS 7 企业级Redis 7部署指南

CentOS 7 企业级Redis 7部署指南

目录导航

  1. 一、环境准备
    • 1.1 依赖管理
  2. 二、离线安装
    • 2.1 源码编译安装
    • 2.2 目录结构规范
  3. 三、生产配置
    • 3.1 主配置文件
    • 3.2 配置生成脚本
  4. 四、系统集成
    • 4.1 Systemd服务文件
    • 4.2 服务管理命令
  5. 五、安全加固
    • 5.1 网络安全配置
    • 5.2 审计配置
  6. 六、性能调优
    • 6.1 内存优化配置
    • 6.2 基准测试命令
  7. 七、维护指南
    • 7.1 监控命令
    • 7.2 备份策略

## 一、环境准备

###1.1 依赖管理安装

依赖包网盘下载:链接:https://drive.uc.cn/s/9021e2417a1e4

# 安装开发工具链
rpm -ivh *.rpm
rpm -Uvh *.rpm --nodeps --force# 验证GCC版本(需≥4.9)
gcc --version | head -n1

image.png

##二、离线安装

###2.1 源码编译安装

# 解压源码包
tar -zxvf redis-7.2.3.tar.gz
cd redis-7.2.3# 多线程编译优化
make -j $(nproc) BUILD_TLS=yes CFLAGS="-O2 -march=native"# 验证编译结果(约需5-10分钟)
make test# 企业级路径安装
sudo make install \PREFIX=/opt/redis \SYSTEMD_DIR=/usr/lib/systemd/system \LOG_DIR=/var/log/redis \DATA_DIR=/data/redis

###2.2 目录结构规范

/opt/redis/
├── bin/          # 可执行文件(redis-server、redis-cli等)
├── etc/          # 配置文件(redis.conf)
├── var/          # 运行时文件(pidfile等)
└── logs -> /var/log/redis  # 日志软链接/data/redis/      # 持久化数据存储(AOF/RDB文件)

##三、生产配置

###3.1 主配置文件 (redis.conf)

# 网络配置
bind 0.0.0.0
protected-mode yes
port 6379
tcp-backlog 511# 安全配置
requirepass ${REDIS_PASSWORD}
rename-command FLUSHDB ""
rename-command CONFIG ""# 资源限制
maxclients 10000
maxmemory 16GB
maxmemory-policy allkeys-lru# 持久化策略
appendonly yes
appendfsync everysec
aof-rewrite-incremental-fsync yes# 性能优化
io-threads 4
activerehashing yes

###3.2 配置生成脚本

#!/bin/bash
# generate_redis_conf.shread -s -p "Enter Redis password: " REDIS_PASSWORD
echosed -e "s/\${REDIS_PASSWORD}/$REDIS_PASSWORD/" \-e "s/^maxmemory .*/maxmemory 16GB/" \< redis.conf.template > redis.conf

##四、系统集成

###4.1 Systemd服务文件

# /usr/lib/systemd/system/redis.service
[Unit]
Description=Redis In-Memory Data Store
Documentation=https://redis.io/documentation
After=network.target
Conflicts=redis-sentinel.service[Service]
Type=notify
User=redis
Group=redis
ExecStart=/opt/redis/bin/redis-server /opt/redis/etc/redis.conf
ExecStop=/opt/redis/bin/redis-cli shutdown
Restart=always
RestartSec=30
LimitNOFILE=65535
OOMScoreAdjust=-100[Install]
WantedBy=multi-user.target

###4.2 服务管理命令

# 创建专用用户
sudo useradd -r -s /sbin/nologin redis# 设置目录权限
sudo chown -R redis:redis /opt/redis /data/redis# 重载服务配置
sudo systemctl daemon-reload
sudo systemctl enable --now redis# 查看服务状态
systemctl status redis

##五、安全加固

###5.1 网络安全配置

# 防火墙设置
sudo firewall-cmd --permanent --add-port=6379/tcp
sudo firewall-cmd --reload# SELinux策略
sudo semanage port -a -t redis_port_t -p tcp 6379

###5.2 审计配置

# 审计日志配置
audit-log-file /var/log/redis/audit.log
audit-log-syslog-enabled yes

##六、性能调优

###6.1 内存优化配置

# 内存分配策略
jemalloc-bg-thread yes
maxmemory-samples 5# 连接池优化
timeout 300
tcp-keepalive 60

###6.2 基准测试命令

redis-benchmark \-h 127.0.0.1 \-p 6379 \-a ${REDIS_PASSWORD} \-c 1000 \-n 1000000 \-d 2048 \-t set,get

##七、维护指南

###7.1 监控命令

# 实时监控(每秒刷新)
redis-cli -a ${REDIS_PASSWORD} --stat# 内存热点分析
redis-cli -a ${REDIS_PASSWORD} --bigkeys

###7.2 备份策略

# 自动备份脚本(每日凌晨2点)
sudo crontab -e
0 2 * * * /opt/redis/bin/redis-cli -a ${REDIS_PASSWORD} BGSAVE

相关文章:

CentOS 7 企业级Redis 7部署指南

CentOS 7 企业级Redis 7部署指南 目录导航 一、环境准备 1.1 依赖管理 二、离线安装 2.1 源码编译安装2.2 目录结构规范 三、生产配置 3.1 主配置文件3.2 配置生成脚本 四、系统集成 4.1 Systemd服务文件4.2 服务管理命令 五、安全加固 5.1 网络安全配置5.2 审计配置 六、性能…...

Python创建Excel的方式——提供4中方式可供参考

目录 专栏导读库的安装代码1——pandas代码2——openpyxl代码3——xlsxwriter代码4——xlwings总结 专栏导读 &#x1f338; 欢迎来到Python办公自动化专栏—Python处理办公问题&#xff0c;解放您的双手 &#x1f3f3;️‍&#x1f308; 博客主页&#xff1a;请点击——>…...

消息中间件深度剖析:以 RabbitMQ 和 Kafka 为核心

在现代分布式系统和微服务架构的构建中&#xff0c;消息中间件作为一个不可或缺的组件&#xff0c;承担着系统间解耦、异步处理、流量削峰、数据传输等重要职能。尤其是在面临大规模并发、高可用性和可扩展性需求时&#xff0c;如何选择合适的消息中间件成为了开发者和架构师们…...

回文数:简单问题中的多种优化思路

回文数&#xff1a;简单问题中的多种优化思路 引言 回文数&#xff08;Palindrome Number&#xff09;是一个有趣的问题&#xff0c;在算法竞赛、面试、甚至一些实际应用场景中都会遇到。最直观的方式是将数字转换成字符串&#xff0c;然后反转比较。但仅仅满足“能解”是不够…...

大语言模型简史:从Transformer(2017)到DeepSeek-R1(2025)的进化之路

2025年初&#xff0c;中国推出了具有开创性且高性价比的「大型语言模型」&#xff08;Large Language Model — LLM&#xff09;DeepSeek-R1&#xff0c;引发了AI的巨大变革。本文回顾了LLM的发展历程&#xff0c;起点是2017年革命性的Transformer架构&#xff0c;该架构通过「…...

java八股文-spring

目录 1. spring基础 1.1 什么是Spring&#xff1f; 1.2 Spring有哪些优点&#xff1f; 1.3 Spring主要模块 1.4 Spring常用注解 1.5 Spring中Bean的作用域 1.6 Spring自动装配的方式 1.7 SpringBean的生命周期 1.8 多级缓存 1.9 循环依赖&#xff1f; 1 .8.1 原因 1.8…...

机器学习--实现多元线性回归

机器学习—实现多元线性回归 本节顺延机器学习--线性回归中的内容&#xff0c;进一步讨论多元函数的回归问题 y ′ h ( x ) w ⊤ ∙ x b y^{\prime}h(x)w^\top\bullet xb y′h(x)w⊤∙xb 其中, w T ⋅ x 就是 W 1 X 1 w 2 X 2 w 3 X 3 ⋯ w N X N \text{其中,}w^\math…...

vue3响应式丢失解决办法(三)

vue3的响应式的理解&#xff0c;与普通对象的区别&#xff08;一&#xff09; vue3 分析总结响应式丢失问题原因&#xff08;二&#xff09; 经过前面2篇文章&#xff0c;知道了响应式为什么丢失了&#xff0c;但是还是碰到了丢失情况&#xff0c;并且通过之前的内容还不能解…...

NLP 八股 DAY1:BERT

BERT全称&#xff1a;Pre-training of deep bidirectional transformers for language understanding&#xff0c;即深度双向Transformer。 模型训练时的两个任务是预测句⼦中被掩盖的词以及判断输⼊的两个句⼦是不是上下句。在预训练 好的BERT模型后⾯根据特定任务加上相应的⽹…...

蓝桥与力扣刷题(230 二叉搜索树中第k小的元素)

题目&#xff1a;给定一个二叉搜索树的根节点 root &#xff0c;和一个整数 k &#xff0c;请你设计一个算法查找其中第 k 小的元素&#xff08;从 1 开始计数&#xff09;。 示例 1&#xff1a; 输入&#xff1a;root [3,1,4,null,2], k 1 输出&#xff1a;1示例 2&#xff…...

半遮挡检测算法 Detecting Binocular Half-Occlusions

【1. 背景】&#xff1a; 本文分析【Detecting Binocular Half-Occlusions&#xff1a;Empirical Comparisons of Five Approaches】Geoffrey Egnal和Richard P. Wildes于2002年发表在IEEE Transactions on Pattern Analysis and Machine Intelligence上&#xff0c;这是1篇中…...

PHP培训机构教务管理系统小程序

&#x1f511; 培训机构教务管理系统——智慧教育&#xff0c;高效管理新典范 &#x1f680; 这款教务管理系统&#xff0c;是基于前沿的ThinkPHP框架与Uniapp技术深度融合&#xff0c;匠心打造的培训机构管理神器。它犹如一把开启高效运营与精细管理的金钥匙&#xff0c;专为…...

《LeetCode 763. 划分字母区间 | 高效分割字符串》

内容&#xff1a; 问题描述&#xff1a; 给定一个字符串 S&#xff0c;将字符串分割成若干个子串&#xff0c;使得每个子串中的字符都不重复&#xff0c;并且返回每个子串的长度。 解题思路&#xff1a; 找到每个字符最后一次出现的位置&#xff1a;我们首先遍历一遍字符串&a…...

无人机不等同轴旋翼架构设计应用探究

“结果显示&#xff0c;对于不等组合&#xff0c;用户应将较小的螺旋桨置于上游以提高能效&#xff0c;但若追求最大推力&#xff0c;则两个相等的螺旋桨更为理想。” 在近期的研究《不等同轴旋翼性能特性探究》中&#xff0c;Max Miles和Stephen D. Prior博士深入探讨了不同螺…...

什么是 大语言模型中Kernel优化

什么是 大语言模型中Kernel优化 目录 什么是 大语言模型中Kernel优化Kernel优化操作系统内核优化深度学习计算内核优化手工优化原理举例Flash Attention,Faster TransformerKernel优化 大语言模型存在访存密集操作(如注意力机制、LayerNorm等),这些操作使得GPU计算性能无法…...

DeepSeek与ChatGPT:AI语言模型的全面对决

DeepSeek与ChatGPT&#xff1a;AI语言模型的全面对决 引言&#xff1a;AI 语言模型的时代浪潮一、认识 DeepSeek 与 ChatGPT&#xff08;一&#xff09;DeepSeek&#xff1a;国产新星的崛起&#xff08;二&#xff09;ChatGPT&#xff1a;AI 界的开拓者 二、DeepSeek 与 ChatGP…...

CTFHub技能树-密码口令wp

目录 引言弱口令默认口令 引言 仅开放如下关卡 弱口令 通常认为容易被别人&#xff08;他们有可能对你很了解&#xff09;猜测到或被破解工具破解的口令均为弱口令。 打开环境&#xff0c;是如下界面&#xff0c;尝试一些弱口令密码无果 利用burpsuite抓包&#xff0c;然后爆…...

Deepseek R1模型本地化部署与API实战指南:释放企业级AI生产力

摘要 本文深入解析Deepseek R1开源大模型的本地化部署流程与API集成方案&#xff0c;涵盖从硬件选型、Docker环境搭建到模型微调及RESTful接口封装的完整企业级解决方案。通过电商评论分析和智能客服搭建等案例&#xff0c;展示如何将前沿AI技术转化为实际生产力。教程支持Lin…...

MISP从入门到实战:威胁情报共享平台搭建与使用详解

MISP从入门到实战&#xff1a;威胁情报共享平台搭建与使用详解 目录 MISP核心作用与价值MISP安装与部署 2.1 Docker快速部署2.2 手动安装&#xff08;Ubuntu&#xff09; MISP基础使用教程 3.1 创建事件与属性3.2 数据共享与同步3.3 威胁情报分析实战 MISP高级功能 4.1 Galaxy…...

【NLP251】BertTokenizer 的全部 API 及 使用案例

BertTokenizer 是 Hugging Face 的 transformers 库中用于处理 BERT 模型输入的分词器类。它基于 WordPiece 分词算法&#xff0c;能够将文本分割成词汇单元&#xff08;tokens&#xff09;&#xff0c;并将其转换为 BERT 模型可以理解的格式。BertTokenizer 是 BERT 模型的核心…...

【MySQL常见疑难杂症】常见文件及其所存储的信息

1、MySQL配置文件的读取顺序 &#xff08;非Win&#xff09;/etc/my.cnf、/etc/mysql/my.cnf、/usr/local/mysql/etc/my.cnf、&#xff5e;/.my.cnf 可以通过命令查看MySQL读取配置文件的顺序 [roothadoop01 ~]# mysql --help |grep /etc/my.cnf /etc/my.cnf /etc/mysql/my.c…...

InnoDB如何解决幻读?深入解析MySQL的并发控制机制

--- ## 一、什么是幻读&#xff08;Phantom Read&#xff09;&#xff1f; **幻读**是数据库事务隔离性中的一个典型问题&#xff0c;具体表现为&#xff1a; 在同一个事务中&#xff0c;多次执行相同的范围查询&#xff08;Range Query&#xff09;时&#xff0c;**后一次…...

栈的深度解析:从基础实现到高级算法应用——C++实现与实战指南

一、栈的核心算法与应用场景 栈的先进后出特性使其在以下算法中表现优异&#xff1a; 括号匹配&#xff1a;校验表达式合法性。表达式求值&#xff1a;中缀转后缀&#xff0c;逆波兰表达式求值。深度优先搜索&#xff08;DFS&#xff09;&#xff1a;模拟递归调用。单调栈&am…...

IDEA集成DeepSeek

引言 随着数据量的爆炸式增长&#xff0c;传统搜索技术已无法满足用户对精准、高效搜索的需求。 DeepSeek作为新一代智能搜索技术&#xff0c;凭借其强大的语义理解与深度学习能力&#xff0c;正在改变搜索领域的游戏规则。 对于 Java 开发者而言&#xff0c;将 DeepSeek 集成…...

Oracle Trace文件突然增长很多的原因分析及解决办法

Oracle Trace文件突然增长很多可能是由多种原因引起的,例如SQL语句的长时间跟踪、错误的跟踪设置、大量的错误和警告信息等。 一、以下是一些解决Trace文件增长过快的方法: 1.清理旧的Trace文件 可以通过以下命令删除超过一定天数的Trace文件,例如删除3天前的Trace文件: …...

leetcode:627. 变更性别(SQL解法)

难度&#xff1a;简单 SQL Schema > Pandas Schema > Salary 表&#xff1a; ----------------------- | Column Name | Type | ----------------------- | id | int | | name | varchar | | sex | ENUM | | salary | int …...

SQLMesh系列教程-3:SQLMesh模型属性详解

SQLMesh 的 MODEL 提供了丰富的属性&#xff0c;用于定义模型的行为、存储、调度、依赖关系等。通过合理配置这些属性&#xff0c;可以构建高效、可维护的数据管道。在 SQLMesh 中&#xff0c;MODEL 是定义数据模型的核心结构&#xff0c;初学SQLMesh&#xff0c;定义模型看到属…...

Java 中的 HashSet 和 HashMap 有什么区别?

一、核心概念与用途 特性HashSetHashMap接口实现实现 Set 接口&#xff08;存储唯一元素&#xff09;实现 Map 接口&#xff08;存储键值对&#xff09;数据存储存储单个对象&#xff08;元素唯一&#xff09;存储键值对&#xff08;键唯一&#xff0c;值可重复&#xff09;典…...

Kubernetes-master 组件

以下是Kubernetes Master Machine的组件。 etcd 它存储集群中每个节点可以使用的配置信息。它是一个高可用性键值存储&#xff0c;可以在多个节点之间分布。只有Kubernetes API服务器可以访问它&#xff0c;因为它可能具有一些敏感信息。这是一个分布式键值存储&#xff0c;所…...

【Leetcode 952】按公因数计算最大组件大小

题干 给定一个由不同正整数的组成的非空数组 nums &#xff0c;考虑下面的图&#xff1a; 有 nums.length 个节点&#xff0c;按从 nums[0] 到 nums[nums.length - 1] 标记&#xff1b;只有当 nums[i] 和 nums[j] 共用一个大于 1 的公因数时&#xff0c;nums[i] 和 nums[j]之…...