zoukankan      html  css  js  c++  java
  • SpringCloud学习之快速搭建分布式配置

    一. 关于spring-cloud中的分布式配置

      Spring Cloud Config为分布式系统中的外部配置提供服务器和客户端支持。使用Config Server,您可以在所有环境中管理应用程序的外部属性 ,通常情况下我们可以把需要管理的配置文件放置在svn或者git上进行做统一的配置仓库。

    二 创建git远程仓库远程仓库中创建所需的配置文件

      本例子中是demo-local.yml , 配置文件内容如下:

      

    student:
      name: test
      age: 28
    View Code

    三 创建config-server端

    1) 创建gradle模块config-server并添加gradle依赖

    dependencies {
        compile('org.springframework.cloud:spring-cloud-config-server')
    }
    View Code

    2)编辑application.yml配置

    server:
      port: 8000
    spring:
      cloud:
        config:
          server:
            git:
              uri: git@gitlab.com:xxxx/config.git
          enabled: true
      profiles:
        active: local
    View Code

     其中spring.cloud.config.server.git是配置远程仓库的地址,如果不使用SSH协议请配置username和password属性

    3)编写启动类

    package com.bdqn.lyrk.config;
    
    import org.springframework.boot.SpringApplication;
    import org.springframework.boot.autoconfigure.SpringBootApplication;
    import org.springframework.cloud.config.server.EnableConfigServer;
    
    
    @SpringBootApplication
    @EnableConfigServer
    public class ConfigServer {
    
        public static void main(String[] args) {
            SpringApplication.run(ConfigServer.class, args);
        }
    }
    View Code

    注意在启动类上添加@EnableConfigServer注解

    四 创建config-client端

     1)创建gradle模块demo-server并添加gradle依赖

    dependencies{
        compile('org.springframework.cloud:spring-cloud-starter-config')
    }
    View Code

    添加bootstrap.yml (Bootstrap.yml(bootstrap.properties)在application.yml(application.properties)之前加载)

    server:
      port: 8001
    spring:
      cloud:
        config:
          uri: http://localhost:8000
          profile: local
      application:
        name: demo
    View Code

    注意几点:

      配置服务从 /{name}/{profile}/{label} 提供属性源,客户端应用程序中的默认绑定

      “name”= ${spring.application.name}
      “profile”= ${spring.profiles.active} (实际上是 Environment.getActiveProfiles() )

      “label”=“master” 

      这里面的spring.application.name与远程仓库的配置文件名demo-local对应

      

    编写DemoConfig类

     1 package com.bdqn.lyrk.server.demo.config;
     2 
     3 import org.springframework.boot.context.properties.ConfigurationProperties;
     4 import org.springframework.context.annotation.Configuration;
     5 
     6 @Configuration
     7 @ConfigurationProperties(prefix = "student")
     8 public class DemoConfig {
     9     private String name;
    10     private int age;
    11 
    12     public String getName() {
    13         return name;
    14     }
    15 
    16     public void setName(String name) {
    17         this.name = name;
    18     }
    19 
    20     public int getAge() {
    21         return age;
    22     }
    23 
    24     public void setAge(int age) {
    25         this.age = age;
    26     }
    27 }
    View Code

    注意 @ConfigurationProperties(prefix = "student")注解,该注解作用是:获取yml配置文件的前缀student,配置文件中余下部分用javabean的属性替换即可

    编写启动类:

     1 package com.bdqn.lyrk.server.demo;
     2 
     3 import com.bdqn.lyrk.server.demo.config.DemoConfig;
     4 import org.springframework.boot.SpringApplication;
     5 import org.springframework.boot.autoconfigure.SpringBootApplication;
     6 import org.springframework.cloud.client.circuitbreaker.EnableCircuitBreaker;
     7 import org.springframework.cloud.config.client.ConfigServicePropertySourceLocator;
     8 import org.springframework.context.ApplicationContext;
     9 
    10 @SpringBootApplication
    11 public class DemoProvider {
    12 
    13     public static void main(String[] args) {
    14         ApplicationContext applicationContext = SpringApplication.run(DemoProvider.class, args);
    15         DemoConfig demoConfig = applicationContext.getBean(DemoConfig.class);
    16         System.out.println(demoConfig.getName());
    17     }
    18 }
    View Code

    运行后得到上述结果,此时我们已经从远程配置中获取到所需的信息了

  • 相关阅读:
    mysql保存中文乱码的原因和解决办法
    NetSetMan IP地址切换工具
    使用批处理文件,自动设置计算机IP地址
    神逸之作:国产快速启动软件神品ALTRun
    Apache详细介绍
    利用sqoop对mysql执行DML操作
    Mysql定时清空表
    azkaban group分组,权限
    azkaban使用
    sqoop无法导出parquet文件到mysql
  • 原文地址:https://www.cnblogs.com/niechen/p/7991947.html
Copyright © 2011-2022 走看看