文档章节

springboot搭建分布式配置中心(一)

HGMrWang
 HGMrWang
发布于 2017/08/31 18:13
字数 546
阅读 67
收藏 1

git仓库

在码云上创建一个repo

仓库地址:http://git.oschina.net/wangxianhong/config-server

包含的文件:

文件内容:

文件的命名格式:wangxh-xxx.yml

wangxh:表示一个具体的服务名称,这个名称是通过在配置文件中用:spring.application.name=wangxh 来定义的。

wangxh-dev:存放的是开发时的配置信息

wangxh-prod:存放的是生产时的配置信息

wangxh-test:存放的是测试时的配置信息

搭建配置中心

  • 使用springboot创建一个普通的项目,在pom中添加依赖,以下是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-server</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>config-server</name>
	<description>分布式配置中心示例</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.cloud</groupId>
			<artifactId>spring-cloud-config-server</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</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>
  • 在启动类添加注解:@EnableConfigServer
@SpringBootApplication
@EnableConfigServer
public class ConfigServerApplication {

	public static void main(String[] args) {
		SpringApplication.run(ConfigServerApplication.class, args);
	}
}
  • 配置application.properties
spring.application.name=config-server
server.port=8000

spring.cloud.config.server.git.uri=http://git.oschina.net/wangxianhong/config-server
#spring.cloud.config.server.git.username=
#spring.cloud.config.server.git.password=

这个文件只是指定了 git的地址,配置中心的名称,端口号。

以上就完成了配置中心的搭建。

验证

wangxh-dev:存放的是开发时的配置信息

wangxh-prod:存放的是生产时的配置信息

wangxh-test:存放的是测试时的配置信息

现在通过配置中心来访问git仓库的以上几个文件。

访问 wangxh-dev文件

http://localhost:8000/wangxh/dev

访问wangxh-prod文件

http://localhost:8000/wangxh/prod

访问wangxh-test文件

http://localhost:8000/wangxh/test

 

总结

如果应用名称叫 serverA 那么需要在git仓库里添加各种场景的yml文件,而这些yml文件的名称规则就是

serverA-dev.yml

serverA-prod.yml

serverA-test.yml

通过http读取这些配置的规则:

http://配置中心的地址/serverA/dev

http://配置中心的地址/serverA/prod

http://配置中心的地址/serverA/test

 

 

 

 

© 著作权归作者所有

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

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

远方的梦Java
2018/08/05
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
如何使用 SpringCloud 搭建服务注册中心?

作者 | 于海东 责编 | 郭 芮 之前在巧玩SpringBoot——SpringBoot的第一个“Hello World!”(https://blog.csdn.net/dongdong9223/article/details/82802137)中讲述过SpringBoot的搭建,能...

CSDN资讯
01/04
0
0
SpringBoot介绍及常用的搭建方式

SpringBoot简介 Spring Boot是Spring社区发布的一个开源项目,旨在帮助开发者快速并且更简单的构建项目。它使用习惯优于配置的理念让你的项目快速运行起来,使用Spring Boot很容易创建一个独...

Hans的博客
前天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Python如何开发桌面应用程序?Python基础教程,第十三讲,图形界面

当使用桌面应用程序的时候,有没有那么一瞬间,想学习一下桌面应用程序开发?行业内专业的桌面应用程序开发一般是C++,C#来做,Java开发的也有,但是比较少。本节课会介绍Python的GUI(图形用...

程序员补给栈
今天
3
0
kafka在的使用

一、基本概念 介绍 Kafka是一个分布式的、可分区的、可复制的消息系统。它提供了普通消息系统的功能,但具有自己独特的设计。 这个独特的设计是什么样的呢? 首先让我们看几个基本的消息系统...

狼王黄师傅
今天
2
0
Android JNI总结

0x01 JNI介绍 JNI是Java Native Interface的缩写,JNI不是Android专有的东西,它是从Java继承而来,但是在Android中,JNI的作用和重要性大大增强。 JNI在Android中起着连接Java和C/C++层的作...

天王盖地虎626
昨天
1
0
大数据教程(11.8)Hive1.2.2简介&初体验

上一篇文章分析了Hive1.2.2的安装,本节博主将分享Hive的体验&Hive服务端和客户端的使用方法。 一、Hive与hadoop直接的关系 Hive利用HDFS存储数据,利用MapReduce查询数据。 二、Hive与传统数...

em_aaron
昨天
3
0
跟我学Spring Cloud(Finchley版)-15-Hystrix监控详解

Hystrix提供了监控Hystrix Command的能力,本节来详细探讨。 监控端点与数据 应用整合Hystrix,同时应用包含spring-boot-starter-actuator 依赖,就会存在一个/actuator/hystrix.stream 端点...

周立_ITMuch
昨天
8
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部