苍穹外卖05 Redis常用命令&&在Java中操作Redis_Spring Data Redis使用方式&店铺营业状态设置

2-8 Redis常用命令

02 02-Redis入门

ctrl+c :快捷结束进程

配置密码:

以后再启动客户端的时候就需要进行密码的配置了。使用-a

在图形化界面中创建链接:

启动成功了。

03 03-Redis常用数据类型

04 04-Redis常用命令_字符串操作命令 

05 05-Redis常用命令_哈希操作命令

06 06-Redis常用命令_列表操作命令

07 07-Redis常用命令_集合操作命令

08 08-Redis常用命令_有序集合操作命令

09 09-Redis常用命令_通用命令

2-9 在Java中操作Redis_Spring Data Redis使用方法 操作步骤

02 11-在Java中操作Redis_Spring Data Redis使用方式_环境搭建

package com.sky.config;

import lombok.extern.slf4j.Slf4j;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.serializer.StringRedisSerializer;

@Configuration
@Slf4j
public class RedisConfigation {

    @Bean
    public RedisTemplate redisTemplate(RedisConnectionFactory redisConnectionFactory) {
        log.info("开始创建redis模板对象...");
        RedisTemplate redisTemplate = new RedisTemplate();
        // 设置连接工厂
        redisTemplate.setConnectionFactory(redisConnectionFactory);
        // 设置key序列化器
        redisTemplate.setKeySerializer(new StringRedisSerializer());
        return redisTemplate;
    }
}

用这五个对象来操作redis当中的数据。

操作字符串类型的数据:

操作字符串功能测试代码如下:

/**
     * 测试redis操作字符串
     */
    @Test
    public void testString() {
        //set
        redisTemplate.opsForValue().set("city", "北京");//设定key的值
        //get
        String city = (String) redisTemplate.opsForValue().get("city");//获取key的值
        System.out.println(city);
        // setx
        redisTemplate.opsForValue().set("code", "123",3, TimeUnit.MINUTES);//设定key的值,并且设定过期时间
        // setnx
        redisTemplate.opsForValue().setIfAbsent("lock","1");//设定key的值,如果key不存在则设置成功,如果key已存在则设置失败
        redisTemplate.opsForValue().setIfAbsent("lock","2");//校验组

    }

操作哈希类型的数据:

操作哈希表代码实现如下:

   @Test
    public void testHash() {

        HashOperations hashOperations =redisTemplate.opsForHash();
        //hset   将哈希表key中的字段field的值设为value
        hashOperations.put("100","name","tom");
        hashOperations.put("100","age","20");
        //hget   获取存储在指定哈希表中指定字段的值
        String name = (String)hashOperations.get("100", "name");
        System.out.println(name);
        //hkey   获取指定哈希表所有字段
        Set keys = hashOperations.keys("100");
        System.out.println(keys);
        //hvals   获取指定哈希表中所有值
        List values = hashOperations.values("100");
        System.out.println(values);
        //hdel   删除指定哈希表字段
        hashOperations.delete("100","age");
    }

其他类型的操作效果大差不差,就是注意好引用参数的形参限制就好了。不过多赘述,用到了多用几次就熟练了。

06 15-店铺营业状态设置_需求分析和设计

由于下方两个接口你只需要调用一个参数status ,又没必要为了这一个参数创建一张表,所以我们可以选择将这个参数创建在redis当中。

07 16-店铺营业状态设置_代码开发

三个接口实现如下:

package com.sky.controller.admin;

import com.sky.result.Result;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PutMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@Slf4j
@RestController
@ApiOperation("店铺管理")
@RequestMapping("/admin/shop")
public class ShopController {

    @Autowired
    private RedisTemplate redisTemplate;

    /**
     * 设置店铺的营业状态
     * @param status
     * @return
     */
    @PutMapping("/{status}")
    @ApiOperation("设置店铺的营业状态")
    public Result setStatus(@PathVariable Integer status){
        log.info("设置店铺的营业状态为:{}", status==1? "营业中":"打烊中");
        redisTemplate.opsForValue().set("SHOP_STATUS", status);
        return Result.success();
    }

    /**
     *  获取营业状态
     * @return
     */
    @RequestMapping("/status")
    @ApiOperation("获取店铺的营业状态")
    public Result<Integer> getStatus(){
        Integer status = (Integer) redisTemplate.opsForValue().get("SHOP_STATUS");
        log.info("获取营业状态为:{}", status==1? "营业中":"打烊中");
        return Result.success(status);
    }
}

package com.sky.controller.user;


import com.sky.result.Result;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@ApiOperation("店铺相关接口")
@RestController
@RequestMapping("/user/shop")
@Slf4j
public class ShopController {

    @Autowired
    private RedisTemplate redisTemplate;


    /**
     * 获取店铺的营业状态
     * @return
     */
    @ApiOperation("获取店铺的营业状态")
    @RequestMapping("/status")
    public Result<Integer> getStatus(){
        Integer status = (Integer) redisTemplate.opsForValue().get("SHOP_STATUS");
        log.info("获取营业状态为:{}", status==1? "营业中":"打烊中");
        return Result.success(status);
    }
}

测试成功!

### Spring Data Redis 连接失败解决方案 当遇到 `org.springframework.data.redis.RedisConnectionFailureException: Unable to connect to Redis` 的异常时,可能的原因包括但不限于网络连接问题、Redis配置不当以及防火墙阻止等问题。 #### 一、验证网络连接状态 确保客户端可以访问目标机器上的Redis服务。可以通过telnet命令来简单测试与Redis服务器之间的连通性[^2]: ```bash telnet localhost 6379 ``` 如果无法建立连接,则可能是由于端口未开放或是IP地址不正确引起的。 #### 二、检查Redis配置文件 对于由保护模式引发的连接问题,在确认安全性的前提下可考虑调整配置参数以允许远程接入。具体操作为编辑Redis配置文件(一般路径为 `/etc/redis/redis.conf`),执行以下更改[^3]: - 修改绑定地址:取消原有仅限于本机回环接口(`bind 127.0.0.1`)的限制,改为监听所有网卡(`bind 0.0.0.0`) ```properties # bind 127.0.0.1 bind 0.0.0.0 ``` - 设置保护模式开关:将`protected-mode yes`更改为`no`从而关闭此特性 ```properties protected-mode no ``` 完成上述改动之后记得保存文件并重启Redis实例以便使新设定生效: ```bash sudo systemctl restart redis-server ``` 另外需要注意的是,出于安全性考量建议生产环境中谨慎对待此类变更,并尽可能采取其他方式设置密码认证等增强防护措施。 #### 三、排查防火墙规则 部分情况下即使完成了以上两步仍然会遭遇同样的错误提示,这时应该查看是否存在防火墙策略阻挡了外部请求到达指定端口号的情况。如果是Linux系统的话,可通过iptables或firewalld工具来进行相应处理;而对于Windows Server而言则需前往高级安全Windows Defender防火墙界面内添加例外规则放行特定流量[^4]。 最后提醒各位开发者朋友务必重视数据存储组件的安全管理,在满足业务需求的同时也要保障系统的稳定性和可靠性!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值