SpringCloud项目中使用携程Apollo分布式配置中心

简介: SpringCloud项目中使用携程Apollo分布式配置中心


image.png

管理后台 http://localhost:8070


image.png

注册中心 http://localhost:8080


image.png

# 与SpringCloud/SpringBoot集成



  • 在apollo管理后台新建项目


image.png

添加配置


image.png


  • 添加依赖

<dependency>
                <groupId>com.ctrip.framework.apollo</groupId>
                <artifactId>apollo-client</artifactId>
                <version>1.1.0</version>
            </dependency>
  • SpringBoot项目配置

spring:
  application:
    name: biz-user
app:
  id: ${spring.application.name}    # 与apollo管理后台配置的项目的appId一致
apollo:
  meta: http://localhost:8080
  bootstrap:
    enabled: true          # 是否启用apollo
    namespaces: application,TEST1.base   # 该app(appId)下的某个命名空间(某个配置文件)/或者x.y(x部门下的公开y命名空间)
  • apollo.bootstrap可以使用注解的方式进行配置

@EnableApolloConfig({"application", "TEST1.base"})


  • 公共配置文件

image.png


先创建一个普通项目,再在项目中添加Namespace


image.png

  • 注意看提示和备注
  • 测试

@Slf4j
@EnableApolloConfig({"application", "TEST1.base"})
@MapperScan({"com.futao.biz.user.dao", "com.futao.biz.user.mapper"})
@SpringBootApplication(scanBasePackages = {"com.futao.common", "com.futao.biz.user"})
public class UserApplication implements CommandLineRunner {
    @Value("${app.apollo.username}")
    private String userName;
    @Value("${app.apollo.age}")
    private int age;
    @Value("${apl.conf1}")
    private String c1;
    @Value("${apl.conf2}")
    private String c2;
    @Value("${apl.conf3}")
    private String c3;
    @Value("${apl.conf4}")
    private String c4;
    public static void main(String[] args) {
        SpringApplication.run(UserApplication.class, args);
    }
    @Override
    public void run(String... args) throws Exception {
        new Thread(() -> {
            while (true) {
                log.info(StringUtils.repeat("-", 50));
                log.info("userName:{}", userName);
                log.info("age:{}", age);
                log.info("c1:{}", c1);
                log.info("c2:{}", c2);
                log.info("c3:{}", c3);
                log.info("c4:{}", c4);
                try {
                    Thread.sleep(2000L);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }).start();
    }
}


image.png

注意:


  • 项目中配置的application命名空间默认读取的是该appId下的application命名空间(并且是私有的命名空间),一般如果要读取公共的配置文件,格式是xxx.yyy,xxx为部门名称,yyy为公共的命名空间
  • apollo中配置的属性并不需要在配置文件中先定义好。(可以只在apollo中配置即可)
  • 配置文件的优先级为引用顺序递减
  • @EnableApolloConfig({"application", "TEST1.base"})=>TEST1.base中的配置无法覆盖application中的配置。
  • @EnableApolloConfig({"TEST1.base","application"})=>application中的配置无法覆盖TEST1.base中的配置。
相关文章
|
1月前
|
数据库
如何在Seata框架中配置分布式事务的隔离级别?
总的来说,配置分布式事务的隔离级别是实现分布式事务管理的重要环节之一,需要认真对待和仔细调整,以满足业务的需求和性能要求。你还可以进一步深入研究和实践 Seata 框架的配置和使用,以更好地应对各种分布式事务场景的挑战。
32 6
|
2月前
|
JSON SpringCloudAlibaba Java
Springcloud Alibaba + jdk17+nacos 项目实践
本文基于 `Springcloud Alibaba + JDK17 + Nacos2.x` 介绍了一个微服务项目的搭建过程,包括项目依赖、配置文件、开发实践中的新特性(如文本块、NPE增强、模式匹配)以及常见的问题和解决方案。通过本文,读者可以了解如何高效地搭建和开发微服务项目,并解决一些常见的开发难题。项目代码已上传至 Gitee,欢迎交流学习。
182 1
Springcloud Alibaba + jdk17+nacos 项目实践
|
29天前
|
负载均衡 Java API
项目中用的网关Gateway及SpringCloud
Spring Cloud Gateway 是一个功能强大、灵活易用的API网关解决方案。通过配置路由、过滤器、熔断器和限流等功能,可以有效地管理和保护微服务。本文详细介绍了Spring Cloud Gateway的基本概念、配置方法和实际应用,希望能帮助开发者更好地理解和使用这一工具。通过合理使用Spring Cloud Gateway,可以显著提升微服务架构的健壮性和可维护性。
38 0
|
3月前
|
NoSQL Java Redis
面试官:项目中如何实现分布式锁?
面试官:项目中如何实现分布式锁?
104 6
面试官:项目中如何实现分布式锁?
|
2月前
|
分布式计算 Hadoop
Hadoop-27 ZooKeeper集群 集群配置启动 3台云服务器 myid集群 zoo.cfg多节点配置 分布式协调框架 Leader Follower Observer
Hadoop-27 ZooKeeper集群 集群配置启动 3台云服务器 myid集群 zoo.cfg多节点配置 分布式协调框架 Leader Follower Observer
57 1
|
3月前
|
负载均衡 Java Nacos
SpringCloud基础2——Nacos配置、Feign、Gateway
nacos配置管理、Feign远程调用、Gateway服务网关
SpringCloud基础2——Nacos配置、Feign、Gateway
|
2月前
|
存储 SQL 消息中间件
Hadoop-26 ZooKeeper集群 3台云服务器 基础概念简介与环境的配置使用 架构组成 分布式协调框架 Leader Follower Observer
Hadoop-26 ZooKeeper集群 3台云服务器 基础概念简介与环境的配置使用 架构组成 分布式协调框架 Leader Follower Observer
54 0
|
2月前
|
负载均衡 Java API
【Spring Cloud生态】Spring Cloud Gateway基本配置
【Spring Cloud生态】Spring Cloud Gateway基本配置
62 0
|
4月前
|
Java 微服务 Spring
Spring Cloud全解析:配置中心之解决configserver单点问题
但是如果该configserver挂掉了,那就无法获取最新的配置了,微服务就出现了configserver的单点问题,那么如何避免configserver单点呢?
|
4月前
|
UED 存储 数据管理
深度解析 Uno Platform 离线状态处理技巧:从网络检测到本地存储同步,全方位提升跨平台应用在无网环境下的用户体验与数据管理策略
【8月更文挑战第31天】处理离线状态下的用户体验是现代应用开发的关键。本文通过在线笔记应用案例,介绍如何使用 Uno Platform 优雅地应对离线状态。首先,利用 `NetworkInformation` 类检测网络状态;其次,使用 SQLite 实现离线存储;然后,在网络恢复时同步数据;最后,通过 UI 反馈提升用户体验。
115 0