Error processing condition on org.springframework.boot.autoconfigure.data.web.XXX

本文详细介绍了在SpringBoot项目中整合Redis时遇到的错误及其解决方法,包括配置依赖、配置文件设置、Redis配置类编写及编码示例,最后分析了运行时报错的原因和解决步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在尝试使用Redis存储用户信息的时候,加入Redis依赖并编码之后,SpringBoot项目启动报错如下:
1) 添加依赖:

<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

2. 添加配置文件::在resource下新建conf.之后新建redis配置文件

#Matser的ip地址
redis.hostName=localhost
#端口号
redis.port=6379
#如果有密码
#redis.password=123456
#客户端超时时间单位是毫秒 默认是2000
redis.timeout=10000
#最大空闲数
redis.maxIdle=300  
#连接池的最大数据库连接数。设为0表示无限制,如果是jedis 2.4以后用redis.maxTotal
#redis.maxActive=600
#控制一个pool可分配多少个jedis实例,用来替换上面的redis.maxActive,如果是jedis 2.4以后用该属性
redis.maxTotal=1000  
#最大建立连接等待时间。如果超过此时间将接到异常。设为-1表示无限制。
redis.maxWaitMillis=1000  
#连接的最小空闲时间 默认1800000毫秒(30分钟)
redis.minEvictableIdleTimeMillis=300000  
#每次释放连接的最大数目,默认3
redis.numTestsPerEvictionRun=1024  
#逐出扫描的时间间隔(毫秒) 如果为负数,则不运行逐出线程, 默认-1
redis.timeBetweenEvictionRunsMillis=30000  
#是否在从池中取出连接前进行检验,如果检验失败,则从池中去除连接并尝试取出另一个
redis.testOnBorrow=true  
#在空闲时检查有效性, 默认false
redis.testWhileIdle=true  

3.创建redis配置类*:

@Configuration
@AutoConfigureAfter(RedisAutoConfiguration.class)
public class RedisConfig {

    //Redis配置文件需要序列化
    @Bean
    public RedisTemplate<String, Serializable> redisCacheTemplate(LettuceConnectionFactory redisConnectionFactory) {
        RedisTemplate<String, Serializable> template = new RedisTemplate<>();
        template.setKeySerializer(new StringRedisSerializer());
        template.setValueSerializer(new GenericJackson2JsonRedisSerializer());
        template.setConnectionFactory(redisConnectionFactory);
        return template;
    }
}

4.编码:

....
@Autowired
    private RedisTemplate redisTemplate;
.......    
//方法内--存:
redisTemplate.opsForValue().set("id",openId);

//取
log.info("当前用户的信息是:"+redisTemplate.opsForValue().get(key));    

5.运行报错

java.lang.IllegalStateException: Error processing condition on org.springframework.boot.autoconfigure.data.web.SpringDataWebAutoConfiguration.pageableCustomizer
	...
Caused by: java.lang.ClassNotFoundException: com.fasterxml.jackson.databind.ObjectMapper
	...

2019-12-24 11:28:27.163  INFO 14684 --- [           main] ConfigServletWebServerApplicationContext : Closing org.springframework.boot.web.servlet.context.AnnotationConfigServletWebServerApplicationContext@2eee3069: startup date [Tue Dec 24 11:28:25 CST 2019]; root of context hierarchy

java.lang.IllegalStateException: Failed to introspect Class [org.springframework.data.web.config.SpringDataWebConfiguration] from ClassLoader [sun.misc.Launcher$AppClassLoader@18b4aac2]
...

6解决:
根据提示去查找依赖中的相关配置,发现自己原来的相关依赖如下:

 <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.fasterxml.jackson.core</groupId>
                    <artifactId>jackson-databind</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
	......
	//Redis相关配置
	<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis</artifactId>
        </dependency>

注意 : 标签 exclusion 的作用是引入spring-boot-starter-web的jar包的时候不需要引入它下面的com.fasterxml.jackson.core包,这里我们将 exclusions这段注释掉就不再报错,就是选择在依赖spring-boot-starter-web的同时依赖他下面的jackson-databind.
原因尚未知晓

### Spring Boot Actuator Web Server 配置错误解决方案 当处理与 Spring Boot Actuator 的 Web Server 自动配置相关的错误时,通常涉及以下几个方面: #### 1. **自动配置类的作用** Spring Boot 提供了一组用于自动配置的类来支持不同的模板引擎和功能模块。这些类包括但不限于 `WebMvcAutoConfiguration`、`ThymeleafAutoConfiguration` 和其他特定于视图技术的自动配置类[^1]。如果某些依赖未正确加载或存在冲突,则可能导致条件评估失败。 对于 Web Server 的自动配置,Spring Boot 使用了基于条件的机制 (`@ConditionalOn...`) 来决定哪些组件应该被启用。例如,在启动过程中可能会触发类似于以下的日志消息: ```plaintext ConditionEvaluationReport: Negative matches: - VelocityAutoConfiguration did not match due to missing velocity dependency. Positive matches: - WebMvcAutoConfiguration matched because a specific bean was found. ``` 这表明某些自动配置可能由于缺少必要的依赖项而未能生效。 --- #### 2. **常见错误及其原因分析** ##### (a) 缺少必要依赖 如果项目中缺失某些关键库(如嵌入式服务器 Tomcat 或 Jetty),则会引发异常。例如,Tomcat 是默认使用的 Servlet 容器,但如果移除了其依赖却没有替换为其他容器,则会导致无法初始化 Web Server。 解决方法是在项目的构建文件中显式声明所需的依赖关系。以下是 Maven 中的一个例子: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- 如果不希望使用 Tomcat --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jetty</artifactId> </dependency> ``` ##### (b) 不兼容版本 确保所使用的 Spring Boot 版本与其子模块保持一致。不同版本之间可能存在 API 变更或者行为差异,从而影响自动配置逻辑。 验证当前正在运行的应用程序是否符合官方推荐的最佳实践,并升级到最新稳定版以获得更好的支持。 ##### (c) 错误的属性设置 Actuator 功能通过应用属性文件中的参数控制其行为模式。假如设置了不当选项(比如禁用了整个 MVC 层面的支持却仍尝试访问 RESTful 接口),同样会造成矛盾情况发生。 检查 `application.properties` 或者 YAML 文件里是否存在类似下面这样的条目干扰正常流程执行: ```properties management.endpoints.web.exposure.include=health,info server.port=8080 ``` 上述片段展示了如何暴露健康状态检查端点以及指定监听端口号;调整它们之前需仔细权衡需求后再做修改以免引入不必要的复杂度。 --- #### 3. **调试技巧** 为了更好地定位问题所在位置,可以开启详细的日志记录以便观察内部决策过程。具体做法如下所示: ```java logging.level.org.springframework.boot.autoconfigure=DEBUG ``` 此命令会让框架打印更多关于各个阶段进展的信息出来帮助开发者快速找到症结所在之处。 另外还可以利用内置工具——Endpoint `/conditions` 查看实际匹配状况报告详情。只需发送 HTTP 请求至对应 URL 即可获取结构化数据形式呈现的结果集。 ```bash curl http://localhost:8080/actuator/conditions ``` --- #### 4. **总结建议** 综上所述,针对 spring boot actuate autoconfigure web server error 进行排查时应重点关注三个方面:一是确认基础环境搭建无误即所需外部资源均已妥善准备完毕;二是审查代码实现部分是否有违背既定规则的地方;三是借助辅助手段收集充分证据支撑最终结论得出合理解释并采取相应措施加以修正完善整体架构设计思路方向更加清晰明确高效实用性强易于维护扩展性强等特点优势明显值得推广普及开来让更多人受益匪浅收获满满成就感爆棚! ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值