springcloud入门之配置服务

配置服务是为了解决项目配置分散,不便于集中管理的问题,传统多模块服务中,一旦配置发生更改,我们需要在相关项目中做修改,然后部署,如果配置文件统一在一个地方管理,那么修改起来就方便多了。

我们这里配置服务在config项目中,config项目即作为配置服务,需要依赖spring-cloud-config-server,同时,它也作为一个eureka客户端程序,需要注册在eureka server上,因此也需要依赖spring-cloud-starter-netflix-eureka-client。

我们根据上面的分析,我们在pom.xml文件中配置以下依赖:

<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter</artifactId>
</dependency>
<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-config-server</artifactId>
</dependency>
<dependency>
	<groupId>org.springframework.cloud</groupId>
	<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

编写ConfigApplication.java应用启动程序:

package com.xxx.config;

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

@SpringBootApplication
@EnableEurekaClient
@EnableConfigServer
public class ConfigApplication {
    public static void main(String[] args) {
        SpringApplication.run(ConfigApplication.class,args);
    }
}

@EnableEurekaClient开启作为eureka server的客户端的支持,@EnableConfigServer开启配置服务器的支持。

这里需要说明一下,我们的配置文件,springcloud应用提供使用bootstrap.yml(或者bootstrap.properties)负责从外部资源加载配置属性,因此,我们config以及以后的项目gateway,feign,ribbon,monitor等均使用两个配置文件,一个是application.yml,一个是bootstrap.yml,在config项目中,application.yml配置文件的内容是:

server:
  port: 8888
spring:
  cloud:
    config:
      server:
        native:
          search-locations: classpath:/config

spring.cloud.config.server.native.search-locations: classpath:/config 表示配置其他应用所需的配置文件的位置位于类路径下的config目录下。如下所示:

这里配置的两个文件分别是给后面feign、ribbon项目使用的,命名规则是根据所在项目spring.application.name中指定的名字来命名的。 

bootstrap.yml配置文件的内容是:

spring:
  application:
    name: config
  profiles:
    active: native
eureka:
  instance:
    metadata-map:
      instanceId: ${spring.application.name}:${random.value}
    non-secure-port: ${server.port:8888}
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/
  • spring.application.name: config指定应用名称为config,这个名字会在服务发现列表中体现出来。
  • spring.profiles.active: native表示配置服务器使用的是本地配置,默认是git。
  • eureka.instance.metadata-map.instanceId: ${spring.application.name}:${random.value}表示在eureka server中的实例ID。
  • eureka.instance.non-secure-port: ${server.port:8888} 非ssl端口,默认使用环境变量server.port的值。
  • eureka.client.service-url.defaultZone: http://localhost:8761/eureka/ 指定eureka server的地址。

配置服务是用来做配置管理的,如果不是特别的要求,配置分别写在各自项目的配置文件里也不是不可以,就是又回到了本文前面提到的修改的问题。

启动配置服务,我们可以在发现服务管理页面上查看,会多了一个实例。

 这里我们给出后续要用到的两个配置文件的内容:

feign.yml

spring:
  jpa:
    database: POSTGRESQL
  datasource:
    driver-class-name: org.postgresql.Driver
    username: postgres
    password:
    url: jdbc:postgresql://localhost:5432/mydb
    platform: postgres

ribbon.yml

springcloud:
  message: this is a message from config server

 如果本文节奏上跟不上,我们可以返回去,看springcloud入门示例之服务发现

项目源代码:https://github.com/buejee/springcloud

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luffy5459

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值