Spring boot2.0.x+SpringCloud(Finchley版本)分布式架构--分布式配置中心(Spring Cloud Config)(五)

前言声明:
如果您有更好的技术与作者分享,或者商业合作;请访问作者个人网站 http://www.esqabc.com/view/message.html 留言给作者。
如果该案例触犯您的专利,请在这里:http://www.esqabc.com/view/message.html 留言给作者说明原由,作者一经查实,马上删除。

五,分布式配置中心(Spring Cloud Config)

开始前准备工作:
1,创建两个项目(esq-config-ser和esq-config-cli)
1)esq-config-ser:分布式配置中心(Spring Cloud Config)(配置服务器)
2)esq-config-cli:分布式配置中心(Spring Cloud Config)(配置客户端)
架构如下:
在这里插入图片描述

1,分布式配置中心(Spring Cloud Config)(配置服务器)(esq-config-ser)
在这里插入图片描述
1,pom配置文件添加:

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-config-server</artifactId>
</dependency>

2,启动文件ConfigSerApplication:

package com.esq.config;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.config.server.EnableConfigServer;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.boot.CommandLineRunner;
import java.util.Arrays;
/**
 * 分布式配置中心(Spring Cloud Config)(配置服务器)启动类
 * @author esq
 * @Create 2019-09-09 09:09:09
 * @Website www.esqabc.com
 * @WeChat 
 */
@SpringBootApplication
@EnableConfigServer
public class ConfigSerApplication{

	public static void main(String[] args) {
		System.out.println("。。。。。。配置服务器程序开始启动。。。。。。");
		long startTime = System.currentTimeMillis();    //获取开始时间
		SpringApplication.run(ConfigSerApplication.class, args);
		long endTime = System.currentTimeMillis();    //获取结束时间
		System.out.println("配置服务器程序启动用时:" + (endTime - startTime) + "毫秒");//输出程序运行时间
		System.out.println("配置服务器程序启动一共用时:" + (endTime - startTime)/60 + "秒。。。。。。");
		System.out.println("。。。。。。配置服务器程序启动成功。。。。。。");
	}
	@Bean
	public CommandLineRunner commandLineRunner(ApplicationContext ctx) {
		
	   return args -> {
	       String[] beanNames = ctx.getBeanDefinitionNames();
	       Arrays.sort(beanNames);
	       Arrays.stream(beanNames).forEach(System.out::println);
	   };
	}	
	
}

3,application.properties配置文件改造;


#配置启动端口号
server.port=9004
#配置项目访问路径
#server.context-path=/eureka
#配置服务名称
spring.application.name=esq-config-ser
#配置远程git仓库地址
spring.cloud.config.server.git.uri=https://github.com/esqabc/esqtest/
#配置远程仓库的名称
spring.cloud.config.server.git.searchPaths=esqtest
#配置仓库的分支类型(这个对应github里面的类型)
spring.cloud.config.label=master
#访问git仓库的用户名(如果是公有的话就不用账号)
spring.cloud.config.server.git.username=
#访问git仓库的用户密码(如果是公有的话就不用密码)
spring.cloud.config.server.git.password=

git仓库视图:
在这里插入图片描述
也可以直接访问:https://github.com/esqabc/esqtest/tree/master/config 了解

4,启动项目,在浏览器输入:http://localhost:9004/esqabc/dev

显示:
{“name”:“esqabc”,“profiles”:[“dev”],“label”:master,“version”:“11786143b6368c303f7f2c3f93fd3a8dc3646617”,“state”:null,“propertySources”:[]}

证明配置服务中心可以从远程程序获取配置信息。
http请求地址和资源文件映射如下:
/{application}/{profile}[/{label}]
/{application}-{profile}.yml
/{label}/{application}-{profile}.yml
/{application}-{profile}.properties
/{label}/{application}-{profile}.properties

1,分布式配置中心(Spring Cloud Config)(配置客户端)(esq-config-cli)
在这里插入图片描述

1,pom配置文件添加:

<?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>com.esq.master</groupId>
    <artifactId>esq-master</artifactId>
    <version>1.0.0</version>
  </parent>
  
  <!-- 本项目信息 -->
  <groupId>com.esq.config</groupId>
  <artifactId>esq-config-cli</artifactId>
  <name>esq-config-cli</name>
  <description>分布式配置中心(Spring Cloud Config)(配置客户端)</description>
  
   <!-- 配置编码格式  begin -->
  <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
  </properties>
  <!-- 配置编码格式  end -->
  
  
  <!-- JAR包配置  begin-->
  <dependencies>
		 <!-- Springboot web服务器的jar-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
         <!-- 分布式配置中心(Spring Cloud Config)(配置客户端)的jar-->
        <dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-starter-config</artifactId>
		</dependency>
  </dependencies>
  <!-- JAR包配置  end-->
  
  
  
  <!-- 插件配置  begin -->
   <build>
	<plugins>
	

	</plugins>	
   </build>
  <!-- 插件配置  end -->
</project>

2,启动文件ConfigCliApplication:

package com.esq.config;


import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
/**
 * 分布式配置中心(Spring Cloud Config)(配置客户端)启动类
 * @author esq
 * @Create 2019-09-09 09:09:09
 * @Website www.esqabc.com
 * @WeChat 
 */
@SpringBootApplication
public class ConfigCliApplication{

	public static void main(String[] args) {
		System.out.println("。。。。。。配置客户端程序开始启动。。。。。。");
		long startTime = System.currentTimeMillis();    //获取开始时间
		SpringApplication.run(ConfigCliApplication.class, args);
		long endTime = System.currentTimeMillis();    //获取结束时间
		System.out.println("配置服务器程序启动用时:" + (endTime - startTime) + "毫秒");//输出程序运行时间
		System.out.println("配置服务器程序启动一共用时:" + (endTime - startTime)/60 + "秒。。。。。。");
		System.out.println("。。。。。。配置服务器程序启动成功。。。。。。");
	}

}

3,添加配置文(bootstrap.properties);


#配置启动端口号
server.port=9005
#配置项目访问路径
#server.context-path=/eureka
#配置服务名称
spring.application.name=esq-config

#配置远程仓库的分支
spring.cloud.config.label=master
#配置类型    dev开发环境配置文件      test测试环境    pro正式环境
spring.cloud.config.profile=dev
#配置配置服务中心的网址。
spring.cloud.config.uri=http://localhost:9004/

4,添加接口访问(UserControler):

package com.esq.config.controler;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;


/**
 * 用户控制器
 * @author esq
 * @Create 2019-09-09 09:09:09
 * @Website www.esqabc.com
 * @WeChat 
 */
@RestController
public class UserControler {
	
	@Value("${esqabc}")
	String esqpis;
	@RequestMapping(value = "/gethi")
	 public String hi() {
		 System.out.println(esqpis);
		 System.out.println("进入消费者==》》用户控制器==》》调用esquser服务");
	     return esqpis;
	}
}

4,启动项目,在浏览器输入:http://localhost:9005/gethi

显示:www.esqabc.com

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

更多请访问:https://blog.csdn.net/esqabc/article/details/87804603

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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章