欢迎访问悦橙教程(wld5.com),关注java教程。悦橙教程  java问答|  每日更新
页面导航 : > > 文章正文

Spring Boot 根据配置决定服务(集群、单机)是否使用某些主件的操作代码,

来源: javaer 分享于  点击 24049 次 点评:31

Spring Boot 根据配置决定服务(集群、单机)是否使用某些主件的操作代码,


目录
  • 解决文案
    • 方案1:使用条件注解 + 配置开关
    • 方案2:使用 Profile 区分
    • 方案3:编程式条件加载(更灵活)
    • 方案4:使用 @ConfigurationProperties 更优雅地管理配置
    • 最佳实践建议:

比如:在集群模式下,我想用 Nacos 组件,单机版不想用它。

server:
  name: VipSoft Server Dev
  port: 8193
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848     #注册中心地址(集群用,号分隔)
        cluster-name: DEFAULT              #可以通过集群名称区分不同的项目
        server-name: netty-service
        group-name: NETTY_GROUP
@Component
public class NettyServer {
    private static final Logger logger = LoggerFactory.getLogger(LoggerConfig.NETTY_LOGGER);
    @Value("${server.cloud.nacos.discovery.server-addr}")
    private String nacosServer;
    @Value("${server.cloud.nacos.discovery.server-name}")
    private String serviceName;
    @Value("${server.cloud.nacos.discovery.group-name}")
    private String groupName;
}
@Component
public class XXXService {
    @Autowired
    private NacosUtil nacosUtil;
}

解决文案

方案1:使用条件注解 + 配置开关

  • 修改 application.yml 添加启用开关:
server:
  name: Telemetry Cloud Server Dev
  port: 8193
  cloud:
    nacos:
      enabled: false  # 添加这个开关
      discovery:
        server-addr: 127.0.0.1:8848
        cluster-name: DEFAULT
        server-name: netty-service
        group-name: NETTY_GROUP
  • 修改 NettyServer 类:
@Component
@ConditionalOnProperty(name = "server.cloud.nacos.enabled", havingValue = "true")
public class NettyServer {
    // 原有代码...
}
@Component
public class XXXService {
    // 允许依赖不存在
    @Autowired(required = false)
    private NacosUtil nacosUtil;
}

方案2:使用 Profile 区分

  • 创建不同环境的配置文件:
  • application.yml (公共配置)
  • application-nacos.yml (Nacos相关配置)
  • application-standalone.yml (单机版配置)
  • application.yml 中激活不同配置:
spring:
  profiles:
    active: standalone # 或 nacos
  • 将 Nacos 相关配置移到 application-nacos.yml 中

方案3:编程式条件加载(更灵活)

  • 添加配置开关:
netty:
  mode: standalone # 或 cloud
  • 创建配置类:
@Configuration
public class NettyConfig {
    @Bean
    @ConditionalOnProperty(name = "netty.mode", havingValue = "cloud")
    public NettyServer nettyServer() {
        return new NettyServer();
    }
}

方案4:使用 @ConfigurationProperties 更优雅地管理配置

  • 创建配置类:
@ConfigurationProperties(prefix = "server.cloud.nacos.discovery")
public class NacosProperties {
    private boolean enabled;
    private String serverAddr;
    private String clusterName;
    private String serverName;
    private String groupName;
    // getters and setters
}
  • 修改 NettyServer:
@Component
public class NettyServer {
    private final NacosProperties nacosProperties;
    public NettyServer(NacosProperties nacosProperties) {
        this.nacosProperties = nacosProperties;
        if(nacosProperties.isEnabled()) {
            // 初始化Nacos相关逻辑
        }
    }
}

最佳实践建议:

推荐方案1或方案4:

  • 如果只是简单开关,用方案1最简单:
server:
  cloud:
    nacos:
      enabled: false
@Component
@ConditionalOnProperty(name = "server.cloud.nacos.enabled", matchIfMissing = false)
public class NettyServer {
    // ...
}
  • 如果需要更复杂的配置管理,用方案4更优雅。

这样你可以通过修改配置文件的 enabled 值来决定是否启用Nacos相关功能,无需修改代码。

到此这篇关于Spring Boot 根据配置决定服务(集群、单机)是否使用某些主件的文章就介绍到这了,更多相关Spring Boot 根据配置决定服务内容请搜索3672js教程以前的文章或继续浏览下面的相关文章希望大家以后多多支持3672js教程!

您可能感兴趣的文章:
  • SpringBoot部署与服务配置方式
  • 如何在Spring Boot应用程序中配置了两个不同的SOAP Web服务端点
  • Spring boot RedisTemplate 序列化服务化配置方式
  • spring boot配置多个请求服务代理的完整步骤
  • 详解Spring Boot 部署与服务配置
相关栏目:

用户点评