文档章节

springboot搭建分布式配置中心(二):客户端

HGMrWang
 HGMrWang
发布于 2017/09/01 10:21
字数 729
阅读 39
收藏 0

创建客户端

  • 使用springboot创建一个客户端,例如我创建的工程名称叫做config-client(随便命名),如图:

  • 添加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>com.wangxh</groupId>
	<artifactId>config-client</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>config-client</name>
	<description>Demo project for Spring Boot</description>

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>1.5.6.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
		<java.version>1.8</java.version>
		<spring-cloud.version>Dalston.SR3</spring-cloud.version>
	</properties>

	<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>
	</dependencies>

	<dependencyManagement>
		<dependencies>
			<dependency>
				<groupId>org.springframework.cloud</groupId>
				<artifactId>spring-cloud-dependencies</artifactId>
				<version>${spring-cloud.version}</version>
				<type>pom</type>
				<scope>import</scope>
			</dependency>
		</dependencies>
	</dependencyManagement>

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

</project>

 

  • 在bootstrap.yml文件中指定分布式配置中心的地址

bootstrap.yml:

# 
spring:
  application:
    name: wangxh
  cloud:
    config:
      uri: http://localhost:8000/
      profile: prod
#      label: master

这里的spring.application.name是wangxh,那么对应上一篇中在git仓库中配置那几个文件名称要保持一样。

uri:是自己搭建的配置中心的访问地址;

profile:是git仓库中以wangxh开头的dev|prod|test| 这几个文件;

label:是这些文件所在的分支,默认是master分支。

补充:

如果有另外一个工程也要使用配置中心,假如这个工程名称(spring.application.name)叫:sms

那么就可以在git仓库中新增对应的以下几个基本配置文件:

sms-dev.yml

sms-prod.yml

sms-test.yml

 

验证

先启动配置中心config-server ,这是springboot搭建分布式配置中心(一)搭建的工程。

再启动config-client

创建一个控制器,打印出tag的值,注:tag在每个配置文件中都有,并且值不一样,就是为了标记客户端正确加载了不同的配置文件。

@RestController
public class HelloController {


    @Value("${tag}")
    private String tag;

    @PostConstruct
    public String getTag() {
        System.out.println(tag);
         return "hello:"+tag;
    }

    @GetMapping("tag")
    public String showTag(){
        return tag;
    }
}

在浏览器访问:http://localhost/tag

此时在config-client的bootstrap.yml如下(注意profile):

# 
spring:
  application:
    name: wangxh
  cloud:
    config:
      uri: http://localhost:8000/
      profile: prod
#      label: master

==============================

现在将profile改成test,重启工程

# 
spring:
  application:
    name: wangxh
  cloud:
    config:
      uri: http://localhost:8000/
      profile: test
#      label: master

在浏览器访问:http://localhost/tag

所以在boottrap.yml文件中通过配置 profile的值,而这个值就是git仓库配置的文件。

总结就是这样:

bootstrap                                git仓库

profile: test                              wangxh-test.yml

profile: dev                              wangxh-dev.yml

profle: prod                             wangxh-prod.yml

 

后记

如果在工程中配置的bootstrap.yml文件使用配置中心,而此时在本地开发的时候又不想使用配置中心的配置文件(主要是git仓库的配置文件在运维哪里,修改很麻烦),那么只需要在application.yml文件将

spring.application.name改一下名字,也就是git仓库不存在,此时启动工程后将和未使用一样,配置文件还是从本机的application.yml文件中加载。

 

© 著作权归作者所有

共有 人打赏支持
HGMrWang
粉丝 7
博文 88
码字总数 41577
作品 0
深圳
程序员
私信 提问
Spring Boot与Spring Cloud是什么关系?

SpringBoot先于Spring Cloud问世。 SpringBoot相当于脚手架,借助他可以快速搭建房子,它本身不具备任何功能属性,值是普通房间,没有其他任何功能。 什么是Spring Boot Spring Boot简化了基...

远方的梦Java
2018/08/05
0
0
Eureka服务发现---SpringCloud(一)

Eureka服务发现 (一)前言 下面我们添加一个EurekaServer的module模块,作为Eureka注册中心;

JackyRiver
2018/07/31
0
0
SpringCloud微服务入门

SpringCloud微服务入门 初识SpringCloud Eureka注册中心 HelloWorld 1.初识SpringCloud 1.1 简介 : springCloud是基于SpringBoot的一整套实现微服务的框架。因为它不是一个组件,而是许多组件...

全世界最好的肥猪精
2018/12/03
0
0
springboot整合kafka应用

1、kafka在消息传递的使用非常普遍,相对于activemq来说kafka的分布式管理和使用更加灵活。 2、activemq的搭建和使用可以参考:   activemq搭建和springmvc的整合:http://www.cnblogs.co...

小不点丶
2017/11/09
0
0
简述Spring Boot与Spring Cloud的关系

如下文章字数大约600字,阅读时间需要5分钟左右。 随着微服务架构的持续火热,以及对开发部署迭代需求越来越快速,现今,spring boot逐渐火热,越来越流行。 随着spring boot 流行的还有另外...

Java大蜗牛
2018/08/27
0
0

没有更多内容

加载失败,请刷新页面

加载更多

阿里大规模数据中心性能分析

郭健美,阿里巴巴高级技术专家,目前主要从事数据中心的性能分析和软硬件结合的性能优化。CCF 系统软件专委和软件工程专委的委员。曾主持国家自然科学基金面上项目、入选上海市浦江人才计划A...

阿里云官方博客
36分钟前
1
0
Coding and Paper Letter(四十四)

资源整理。 1 Coding: 1.Rstudio2019年会“机器学习应用”的幻灯片,代码和数据 rstudio conf 2019 2.R语言包sparkxgb,Spark上XGBoost的R接口。 sparkxgb 3.自动SQL注入和数据库接管工具。 ...

胖胖雕
38分钟前
1
0
Ubuntu最新的主要操作系统放弃32位支持?

现在是2018年,2019年即将到来——64位处理器已经成为主流很长一段时间了。如果你仍然使用32位的电脑,那么是时候把它扔进垃圾箱了。 我为所有基于Linux的操作系统维护者感到自豪,他们有勇气...

Linux就该这么学
40分钟前
1
0
Fundebug发布Vue插件,简化BUG监控接入代码

摘要: 代码越短越好! 我们发布了fundebug-vue插件,可以简化Vue框架接入Fundebug的代码。 Vue如何接入Fundebug 1. 安装fundebug-javascript与fundebug-vue npm install fundebug-javascrip...

Fundebug
47分钟前
1
0
MySQL学习笔记之二

数据库的操作总结就是:增删改查(CURD),今天记录一下基础的检索查询工作。 检索MySQL 1.查询表中所有的记录 mysql> select * from apps;+----+------------+-----------------------+------...

凌宇之蓝
58分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部