在 Ubuntu 上安装和配置 Redis

devtools/2025/1/11 23:30:30/

在 Ubuntu 上安装和配置 Redis,并使用发布-订阅(Pub/Sub)功能,可以按照以下步骤进行:

一、安装 Redis

1. 更新包列表

首先,更新本地的包列表以确保获取到最新的软件包信息:

sudo apt update

2. 安装 Redis

使用 apt 包管理器安装 Redis:

sudo apt install redis-server

3. 验证安装

安装完成后,可以通过以下命令检查 Redis 的运行状态:

sudo systemctl status redis

如果 Redis 正在运行,输出中会显示 active (running)

二、配置 Redis

Redis 的主要配置文件位于 /etc/redis/redis.conf。你可以根据需要进行修改。

1. 编辑配置文件

使用你喜欢的文本编辑器(如 nano)编辑配置文件:

sudo nano /etc/redis/redis.conf

2. 常见配置选项

  • 持久化设置

    • 默认情况下,Redis 使用 RDB 快照持久化。你可以根据需求启用或禁用。
  • 绑定地址和端口

    • 默认绑定到 127.0.0.1,如果需要远程访问,可以修改 bind 参数,但需注意安全性。
  • 设置密码

    • 为了增强安全性,可以设置访问密码。在配置文件中取消注释并设置 requirepass
      requirepass yourpassword
      
  • 后台运行

    • 默认情况下,Redis 以后台模式运行。确保 daemonize 设置为 yes
      daemonize yes
      

3. 重新启动 Redis 服务

在修改配置文件后,重新启动 Redis 服务以应用更改:

sudo systemctl restart redis

4. 设置开机自启

确保 Redis 在系统启动时自动启动:

sudo systemctl enable redis

三、测试 Redis 安装

使用 redis-cli 工具连接到 Redis 服务器并测试:

redis-cli

redis-cli 提示符下输入:

redis">PING

如果一切正常,Redis 会回复:

redis">PONG

四、Redis 发布-订阅(Pub/Sub)使用指南

Redis 的发布-订阅功能允许消息在客户端之间实时传递。以下是如何使用 redis-cli 进行发布和订阅的示例。

1. 订阅频道

打开一个终端窗口,运行以下命令订阅一个频道(例如 news):

redis-cli

redis-cli 提示符下输入:

redis">SUBSCRIBE news

你将看到类似如下的输出,表示已成功订阅:

redis">1) "subscribe"
2) "news"
3) (integer) 1

此终端将持续监听 news 频道的消息。

2. 发布消息

打开另一个终端窗口,运行以下命令发布消息到 news 频道:

redis-cli

redis-cli 提示符下输入:

redis">PUBLISH news "Hello, Redis Pub/Sub!"

执行后,你将在订阅 news 频道的终端看到如下输出:

redis">(integer) 1

而订阅终端将显示:

redis">1) "message"
2) "news"
3) "Hello, Redis Pub/Sub!"

3. 示例:多个频道和消息

你可以订阅多个频道或使用通配符模式。例如,订阅所有以 news. 开头的频道:

redis">PSUBSCRIBE news.*

发布到不同的频道:

redis">PUBLISH news.sports "Sports news update"
PUBLISH news.weather "Weather forecast update"

订阅终端将接收到相应的消息。

4. 使用密码保护的 Redis 实例

如果 Redis 配置了访问密码,连接时需要提供密码。例如:

redis-cli -a yourpassword

或者在 redis-cli 内使用 AUTH 命令:

redis">AUTH yourpassword

五、进阶使用

除了命令行工具,你还可以在各种编程语言中使用 Redis 的 Pub/Sub 功能。例如,使用 Python 的 redis 库:

import redis# 创建 Redis 连接
r = redis.Redis(host='localhost', port=6379, password='yourpassword')# 订阅频道
pubsub = r.pubsub()
pubsub.subscribe('news')# 监听消息
for message in pubsub.listen():if message['type'] == 'message':print(f"Received message: {message['data'].decode()}")

发布消息:

import redisr = redis.Redis(host='localhost', port=6379, password='yourpassword')
r.publish('news', 'Hello from Python!')

在 Ubuntu 上安装和配置用于 C++ 编程的 Redis 环境,主要包括以下几个步骤:

  1. 安装 Redis 服务器(如果尚未安装)
  2. 安装必要的依赖库
  3. 安装 C++ Redis 客户端库(如 redis-plus-plus
  4. 配置开发环境
  5. 编写和运行示例 C++ 程序

以下是详细的步骤说明:

六、安装 Redis 服务器

如果你还没有在 Ubuntu 上安装 Redis,可以参考之前的回答中的步骤进行安装。如果已经安装,可以跳过此部分。

七、安装必要的依赖库

在安装 redis-plus-plus 之前,需要先安装一些依赖库,包括 hiredisCMake 等。

1. 更新包列表

sudo apt update

redis_237">2. 安装 hiredis

hiredis 是一个高性能的 Redis C 客户端库,是 redis-plus-plus 的依赖。

sudo apt install libhiredis-dev

3. 安装 CMake

CMake 是一个跨平台的构建系统,用于管理项目的构建过程。

sudo apt install cmake

4. 安装其他依赖

确保安装了编译 C++ 代码所需的编译器和工具:

sudo apt install build-essential

redisplusplusC_Redis__261">八、安装 redis-plus-plus(C++ Redis 客户端库)

redis-plus-plus 是一个功能丰富且易于使用的 C++ Redis 客户端库,基于 hiredis 构建。

redisplusplus__265">1. 克隆 redis-plus-plus 仓库

git clone https://github.com/sewenew/redis-plus-plus.git
cd redis-plus-plus

2. 创建构建目录并编译

mkdir build
cd build
cmake .. -DCMAKE_BUILD_TYPE=Release
make
sudo make install

这将编译并安装 redis-plus-plus 库到系统中。

3. 更新库缓存

sudo ldconfig

九、配置开发环境

确保你的 C++ 项目能够找到 redis-plus-plushiredis 的头文件和库文件。下面以一个简单的 C++ 项目为例,演示如何配置和使用 redis-plus-plus

1. 创建项目目录

mkdir ~/redis_cpp_project
cd ~/redis_cpp_project

2. 编写示例代码

创建一个名为 main.cpp 的文件,内容如下:

#include <sw/redis++/redis++.h>
#include <iostream>using namespace sw::redis;int main() {try {// 连接到 Redis 服务器auto redis = Redis("tcp://127.0.0.1:6379");// 设置键值对redis.set("key", "Hello, Redis!");// 获取键的值auto val = redis.get("key");if (val) {std::cout << "key: " << *val << std::endl;} else {std::cout << "key does not exist." << std::endl;}// 发布-订阅示例// 订阅频道auto sub = redis.subscriber();sub.on_message([](std::string channel, std::string msg) {std::cout << "Received message from channel " << channel << ": " << msg << std::endl;});sub.subscribe("news");// 在另一个线程中监听消息std::thread([&sub]() {try {sub.consume();} catch (const std::exception &e) {std::cerr << "Subscriber error: " << e.what() << std::endl;}}).detach();// 发布消息redis.publish("news", "Hello from C++!");// 等待一段时间以确保消息被接收std::this_thread::sleep_for(std::chrono::seconds(1));} catch (const Error &err) {std::cerr << "Redis error: " << err.what() << std::endl;}return 0;
}

3. 编写 CMakeLists.txt

创建一个名为 CMakeLists.txt 的文件,内容如下:

cmake_minimum_required(VERSION 3.5)
project(RedisCppExample)set(CMAKE_CXX_STANDARD 14)find_package(hiredis REQUIRED)
find_package(redis++ REQUIRED)add_executable(redis_cpp_example main.cpp)target_link_libraries(redis_cpp_example PRIVATE redis++ hiredis::hiredis)

4. 构建项目

mkdir build
cd build
cmake ..
make

5. 运行示例程序

确保 Redis 服务器正在运行,然后执行:

./redis_cpp_example

你应该会看到类似如下的输出:

key: Hello, Redis!
Received message from channel news: Hello from C++!

十、进一步学习和参考

1. 官方文档

  • redis-plus-plus GitHub 仓库
  • hiredis GitHub 仓库

2. 示例代码

redis-plus-plus 仓库中包含多个示例代码,展示了如何使用不同的功能。可以参考这些示例来扩展你的项目。

3. 编程指南

  • 连接 Redis:如何配置连接选项,如密码验证、SSL 等。
  • 基本操作:字符串、哈希、列表、集合、有序集合等数据结构的操作。
  • 发布-订阅:高级用法,如模式订阅、消息过滤等。
  • 事务和管道:如何在 C++ 中使用 Redis 的事务和管道功能。
  • 异步操作:使用异步 API 以提高性能和响应性。

十一、常见问题排查

1. 编译错误

如果在编译过程中遇到找不到 redis-plus-plushiredis 的头文件或库文件,确保它们已正确安装,并且 CMakeLists.txt 中的 find_package 指令能够找到它们。

2. 运行时错误

如果运行时无法连接到 Redis 服务器,请确保 Redis 服务器正在运行,并且连接地址和端口正确。

3. 权限问题

如果 Redis 配置了访问密码,在连接时需要提供密码。例如:

auto redis = Redis("tcp://127.0.0.1:6379?password=yourpassword");

http://www.ppmy.cn/devtools/149718.html

相关文章

【漏洞分析】DDOS攻防分析

0x00 UDP攻击实例 2013年12月30日&#xff0c;网游界发生了一起“追杀”事件。事件的主角是PhantmL0rd&#xff08;这名字一看就是个玩家&#xff09;和黑客组织DERP Trolling。 PhantomL0rd&#xff0c;人称“鬼王”&#xff0c;本名James Varga&#xff0c;某专业游戏小组的…

城市生命线安全综合监管平台

【落地产品&#xff0c;有需要可留言联系&#xff0c;支持项目合作或源码合作】 一、建设背景 以关于城市安全的重要论述为建设纲要&#xff0c;聚焦城市安全重点领域&#xff0c;围绕燃气爆炸、城市内涝、地下管线交互风险、第三方施工破坏、供水爆管、桥梁坍塌、道路塌陷七…

学习、应用AI时,工作流与智能体的侧重选择

近日有朋友留言&#xff1a;“学习、应用AI时&#xff0c;工作流与智能体的侧重选择&#xff1f;” 其实在学习、应用AI时&#xff0c;选择工作流还是智能体主要取决于具体的应用场景和需求。以下是两者的一些特点和适用场景&#xff1a; 工作流的特点和适用场景 - 特点&…

ip属地出省会变吗?怎么出省让ip属地不变

在数字化时代&#xff0c;IP属地作为网络身份的一个重要标识&#xff0c;不仅影响着我们的网络体验&#xff0c;还与网络安全、隐私保护等方面息息相关。当我们跨省移动时&#xff0c;是否会遇到IP属地变化的问题&#xff1f;如果希望保持IP属地不变&#xff0c;又该如何操作呢…

Spring Boot项目中增加MQTT对接

在Spring Boot项目中增加MQTT对接&#xff0c;通常涉及以下几个步骤&#xff1a; 一、搭建MQTT服务器 首先&#xff0c;你需要搭建一个MQTT服务器&#xff08;Broker&#xff09;。这可以通过多种方式实现&#xff0c;例如使用Docker来部署EMQX或Mosquitto等MQTT Broker。 以…

C#用直线和曲线抗锯齿

使用 GDI 绘制一条线时&#xff0c;要提供线条的起点和终点&#xff0c;但不必提供有关线条上各个像素的任何信息。 GDI 与显示驱动程序软件协同工作&#xff0c;确定将打开哪些像素以在特定显示设备上显示该线条。 效果对比 代码实现 关键代码 e.Graphics.SmoothingMode Sm…

空对象模式

在空对象模式&#xff08;Null Object Pattern&#xff09;中&#xff0c;一个空对象取代 NULL 对象实例的检查。Null 对象不是检查空值&#xff0c;而是反应一个不做任何动作的关系。这样的 Null 对象也可以在数据不可用的时候提供默认的行为。 在空对象模式中&#xff0c;我…

Spring Boot3 配合ProxySQL实现对 MySQL 主从同步的读写分离和负载均衡

将 ProxySQL 配合 Spring Boot 使用&#xff0c;主要的目的是在 Spring Boot 应用程序中实现对 MySQL 主从同步的读写分离和负载均衡。这样&#xff0c;你可以利用 ProxySQL 自动将写操作路由到主库&#xff0c;而将读操作路由到从库。 1. 准备工作 确保你的 MySQL 主从同步环…