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

Redis实训:社交关注关系存储任务

一、实验目的

1.  理解Redis的安装、配置及基本操作。

2.  掌握Redis的不同数据类型及相应操作方法。

3.  学习使用Java客户端连接Redis,并进行数据操作。

4.  实践使用Redis存储社交关注关系的功能。

二、实验环境准备

1.  JAVA环境准备:确保Java Development Kit (JDK) 已安装并配置好环境变量。

2.  Hadoop环境准备:安装并配置Hadoop环境,确保Hadoop的各个组件可以在伪分布式模式下运行。

三、实验教材参考

《大数据存储》,谭旭,人民邮电出版社,2022,ISBN 978-7-115-59414-3。

四、实验内容与步骤

1、安装和配置Redis

按照Redis官方配置或适合操作系统的指南,安装和配置了Redis数据库。

安装成功后启动界面如下:

2、验证Java客户端连接

1. 使用Maven或手动导入Jedis库到Java项目中。  

使用Maven构建项目,在pom.xml文件中添加Jedis依赖:

<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>4.4.4</version>
</dependency>

2. 编写简单的Java程序,连接到本地Redis服务,并进行简单的读写操作,验证连接成功。

(1)实现代码

package com.example;

import redis.clients.jedis.Jedis;

public class Four_Redis {
    public static void main(String[] args) {
        // 连接到本地Redis服务
        Jedis jedis = new Jedis("192.168.10.200", 6379);

        // 测试连接
        System.out.println("连接成功!Redis服务器状态: " + jedis.ping());

        // 写入数据到Redis
        jedis.set("key1", "Hello, Redis!");

        // 从Redis读取数据
        String value = jedis.get("key1");
        System.out.println("从Redis中获取的值: " + value);

        // 关闭连接
        jedis.close();
    }
}

(2)运行结果

3、实现社交关注关系存储任务

1. 设计并编写Java程序,实现用户关注其他用户的功能。

2. 实现查询某用户关注的用户列表和某用户的粉丝列表的功能。

(1)Java实现代码:

package com.example;
import redis.clients.jedis.Jedis;
import java.util.Set;
public class Four_Redis {

    private final Jedis jedis;

    public Four_Redis() {
        // 连接到本地Redis服务
        this.jedis = new Jedis("192.168.10.200", 6379);
        System.out.println("连接Redis成功: " + jedis.ping());
    }

    // 用户关注其他用户

    public void followUser(String userId, String followUserId) {
        jedis.sadd("user:" + userId + ":following", followUserId); // 当前用户的关注列表
        jedis.sadd("user:" + followUserId + ":followers", userId); // 被关注用户的粉丝列表
    }

    //获取某用户关注的用户列表
    public Set<String> getFollowing(String userId) {
        return jedis.smembers("user:" + userId + ":following");
    }

    // 获取某用户的粉丝列表
    public Set<String> getFollowers(String userId) {
        return jedis.smembers("user:" + userId + ":followers");
    }

    public void close() {
        jedis.close();
    }

    public static void main(String[] args) {
        Four_Redis app = new Four_Redis();

        // 模拟用户关注关系
        app.followUser("张三", "二麻子");
        app.followUser("张三", "三顺子");
        app.followUser("二麻子", "三顺子");
        app.followUser("三顺子", "张三");

        // 获取用户关注的列表
        System.out.println("张三关注的用户: " + app.getFollowing("张三"));
        System.out.println("二麻子关注的用户: " + app.getFollowing("二麻子"));

        // 获取用户的粉丝列表
        System.out.println("三顺子的粉丝: " + app.getFollowers("三顺子"));
        System.out.println("张三的粉丝: " + app.getFollowers("张三"));

        // 关闭连接
        app.close();
    }
}

(2)运行结果

4、连接Redis时报错

报错信息:

DENIED Redis is running in protected mode because protected mode is enabled, no bind address was specified, no authentication password is requested to clients. In this mode connections are only accepted from the loopback interface. If you want to connect from external computers to Redis you may adopt one of the following solutions: 1) Just disable protected mode sending the command 'CONFIG SET protected-mode no' from the loopback interface by connecting to Redis from the same host the server is running, however MAKE SURE Redis is not publicly accessible from internet if you do so. Use CONFIG REWRITE to make this change permanent. 2) Alternatively you can just disable the protected mode by editing the Redis configuration file, and setting the protected mode option to 'no', and then restarting the server. 3) If you started the server manually just for testing, restart it with the '--protected-mode no' option. 4) Setup a bind address or an authentication password. NOTE: You only need to do one of the above things in order for the server to start accepting connections from the outside.

Redis正在运行在保护模式下,保护模式默认情况下只允许本地回环接口访问,不允许外部机器直接连接。

方法一:禁用保护模式。

(1)使用命令修改

Shell进入Redis后,执行命令CONFIG SET protected-mode no禁用保护模式,可以执行命令CONFIG REWRITE使更改永久生效。

(2)修改配置文件

打开 Redis 的配置文件,作者的配置文件在/software/redis中,找到protected-mode yes,修改为protected-mode no,保存后重新启动Redis :sudo systemctl restart redis。

方法二:取消Redis占用

ps aux | grep redis查看Redis进程使用。作者这里显示的结果如下

root   3550  0.0  0.2 145412  2108 ?    Ssl  11:27   0:00 redis-server *:6379表示一个运行中的 Redis 服务进程。

root:运行该进程的用户。这里显示的是 root,说明 Redis 是以 root 用户权限启动的(不推荐在生产环境中以 root 用户运行服务,最好用一个专门的用户来运行)。

3550:进程 ID(PID)。每个进程在系统中都有唯一的 PID,可以通过这个数字操作或监控这个进程(比如使用 kill 命令终止进程)。

0.0:该进程的 CPU 使用率(%CPU)。这里显示 0.0%,说明 Redis 当前几乎没有占用 CPU。

0.2:该进程的内存使用率(%MEM)。这里显示 0.2%,说明 Redis 只占用了系统少量内存。

145412:虚拟内存大小(VSZ,单位为 KB)。表示 Redis 服务使用的总虚拟内存量,这包括了被分配但未实际使用的内存。

2108:常驻内存大小(RSS,单位为 KB)。表示 Redis 实际占用的物理内存。

?:TTY(终端)。? 表示这个进程不是由终端直接启动的,而是一个后台服务(守护进程)。

Ssl:进程的状态信息:

S:表示进程处于休眠状态(sleeping)。

s:表示进程是一个会话领导进程。

l:表示进程有多线程(使用 pthread)。

11:27:进程启动的时间。这表明该进程在当天的 11:27 启动。

0:00:该进程累计的 CPU 使用时间。这里表示该进程自启动以来几乎没有消耗 CPU 时间。

redis-server *:6379:进程启动的命令及参数:

redis-server:表示这是 Redis 服务器的主进程。

*:表示 Redis 绑定的网络接口为所有地址(即 0.0.0.0),可以接受来自外部的连接。

6379:表示 Redis 服务监听的端口号,6379 是 Redis 默认端口。

root       3681  0.0  0.0 112824   988 pts/0    R+   11:35   0:00 grep --color=autoredis

显示的是 grep redis 命令本身的进程信息,因为 ps aux 的结果也包含了正在运行的 grep 命令进程。

这里需要关闭Redis进程,并重启服务。


http://www.kler.cn/a/514166.html

相关文章:

  • SentencePiece和 WordPiece tokenization 的含义和区别
  • Node.js HTTP模块详解:创建服务器、响应请求与客户端请求
  • python进程池、线程池
  • 【RAG落地利器】向量数据库Chroma入门教程
  • Android SystemUI——CarSystemBar车载状态栏(九)
  • vue3 通过ref 进行数据响应
  • OneData体系架构详解
  • react中hooks之 React 19 新 Hooks useActionState useFormStatus用法总结
  • js重要知识点
  • MySQL入门(数据库、数据表、数据、字段的操作以及查询相关sql语法)
  • SQL中字符串截取函数(substring)
  • 解决 PostgreSQL 中创建 TimescaleDB 扩展的字符串错误
  • 分布式系统架构8:分布式缓存
  • SpringMVC新版本踩坑[已解决]
  • 2025年01月20日Github流行趋势
  • 连接 OpenAI 模型:基础操作
  • LatentSync本地部署教程:基于音频精准生成唇形高度同步视频
  • C#与AI的共同发展
  • list底层实现细节
  • 数据清洗新利器:自动化数据清洗工具的探秘
  • 我在广州学Mysql 系列——触发器的使用
  • AG32 FPGA 的 Block RAM 资源:M9K 使用
  • Go语言如何实现限制用户 1 分钟内最多请求 1000 次?
  • PHP礼品兑换系统小程序
  • 【漫话机器学习系列】054.极值(Extrema)
  • 接口(1)