第一章:初探Spring Cloud Config配置集中管理_springcloud 集中配置管理-程序员宅基地

技术标签: spring  spring-cloud  SpringCloud  config  

前路艰难,但谨记,你并不孤独。

Spring Cloud如火如荼,抽空研究研究Spring大家族中的新份子。具体的介绍不会粗线在本系列博文中,如需要理论等知识直接百度or谷歌。

Spring Cloud中保护N多已构建好的微服务,可以做到即插即用,其中大致包含几种服务:Config、Eureka、Ribbon、Hystrix、Feign、Bus等,具体介绍及开源地址请见:Spring Cloud中文官网

今天让我们一起研究下Config,让你发现Spring Cloud的美,也许仅仅因为这一个小小的功能就会让你对Spring Cloud爱不释手,有木有呀?

本文中为一个Maven工程cloud-demo,包含多个maven module工程,其中一个配置的集中服务cloud-demo-config,一个使用配置服务的简单Spring Boot工程cloud-demo-helloword,一个存放配置的文件夹cloud-demo-repo。

所有代码地址:https://github.com/S1ow/cloud-demo.git 持续更新


Now show code


第一步,创建主工程,方便管理

主工程是一个简单Maven工程,创建成功后删除所有文件,只留下pom文件,并创建cloud-demo-repo文件夹(此文件夹需要上传到git/svn上,用于配置服务的读取与集中管理),pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>

  <groupId>cloud</groupId>
  <artifactId>cloud-demo</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>pom</packaging>

  <name>cloud-demo</name>
  <url>http://maven.apache.org</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>

  <modules>
    <module>cloud-demo-config</module>
    <module>cloud-demo-helloword</module>
  </modules>
</project>
  1. cloud-demo-repo:配置文件存放处,可以理解为配置的提供方;
  2. cloud-demo-config:配置服务器,所有的配置读取都是由该服务来实现的,它是从git上来读取配置文件的,可以理解为配置文件的中间转换器;
  3. cloud-demo-helloword:一个简单的应用,可以理解为配置的消费方;

第二步,创建配置“服务中心”,cloud-demo-config工程

会发现创建一个Spring Cloud Config配置服务是多么的轻量级,以后的代码会不会变成傻瓜式编程呢?

1、右键cloud-demo工程new –> Mvane Module工程即可,这也是一个Spring Boot应用程序,所有的Spring Cloud的启动方式全部采用Spring boot,pom.xml如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>cloud</groupId>
    <artifactId>cloud-demo-config</artifactId>
    <version>0.0.1</version>
    <packaging>jar</packaging>

    <name>cloud-demo-config</name>
    <description>cloud-demo-config</description>

    <parent>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-parent</artifactId>
        <version>Brixton.RELEASE</version>
        <relativePath />
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <repositories>
        <repository>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
            <id>public</id>
            <name>Public Repositories</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
        </repository>
    </repositories>

    <pluginRepositories>
        <pluginRepository>
            <id>public</id>
            <name>Public Repositories</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
        </pluginRepository>
    </pluginRepositories>

    <dependencies>
        <!-- 配置服务所需的依赖 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-config-server</artifactId>
        </dependency>
        <!-- 暴露服务的一些管理功能 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <!-- 测试组件,权重test -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
        <defaultGoal>compile</defaultGoal>
    </build>

</project>
  • 采用阿里的maven私服地址
  • 使用的Spring的Brixton配置

    2、下面需要创建一个启动类,随着启动类的创建,配置服务也即将搭建完毕了,就是这么so easy:

package org.cloud.demo.config;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;

/**
 * 配置服务中心
 *  */
@SpringBootApplication
//只需要一个注解即开启了配置服务的管理
@EnableConfigServer
public class ConfigApplication{
    

    public static void main( String[] args ){
        SpringApplication.run(ConfigApplication.class, args);
    }
}
  • @SpringBootApplication:查看源码相当于@Configuration、@EnableAutoConfiguration、@ComponentScan三个注解,可谓是三个臭皮匠顶个诸葛亮;
  • @EnableConfigServer:顾名思义告诉Spring Boot我要开启配置服务,请给我让路好吗?好的!

    3、还记得刚开始我们创建的需要上传到git/svn上的文件夹cloud-demo-repo么?这里存放是配置文件,配置服务cloud-demo-config需要知道文件在哪呀,对吧?所以需要修改cloud-demo-config工程的application.properties告诉配置服务,去哪里找配置文件:

#配置服务的启动端口,此处可不使用远程配置
server.port=8888
#配置服务的名称,总之你喜欢就好
spring.application.name=cloud-demo-config

#配置服务去哪里找配置文件
spring.cloud.config.server.git.uri=https://github.com/S1ow/cloud-demo.git
#去哪个文件夹找配置文件
spring.cloud.config.server.git.searchPaths=cloud-demo-repo

4、这样配置服务就搭建好了,先别着急启动,让我们创建一份远程配置cloudhello-test.properties,这里的配置文件命名是很有讲究的,A-B-C.type的命名方式:

  1. A:消费配置服务名称,映射到客户端的“spring.application.name”;
  2. B:profile,映射到客户端上的“spring.profiles.active”(逗号分隔列表);
  3. C:label,可以理解是一个小版本号,映射到客户端上的“spring.profiles.active”(逗号分隔列表);
  4. type:可以是yml、properties
#这里的配置跟配置服务没有半毛钱关系,用于配置服务的消费应用的
config.server.ip=127.0.0.1
config.server.port=8888

app.profile=test
#测试环境
app.hello=\u6D4B\u8BD5\u73AF\u5883\uFF01

再创建一个cloudhello-dev.properties,方便后面配置消费的调用:

config.server.ip=127.0.0.1
config.server.port=8888

app.profile=dev
#开发环境
app.hello=\u5F00\u53D1\u73AF\u5883

配置服务就搞定了,有木有很简单,可以启动配置服务工程,并可以通过http://ip:port/A/B 来看看读取回来的配置信息啦,其中ip和port为配置服务的,A/B就是上面提到的A/B。

第三步,创建配置的消费,cloud-demo-helloword工程

1、pom.xml,这里不做过多描述,与cloud-demo-config工程配置几乎相同:

<?xml version="1.0"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <modelVersion>4.0.0</modelVersion>
  <!-- <parent>
    <groupId>cloud</groupId>
    <artifactId>cloud-demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
  </parent> -->
  <groupId>cloud-demo-helloword</groupId>
  <artifactId>cloud-demo-helloword</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <name>cloud-demo-helloword</name>
  <url>http://maven.apache.org</url>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.3.5.RELEASE</version>
        <relativePath />
    </parent>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-parent</artifactId>
                <version>Brixton.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>
        <!-- 暴露服务的一些管理功能 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <repositories>
        <repository>
            <snapshots>
                <enabled>true</enabled>
            </snapshots>
            <id>public</id>
            <name>Public Repositories</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
        </repository>
    </repositories>

    <pluginRepositories>
        <pluginRepository>
            <id>public</id>
            <name>Public Repositories</name>
            <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
        </pluginRepository>
    </pluginRepositories>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

2、创建hello工程的启动类:

package org.cloud.demo.helloword;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class HelloApplication {
    

    public static void main( String[] args ){
        SpringApplication.run(HelloApplication.class, args);
    }
}

3、创建一个Controller用于获取远程配置:

package org.cloud.demo.helloword;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RefreshScope
public class HelloController {

    //将从远程配置获取app.hello这个key
    @Value("${app.hello}")
    String bar;

    //根据配置的不同输出不同
    @RequestMapping("/")
    String hello(){
        return "This is " + bar;
    }
}

4、hello工程的application.properties:

#配置服务的名称,与cloudhello-test.properties中的cloudhello相同
spring.application.name=cloudhello
#hello工程启动端口
server.port=9999

#告诉springcloud去哪里找配置,这里的config.server.ip与#config.server.port均为远程配置
spring.cloud.config.uri=http://${config.server.ip}:${config.server.port}
#读取那个服务的配置
spring.cloud.config.name=cloudhello
获取哪个profile,如果获取不到默认为test
spring.cloud.config.profile=test

Ok,下面启动hello工程,访问http://127.0.0.1:9999/ 可以得到返回

This is 测试环境

将上述配置文件中的spring.cloud.config.profile修改为dev,重启服务,访问上述地址,可以得到返回:

This is 开发环境

从这个简单的例子中,可以发现切换配置的快速,对于有多个环境需要维护的企业,减低了极大的成本,带来更短的时间,更高的安全性。

快去试试吧。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/yf275908654/article/details/72927497

智能推荐

linux开机运行jar包,Linux中jar包启动和jar包后台运行的实现方式-程序员宅基地

文章浏览阅读362次。linux 运行jar包命令如下:方式一:java -jar shareniu.jar特点:当前ssh窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出那如何让窗口不锁定?方式二java -jar shareniu.jar &&代表在后台运行。特定:当前ssh窗口不被锁定,但是当窗口关闭时,程序中止运行。继续改进,如何让窗口关闭时hYoeXW,程序仍然运行?方式..._开机自启jar包跟后台运行一样吗

安卓端APP遥控树莓派小车_手机实时遥控树莓派小车实现-程序员宅基地

文章浏览阅读2w次,点赞9次,收藏105次。在android端写一个小小的控制器来通过局域网来控制树莓派小车的行驶,基本思路是在树莓派上写一个socket服务器,android端写一个socket客户机,两边约定好命令的指令(例如可以简单的把停止约定为“0”,把前进约定为“1”),android负责发送,树莓派负责接受并执行。用这种方法理论上是可以远程控制的,前提是得要知道树莓派被分配的公网IP。_手机实时遥控树莓派小车实现

wordpress 添加自定义字段到 文章_wordpass 数据库 增加字段-程序员宅基地

文章浏览阅读2.8k次。$my_post = array( 'post_title' => $publication_name, 'post_excerpt' => $publication_name, 'post_date' => '2019-04-30 09:00:00', 'post_date_gmt' => '2019-04-30 09:..._wordpass 数据库 增加字段

【微服务】springboot 多模块打包使用详解_springboot 打包-程序员宅基地

文章浏览阅读3.9k次。项目打包是项目进行服务器部署的最后一关,对于一个springboot项目来说,功能开发完成后,需要将代码编译、打包、并部署到服务器上进行验证和测试,以maven为例,使用大家熟悉的mvn命令即可完成本地的打包构建,但事实上真的这么简单吗?以Java项目的工程模块为例进行说明,从早期的前后端一个工程搞定,到今天普遍使用的前后端分离的模式,从早期流行的承载式tomcat容器部署到如今更简洁的jar包部署,不同的事情,不同的工程部署模式,也为项目在最终打包构建的模式上带来了不同的变化。_springboot 打包

mysql5.5.50安装图解_mysql5.5的安装步骤-程序员宅基地

文章浏览阅读135次。好久没有安装mysql了,今天装了下,还有点不流畅,把详细的安装的流程写下来~,后续把mysql日常操作都写成checklist1.创建mysql组和mysql用户groupadd mysqluseradd -g mysql mysql2.创建相关的目录(根据自己的规则设置目录)mkdir/data/dbdata/usr/local/mysql/usr/local/mysql/tmp或者(推荐使用..._mysql5.5.50安装

简单的微博发布程序_请设计并实现一个简易的微博系统,让用户可以发送推文-程序员宅基地

文章浏览阅读625次。能实现简单的上传和删除,以及显示发布的时间。主要是先创建个文本节点,然后将所要发布的信息追加在文本节点上。代码实现<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <title></title> <style type="text/css"&g..._请设计并实现一个简易的微博系统,让用户可以发送推文

随便推点

Postgres:pg_basebackup物理备份与还原_postgres 异地备份 下载到本地-程序员宅基地

文章浏览阅读4.7k次。pg_basebackup备份与还原_postgres 异地备份 下载到本地

【转】前端学习方法总结-程序员宅基地

文章浏览阅读67次。原文出处qu deqing结合个人经历总结的前端入门方法,总结从零基础到具备前端基本技能的道路、学习方法、资料。由于能力有限,不能保证面面俱到,只是作为入门参考,面向初学者,让初学者少走弯路。互联网的快速发展和激烈竞争,用户体验成为一个重要的关注点,导致专业前端工程师成为热门职业,各大公司对前端工程师的需求量都很大,要求也越来越高,优秀的前端工程师更是稀缺。个人感觉前端入门相对容易,但是也...

FPGA 外置Flash的读写,用户数据存储_fpga将图片存储到flash中-程序员宅基地

文章浏览阅读1w次,点赞10次,收藏117次。FPGA 外置Flash的读写,用户数据存储前言一,该功能验证平台及参考文章1,Xilinx xc7k325tffg676-22,vivado 2017.43,验证的flash芯片:MT25QL2563,参考文章:MT25QL256_datasheet二、实现的功能1,read Device ID2,设置4-byte模式5,flash的数据读写三,部分代码总结前言大多数FPGA内部不具有掉电存储程序的功能,所以都是外置flash存储器来存储程序,上电后加载flash中的程序到FPGA中,在运行。外置f_fpga将图片存储到flash中

aardio(GBK汉字转UTF8汉字)获取的字符串代码乱码的解决方法-程序员宅基地

文章浏览阅读94次。aardio(GBK汉字转UTF8汉字)获取的字符串代码乱码的解决方法

基于 Matlab 的通信系统仿真――数字通信大作业_电子通信系统课程大作业-程序员宅基地

文章浏览阅读9.2k次,点赞7次,收藏144次。基于 Matlab 的通信系统仿真――数字通信大作业附:MATLAB的通信系统仿真.rar资源包括:main.m,modulation.m,demodulation.m,MATLAB的通信系统仿真说明文档https://download.csdn.net/download/alongiii/14945669目录基于 Matlab 的通信系统仿真――数字通信大作业系统综述结构框图系统实现随机信号的生成星座图映射插值波形成形(平方根升余弦滤波器)10 倍载波调制加入高斯白噪声匹配滤波器采样判决解调误码率_电子通信系统课程大作业

OnTriggerEnter与OnCollisionEnter详解_ontriggerenter和oncollision-程序员宅基地

文章浏览阅读2.2k次。1,测试OnTriggerEnter和OnCollisionEnter的区别测试:如果两个物体A,B两者都有碰撞体collider(Box Collider,Sphere Collider,Capsule Collider等)A,B都有刚体(Rigidbody)A或者B中有一个勾选isTrigger或者两者都勾选isTriggerA和B都可以进入OnTriggerEnter方法,但是不可进入OnCollisionEnter方法。A和B都不勾选isTrigger,A和B能进入OnCollis_ontriggerenter和oncollision