爆款云主机2核4G限时秒杀,88元/年起!
查看详情

活动

天翼云最新优惠活动,涵盖免费试用,产品折扣等,助您降本增效!
热门活动
  • 618智算钜惠季 爆款云主机2核4G限时秒杀,88元/年起!
  • 免费体验DeepSeek,上天翼云息壤 NEW 新老用户均可免费体验2500万Tokens,限时两周
  • 云上钜惠 HOT 爆款云主机全场特惠,更有万元锦鲤券等你来领!
  • 算力套餐 HOT 让算力触手可及
  • 天翼云脑AOne NEW 连接、保护、办公,All-in-One!
  • 中小企业应用上云专场 产品组合下单即享折上9折起,助力企业快速上云
  • 息壤高校钜惠活动 NEW 天翼云息壤杯高校AI大赛,数款产品享受线上订购超值特惠
  • 天翼云电脑专场 HOT 移动办公新选择,爆款4核8G畅享1年3.5折起,快来抢购!
  • 天翼云奖励推广计划 加入成为云推官,推荐新用户注册下单得现金奖励
免费活动
  • 免费试用中心 HOT 多款云产品免费试用,快来开启云上之旅
  • 天翼云用户体验官 NEW 您的洞察,重塑科技边界

智算服务

打造统一的产品能力,实现算网调度、训练推理、技术架构、资源管理一体化智算服务
智算云(DeepSeek专区)
科研助手
  • 算力商城
  • 应用商城
  • 开发机
  • 并行计算
算力互联调度平台
  • 应用市场
  • 算力市场
  • 算力调度推荐
一站式智算服务平台
  • 模型广场
  • 体验中心
  • 服务接入
智算一体机
  • 智算一体机
大模型
  • DeepSeek-R1-昇腾版(671B)
  • DeepSeek-R1-英伟达版(671B)
  • DeepSeek-V3-昇腾版(671B)
  • DeepSeek-R1-Distill-Llama-70B
  • DeepSeek-R1-Distill-Qwen-32B
  • Qwen2-72B-Instruct
  • StableDiffusion-V2.1
  • TeleChat-12B

应用商城

天翼云精选行业优秀合作伙伴及千余款商品,提供一站式云上应用服务
进入甄选商城进入云市场创新解决方案
办公协同
  • WPS云文档
  • 安全邮箱
  • EMM手机管家
  • 智能商业平台
财务管理
  • 工资条
  • 税务风控云
企业应用
  • 翼信息化运维服务
  • 翼视频云归档解决方案
工业能源
  • 智慧工厂_生产流程管理解决方案
  • 智慧工地
建站工具
  • SSL证书
  • 新域名服务
网络工具
  • 翼云加速
灾备迁移
  • 云管家2.0
  • 翼备份
资源管理
  • 全栈混合云敏捷版(软件)
  • 全栈混合云敏捷版(一体机)
行业应用
  • 翼电子教室
  • 翼智慧显示一体化解决方案

合作伙伴

天翼云携手合作伙伴,共创云上生态,合作共赢
天翼云生态合作中心
  • 天翼云生态合作中心
天翼云渠道合作伙伴
  • 天翼云代理渠道合作伙伴
天翼云服务合作伙伴
  • 天翼云集成商交付能力认证
天翼云应用合作伙伴
  • 天翼云云市场合作伙伴
  • 天翼云甄选商城合作伙伴
天翼云技术合作伙伴
  • 天翼云OpenAPI中心
  • 天翼云EasyCoding平台
天翼云培训认证
  • 天翼云学堂
  • 天翼云市场商学院
天翼云合作计划
  • 云汇计划
天翼云东升计划
  • 适配中心
  • 东升计划
  • 适配互认证

开发者

开发者相关功能入口汇聚
技术社区
  • 专栏文章
  • 互动问答
  • 技术视频
资源与工具
  • OpenAPI中心
开放能力
  • EasyCoding敏捷开发平台
培训与认证
  • 天翼云学堂
  • 天翼云认证
魔乐社区
  • 魔乐社区

支持与服务

为您提供全方位支持与服务,全流程技术保障,助您轻松上云,安全无忧
文档与工具
  • 文档中心
  • 新手上云
  • 自助服务
  • OpenAPI中心
定价
  • 价格计算器
  • 定价策略
基础服务
  • 售前咨询
  • 在线支持
  • 在线支持
  • 工单服务
  • 建议与反馈
  • 用户体验官
  • 服务保障
  • 客户公告
  • 会员中心
增值服务
  • 红心服务
  • 首保服务
  • 客户支持计划
  • 专家技术服务
  • 备案管家

了解天翼云

天翼云秉承央企使命,致力于成为数字经济主力军,投身科技强国伟大事业,为用户提供安全、普惠云服务
品牌介绍
  • 关于天翼云
  • 智算云
  • 天翼云4.0
  • 新闻资讯
  • 天翼云APP
基础设施
  • 全球基础设施
  • 信任中心
最佳实践
  • 精选案例
  • 超级探访
  • 云杂志
  • 分析师和白皮书
  • 天翼云·创新直播间
市场活动
  • 2025智能云生态大会
  • 2024智算云生态大会
  • 2023云生态大会
  • 2022云生态大会
  • 天翼云中国行
天翼云
  • 活动
  • 智算服务
  • 产品
  • 解决方案
  • 应用商城
  • 合作伙伴
  • 开发者
  • 支持与服务
  • 了解天翼云
      • 文档
      • 控制中心
      • 备案
      • 管理中心

      布隆过滤器介绍及原理、集成Redisson布隆过滤器解决Redis缓存穿透问题

      首页 知识中心 软件开发 文章详情页

      布隆过滤器介绍及原理、集成Redisson布隆过滤器解决Redis缓存穿透问题

      2023-05-18 06:37:36 阅读次数:144

      Redisson,SpringBoot

      (目录)


      布隆过滤器

      1 什么是布隆过滤器

      介绍布隆过滤器之前,先介绍一下哈希函数,我们在Java中的HashMap,HashSet也接触过hashcode()这个函数。

      哈希函数指将哈希表中元素的关键键值通过一定的函数关系映射为元素存储位置的函数。

      哈希函数的特点:

      • 如果根据同一个哈希函数得到的哈希值不同,那么这两个哈希值的原始输入值肯定不同
      • 如果根据同一个哈希函数得到的两个哈希值相等,两个哈希值的原始输入值有可能相等,有可能不相等

      那什么是布隆过滤器?

      布隆过滤器实际上是一个非常长的二进制向量(bitmap)和一系列随机哈希函数。

      优缺点

      优点:

      • 布隆过滤器存储空间和插入/查询时间都是常数
      • Hash函数相互之间没有关系,方便由硬件并行实现
      • 布隆过滤器不需要存储元素本身,在某些对保密要求非常严格的场合有优势
      • 布隆过滤器可以表示全集,其它任何数据结构都不能

      缺点:

      • 有一定的误判率

      常见的补救办法是建立一个小的白名单,存储那些可能被误判的元素。但是如果元素数量太少,使用散列表足矣。

      • 一般情况下不能从布隆过滤器中删除元素

      我们很容易想到把位列阵变成整数数组,每插入一个元素相应的计数器加1, 这样删除元素时将计数器减掉就可以了。然而要保证安全的删除元素并非如此简单。首先我们必须保证删除的元素的确在布隆过滤器里面,这一点单凭这个过滤器是无法保证的。另外计数器回绕也会造成问题。


      2 布隆过滤器的作用

      布隆过滤器可以用于检索一个元素是否在一个集合中,常用于解决如下问题

      1. 解决Redis缓存穿透
      2. 邮件过滤,使用布隆过滤器来做邮件黑名单过滤
      3. 解决视频推荐过的不再推荐

      缓存穿透攻击

      缓存穿透攻击:

      恶意用户在短时内大量查询不存在的数据,导致大量请求被送达数据库进行查询,当请求数量超过数据库负载上限时,使系统缓存穿透攻击是指恶意用户在短时内大量查询不存在的数据,导致大量请求被送达数据库进行查询,当请求数量超过数据库负载上限时,使系统响应出现高延迟甚至瘫痪的攻击行为。响应出现高延迟甚至瘫痪的攻击行为.


      3 布隆过滤器的基本原理

      • 首先,建立一个二进制向量,并将所有位设置为0。
      • 然后,选定K个散列函数,用于对元素进行K次散列,计算向量的位下标。
      • 添加元素:当添加一个元素到集合中时,通过K个散列函数分别作用于元素,生成K个值作为下标,并将向量的相应位设置为1。
      • 检查元素:
      1. 如果要检查一个元素是否存在集合中,用同样的散列方法,生成K个下标,并检查向量的相应位是否全部是1。
      2. 如果全为1,则该元素很可能在集合中
      3. 否则(只要有1个或以上的位为0),该元素肯定不在集合中。

      布隆过滤器介绍及原理、集成Redisson布隆过滤器解决Redis缓存穿透问题


      4. 减少布隆过滤器误判的措施

      1. 增加二进制数组位数
      2. 增加 Hash 次数

      5 布隆过滤器再项目中使用流程

      布隆过滤器介绍及原理、集成Redisson布隆过滤器解决Redis缓存穿透问题

      布隆过滤器介绍及原理、集成Redisson布隆过滤器解决Redis缓存穿透问题

      核心代码:

      布隆过滤器介绍及原理、集成Redisson布隆过滤器解决Redis缓存穿透问题


      6 布隆过滤器中内容被删除了怎么办?

      布隆过滤器因为某一位二进制可能被多个编号Hash引用,因此布隆过滤器无法直接处理删除数据的情况

      常见的解决方案如下:

      • 解决方案1:定时异步重建布隆过滤器

      • 解决方案2: 计数Bloom Fliter


      7 在Spring Boot中集成Redisson实现布隆过滤器

      7.1 添加redisson依赖

      <!--redisson-->
      <dependency>
      	<groupId>org.redisson</groupId>
      	<artifactId>redisson-spring-boot-starter</artifactId>
      	<version>3.17.0</version>
      </dependency>
      

      7.2 配置yml

      spring:
        datasource:
          username: xx
          password: xxxxxx
          driver-class-name: com.mysql.cj.jdbc.Driver
          url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=CTT
        cache:
          type: redis
        redis:
          database: 0
          port: 6379               # Redis服务器连接端口
          host: localhost          # Redis服务器地址
          password: xxxxxx         # Redis服务器连接密码(默认为空)
          timeout: 5000            # 超时时间
      

      7.3 配置RedissonConfig

      import com.fasterxml.jackson.annotation.JsonAutoDetect;
      import com.fasterxml.jackson.annotation.PropertyAccessor;
      import com.fasterxml.jackson.databind.ObjectMapper;
      import org.redisson.Redisson;
      import org.redisson.api.RedissonClient;
      import org.redisson.config.Config;
      import org.springframework.beans.factory.annotation.Value;
      import org.springframework.cache.CacheManager;
      import org.springframework.cache.annotation.EnableCaching;
      import org.springframework.context.annotation.Bean;
      import org.springframework.context.annotation.Configuration;
      import org.springframework.data.redis.cache.RedisCacheConfiguration;
      import org.springframework.data.redis.cache.RedisCacheManager;
      import org.springframework.data.redis.connection.RedisConnectionFactory;
      import org.springframework.data.redis.serializer.Jackson2JsonRedisSerializer;
      import org.springframework.data.redis.serializer.RedisSerializationContext;
      import org.springframework.data.redis.serializer.RedisSerializer;
      import org.springframework.data.redis.serializer.StringRedisSerializer;
      
      import java.time.Duration;
      import java.util.Random;
      
      @EnableCaching
      @Configuration
      public class RedissonConfig {
      
          @Value("")
          private String host;
      
          @Value("")
          private String port;
      
          @Value("")
          private String password;
      
      
          @Bean(destroyMethod = "shutdown")  // bean销毁时关闭Redisson实例,但不关闭Redis服务
          public RedissonClient redisson() {
              //创建配置
              Config config = new Config();
              /**
               *  连接哨兵:config.useSentinelServers().setMasterName("myMaster").addSentinelAddress()
               *  连接集群: config.useClusterServers().addNodeAddress()
               */
              config.useSingleServer()
                      .setAddress("redis://" + host + ":" + port)
                      .setPassword(password)
                      .setTimeout(5000);
              //根据config创建出RedissonClient实例
              return Redisson.create(config);
          }
      
          @Bean
          public CacheManager RedisCacheManager(RedisConnectionFactory factory) {
              RedisSerializer<String> redisSerializer = new StringRedisSerializer();
              Jackson2JsonRedisSerializer jackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer(Object.class);
              // 解决查询缓存转换异常的问题
              ObjectMapper om = new ObjectMapper();
              om.setVisibility(PropertyAccessor.ALL, JsonAutoDetect.Visibility.ANY);
              /**
               * 新版本中om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL)已经被废弃
               * 建议替换为om.activateDefaultTyping(LaissezFaireSubTypeValidator.instance, ObjectMapper.DefaultTyping.NON_FINAL)
               */
              om.enableDefaultTyping(ObjectMapper.DefaultTyping.NON_FINAL);
              jackson2JsonRedisSerializer.setObjectMapper(om);
              // 配置序列化解决乱码的问题
              RedisCacheConfiguration config = RedisCacheConfiguration.defaultCacheConfig()
                      // 设置缓存过期时间  为解决缓存雪崩,所以将过期时间加随机值
                      .entryTtl(Duration.ofSeconds(60 * 60 + new Random().nextInt(60 * 10)))
                      // 设置key的序列化方式
                      .serializeKeysWith(RedisSerializationContext.SerializationPair.fromSerializer(redisSerializer))
                      // 设置value的序列化方式
                      .serializeValuesWith(RedisSerializationContext.SerializationPair.fromSerializer(jackson2JsonRedisSerializer));
              // .disableCachingNullValues(); //为防止缓存击穿,所以允许缓存null值
              RedisCacheManager cacheManager = RedisCacheManager.builder(factory)
                      .cacheDefaults(config)
                      // 启用RedisCache以将缓存 put/evict 操作与正在进行的 Spring 管理的事务同步
                      .transactionAware()
                      .build();
              return cacheManager;
          }
      }
      
      

      7.4 工具类BloomFilterUtil

      import org.redisson.api.RBloomFilter;
      import org.redisson.api.RedissonClient;
      import org.springframework.stereotype.Component;
      
      import javax.annotation.Resource;
      
      @Component
      public class BloomFilterUtil {
      
          @Resource
          private RedissonClient redissonClient;
      
          /**
           * 创建布隆过滤器
           *
           * @param filterName         过滤器名称
           * @param expectedInsertions 预测插入数量
           * @param falsePositiveRate  误判率
           */
          public <T> RBloomFilter<T> create(String filterName, long expectedInsertions, double falsePositiveRate) {
              RBloomFilter<T> bloomFilter = redissonClient.getBloomFilter(filterName);
              bloomFilter.tryInit(expectedInsertions, falsePositiveRate);
              return bloomFilter;
          }
      }
      

      7.5 编写service实现层

      其它层正常编写即可,与之前并无差别,此处不再展示

      import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
      import com.company.springboot.entity.User;
      import com.company.springboot.mapper.UserMapper;
      import com.company.springboot.service.UserService;
      import com.company.springboot.util.BloomFilterUtil;
      import org.redisson.api.RBloomFilter;
      import org.redisson.api.RedissonClient;
      import org.redisson.client.codec.StringCodec;
      import org.springframework.cache.annotation.CacheEvict;
      import org.springframework.cache.annotation.CachePut;
      import org.springframework.cache.annotation.Cacheable;
      import org.springframework.stereotype.Service;
      
      import javax.annotation.PostConstruct;
      import javax.annotation.Resource;
      import java.util.List;
      import java.util.Random;
      import java.util.concurrent.TimeUnit;
      
      @Service
      public class UserServiceImpl extends ServiceImpl<UserMapper, User>
              implements UserService {
          // 预期插入数量
          static long expectedInsertions = 200L;
          // 误判率
          static double falseProbability = 0.01;
      
          // 非法请求所返回的JSON
          static String illegalJson = "[\"com.company.springboot.entity.User\",{\"id\":null,\"userName\":\"null\",\"sex\":null,\"age\":null}]";
      
          private RBloomFilter<Long> bloomFilter = null;
      
          @Resource
          private BloomFilterUtil bloomFilterUtil;
      
          @Resource
          private RedissonClient redissonClient;
      
          @Resource
          private UserMapper userMapper;
      
          @PostConstruct // 项目启动的时候执行该方法,也可以理解为在spring容器初始化的时候执行该方法
          public void init() {
              // 启动项目时初始化bloomFilter
              List<User> userList = this.list();
              bloomFilter = bloomFilterUtil.create("idWhiteList", expectedInsertions, falseProbability);
              for (User user : userList) {
                  bloomFilter.add(user.getId());
              }
          }
      
      
          @Cacheable(cacheNames = "user", key = "#id", unless = "#result==null")
          public User findById(Long id) {
              // bloomFilter中不存在该key,为非法访问
              if (!bloomFilter.contains(id)) {
                  System.out.println("所要查询的数据既不在缓存中,也不在数据库中,为非法key");
                     /**
                   * 设置unless = "#result==null"并在非法访问的时候返回null的目的是不将该次查询返回的null使用
                   * RedissonConfig-->RedisCacheManager-->RedisCacheConfiguration-->entryTtl设置的过期时间存入缓存。
                   *
                   * 因为那段时间太长了,在那段时间内可能该非法key又添加到bloomFilter,比如之前不存在id为1234567的用户,
                   * 在那段时间可能刚好id为1234567的用户完成注册,使该key成为合法key。
                   *
                   * 所以我们需要在缓存中添加一个可容忍的短期过期的null或者是其它自定义的值,使得短时间内直接读取缓存中的该值。
                   *
                   * 因为Spring Cache本身无法缓存null,因此选择设置为一个其中所有值均为null的JSON,
                   */
                  redissonClient.getBucket("user::" + id, new StringCodec()).set(illegalJson, new Random().nextInt(200) + 300, TimeUnit.SECONDS);
                  return null;
              }
              // 不是非法访问,可以访问数据库
              System.out.println("数据库中得到数据*****");
              return userMapper.selectById(id);
          }
      
          // 先执行方法体中的代码,成功执行之后删除缓存
          @CacheEvict(cacheNames = "user", key = "#id")
          public boolean delete(Long id) {
              // 删除数据库中具有的数据,就算此key从此之后不再出现,也不能从布隆过滤器删除
              return userMapper.deleteById(id) == 1;
          }
      
          // 如果缓存中先前存在,则更新缓存;如果不存在,则将方法的返回值存入缓存
          @CachePut(cacheNames = "user", key = "#user.id")
          public User update(User user) {
              userMapper.updateById(user);
              // 新生成key的加入布隆过滤器,此key从此合法,因为该更新方法并不更新id,所以也不会产生新的合法的key
              bloomFilter.add(user.getId());
              return user;
          }
      
          @CachePut(cacheNames = "user", key = "#user.id")
          public User insert(User user) {
              userMapper.insert(user);
              // 新生成key的加入布隆过滤器,此key从此合法
              bloomFilter.add(user.getId());
              return user;
          }
      }
      
      

      创建表sql

      CREATE TABLE `user`  (
        `id` bigint(20) NOT NULL AUTO_INCREMENT,
        `user_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NULL DEFAULT NULL COMMENT '用户名',
        `sex` tinyint(1) NULL DEFAULT NULL COMMENT '0 男 1 女',
        `age` int(11) NULL DEFAULT NULL COMMENT '年龄',
        PRIMARY KEY (`id`) USING BTREE
      ) ENGINE = InnoDB AUTO_INCREMENT = 104 CHARACTER SET = utf8 COLLATE = utf8_bin ROW_FORMAT = DYNAMIC;
      
      SET FOREIGN_KEY_CHECKS = 1;
      

      版权声明:本文内容来自第三方投稿或授权转载,原文地址:https://blog.51cto.com/panyujie/6081164,作者:Perceus,版权归原作者所有。本网站转在其作品的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如因作品内容、版权等问题需要同本网站联系,请发邮件至ctyunbbs@chinatelecom.cn沟通。

      上一篇:Java学习路线-:多线程的同步与死锁

      下一篇:iOS__上传应用到AppStore出现Authenticating with the iTunes store

      相关文章

      2025-04-22 09:27:28

      SpringBoot 自定义TaskExecutor线程池执行异步操作

      SpringBoot 自定义TaskExecutor线程池执行异步操作

      2025-04-22 09:27:28
      SpringBoot , 异步 , 线程 , 自定义
      2025-04-15 09:24:56

      探秘Redis分布式锁:实战与注意事项

      Redis的Watch命令可以实现乐观锁,这是一种保护数据完整性的机制。在分布式环境中,当多个客户端并发地操作相同的键时,乐观锁有助于防止数据竞争和冲突。

      2025-04-15 09:24:56
      Redis , Redisson , 分布式 , 实例 , 客户端 , 获取
      2025-04-11 07:12:29

      基于主流SpringBoot进行JavaWeb开发的学习路线

      基于主流SpringBoot进行JavaWeb开发的学习路线

      2025-04-11 07:12:29
      Java , SpringBoot , Vue , Web , 学习 , 开发 , 接口
      2025-03-10 09:52:02

      毕设--基于 SpringBoot 垃圾分类网站设计与实现

      毕设--基于 SpringBoot 垃圾分类网站设计与实现

      2025-03-10 09:52:02
      Java , SpringBoot , Web , 垃圾 , 模板
      2025-03-05 09:19:11

      RedLock 与 Redisson 实现分布式锁---算法与应用

      在分布式系统中,分布式锁是确保数据一致性和防止资源冲突的重要机制。随着应用程序的规模扩大和复杂性增加,如何有效地管理分布式锁成为一个关键问题。

      2025-03-05 09:19:11
      Redis , Redisson , 分布式 , 客户端 , 时间 , 获取
      2025-03-04 09:07:50

      SpringBoot的事件监听使用

      SpringBoot的事件监听使用

      2025-03-04 09:07:50
      SpringBoot , 事件 , 注解 , 监听
      2024-12-24 10:19:23

      Redisson分布式锁主从一致性问题解决

      联锁(RedissonMultiLock)对象可以将多个RLock对象关联为一个联锁,实现加锁和解锁功能。每个RLock对象实例可以来自于不同的Redisson实例。

      2024-12-24 10:19:23
      Redis , Redisson , 分布式 , 死锁
      2024-12-20 07:55:14

      SpringBoot系列之切换log4j日志框架

      SpringBoot系列之切换log4j日志框架

      2024-12-20 07:55:14
      jar , log4j , logback , SpringBoot , 日志
      2024-12-17 08:26:04

      Redis 实现管道(Pipeline)

      在 SpringBoot 服务中通过整合 Redis 实现管道(Pipeline)可以提高 Redis 的性能和吞吐量。

      2024-12-17 08:26:04
      Redis , SpringBoot , 使用 , 函数 , 回调 , 管道
      2024-12-06 06:40:56

      基于SpringBoot+Vue的宠物领养饲养交流管理平台设计与实现

      基于SpringBoot+Vue的宠物领养饲养交流管理平台设计与实现

      2024-12-06 06:40:56
      SpringBoot
      查看更多
      推荐标签

      作者介绍

      天翼云小翼
      天翼云用户

      文章

      33561

      阅读量

      5266114

      查看更多

      最新文章

      SpringBoot 自定义TaskExecutor线程池执行异步操作

      2025-04-22 09:27:28

      基于主流SpringBoot进行JavaWeb开发的学习路线

      2025-04-11 07:12:29

      毕设--基于 SpringBoot 垃圾分类网站设计与实现

      2025-03-10 09:52:02

      SpringBoot的事件监听使用

      2025-03-04 09:07:50

      Redis 实现管道(Pipeline)

      2024-12-17 08:26:04

      基于SpringBoot+Vue的宠物领养饲养交流管理平台设计与实现

      2024-12-06 06:40:56

      查看更多

      热门文章

      SpringBoot 单元测试(三十六)

      2024-09-25 10:14:09

      Ajax提交数据SpringBoot后台报错“HttpMessageNotReadableException: JSON parse error: Cannot construct instance“

      2023-06-13 08:29:06

      AOP 中 获取常见的各种参数方法合集

      2023-05-15 10:01:00

      Spring Boot filter

      2024-09-25 10:14:21

      Spring Boot API 的 Controller 如何获得发送的 JSON 数据

      2023-06-28 09:05:02

      Spring Boot启动Tomcat端口占用

      2023-04-06 06:35:43

      查看更多

      热门标签

      java Java python 编程开发 代码 开发语言 算法 线程 Python html 数组 C++ 元素 javascript c++
      查看更多

      相关产品

      弹性云主机

      随时自助获取、弹性伸缩的云服务器资源

      天翼云电脑(公众版)

      便捷、安全、高效的云电脑服务

      对象存储

      高品质、低成本的云上存储服务

      云硬盘

      为云上计算资源提供持久性块存储

      查看更多

      随机文章

      白话OAuth2用户认证及鉴权标准流程

      SpringBoot创建子项目继承父项目报错【<packaging>pom</packaging>】

      如何在SpringBoot项目上让接口返回数据脱敏,一个注解即可

      SpringBoot配置文件敏感信息加密(四十六)

      SpringBoot-RabbitMQ消息的消费与签收机制

      SpringBoot 允许跨域

      • 7*24小时售后
      • 无忧退款
      • 免费备案
      • 专家服务
      售前咨询热线
      400-810-9889转1
      关注天翼云
      • 旗舰店
      • 天翼云APP
      • 天翼云微信公众号
      服务与支持
      • 备案中心
      • 售前咨询
      • 智能客服
      • 自助服务
      • 工单管理
      • 客户公告
      • 涉诈举报
      账户管理
      • 管理中心
      • 订单管理
      • 余额管理
      • 发票管理
      • 充值汇款
      • 续费管理
      快速入口
      • 天翼云旗舰店
      • 文档中心
      • 最新活动
      • 免费试用
      • 信任中心
      • 天翼云学堂
      云网生态
      • 甄选商城
      • 渠道合作
      • 云市场合作
      了解天翼云
      • 关于天翼云
      • 天翼云APP
      • 服务案例
      • 新闻资讯
      • 联系我们
      热门产品
      • 云电脑
      • 弹性云主机
      • 云电脑政企版
      • 天翼云手机
      • 云数据库
      • 对象存储
      • 云硬盘
      • Web应用防火墙
      • 服务器安全卫士
      • CDN加速
      热门推荐
      • 云服务备份
      • 边缘安全加速平台
      • 全站加速
      • 安全加速
      • 云服务器
      • 云主机
      • 智能边缘云
      • 应用编排服务
      • 微服务引擎
      • 共享流量包
      更多推荐
      • web应用防火墙
      • 密钥管理
      • 等保咨询
      • 安全专区
      • 应用运维管理
      • 云日志服务
      • 文档数据库服务
      • 云搜索服务
      • 数据湖探索
      • 数据仓库服务
      友情链接
      • 中国电信集团
      • 189邮箱
      • 天翼企业云盘
      • 天翼云盘
      ©2025 天翼云科技有限公司版权所有 增值电信业务经营许可证A2.B1.B2-20090001
      公司地址:北京市东城区青龙胡同甲1号、3号2幢2层205-32室
      • 用户协议
      • 隐私政策
      • 个人信息保护
      • 法律声明
      备案 京公网安备11010802043424号 京ICP备 2021034386号