其他分享
首页 > 其他分享> > springConfig和springCloudBus

springConfig和springCloudBus

作者:互联网

1、Spring Cloud Config简介 :

​ 在分布式系统中,由于服务数量巨多,为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件。在Spring Cloud中,有分布式配置中心组件spring cloud config ,它支持配置服务放在配置服务的内存中(即本地),也支持放在远程Git仓库中。在spring cloud config 组件中,分两个角色,一是config server,二是config client。

​ Config Server是一个可横向扩展、集中式的配置服务器,它用于集中管理应用程序各个环境下的配置,默认使用Git存储配置文件内容,也可以使用SVN存储,或者是本地文件存储。

​ Config Client是Config Server的客户端,用于操作存储在Config Server中的配置内容。微服务在启动时会请求Config Server获取配置文件的内容,请求到后再启动容器。

详细内容看在线文档: https://springcloud.cc/spring-cloud-config.html

1.1 配置服务端

1.1.1 将配置文件提交到码云

​ 使用GitHub时,国内的用户经常遇到的问题是访问速度太慢,有时候还会出现无法连接的情况。如果我们希望体验Git飞一般的速度,可以使用国内的Git托管服务——码云gitee.com)。

​ 和GitHub相比,码云也提供免费的Git仓库。此外,还集成了代码质量检测、项目演示等功能。对于团队协作开发,码云还提供了项目管理、代码托管、文档管理的服务。

步骤:

(1)浏览器打开gitee.com,注册用户 ,注册后登陆码云管理控制台

[外链图片转存失败(img-411jQu7U-1568627793969)(F:/黑马102/JY/项目二资料/day12_服务鉴权及配置中心/笔记/assets/8_21.png)]

(2)创建仓库 leyou-config (点击右上角的加号 ,下拉菜单选择创建项目)

(3)上传配置文件,将ly_item_service工程的application.yml改名为item-dev.yml后上传

[外链图片转存失败(img-H7jGe1Rt-1568627793971)(F:/黑马102/JY/项目二资料/day12_服务鉴权及配置中心/笔记/assets/8_25.png)]

可以通过拖拽的方式将文件上传上去

[外链图片转存失败(img-ipaAMgud-1568627793972)(F:/黑马102/JY/项目二资料/day12_服务鉴权及配置中心/笔记/assets/8_26.png)]

上传成功后列表可见

[外链图片转存失败(img-tmQBQ0fP-1568627793973)(F:/黑马102/JY/项目二资料/day12_服务鉴权及配置中心/笔记/assets/8_23.png)]

可以再次编辑此文件

[外链图片转存失败(img-OHJhFjdP-1568627793975)(F:/黑马102/JY/项目二资料/day12_服务鉴权及配置中心/笔记/assets/8_22.png)]

文件命名规则:

{application}-{profile}.yml或{application}-{profile}.properties

application为应用名称 profile指的开发环境(用于区分开发环境,测试环境、生产环境等)

(4)复制git地址 ,备用

[外链图片转存失败(img-UQLhCz2e-1568627793979)(F:/黑马102/JY/项目二资料/day12_服务鉴权及配置中心/笔记/assets/8_24.png)]

地址为:https://gitee.com/chuanzhiliubei/tensquare-config.git

2、1配置中心微服务

(1)创建工程模块 配置中心微服务 ly_config ,pom.xml引入依赖

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

(2)创建启动类ConfigServerApplication

@EnableConfigServer //开启配置服务
@SpringBootApplication
public class LyConfigServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(LyConfigServerApplication.class, args);
    }
}

(3)编写配置文件application.yml

spring:
  application:
    name: config-service
  cloud:
    config:
      server:
        git:
          uri: https://gitee.com/xxx/leyou-config.git
server:
  port: 12000

(4)浏览器测试:http://localhost:12000/item-dev.yml 可以看到配置内容

2.2 配置客户端

(1)在leyou_item_service工程添加依赖

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

(2)添加bootstrap.yml ,删除application.yml

spring:
  cloud:
    config:
      name: item #文件命名规则中应用名称
      profile: dev #文件命名规则中类型名称
      label: master #git仓库分支名称
      uri: http://127.0.0.1:12000 #配置中心地址

(3)测试: 启动工程ly_registry、ly_config、ly_item_service,看是否可以正常运行

2 消息总线组件SpringCloudBus

2.1 SpringCloudBus简介

​ 如果我们更新码云中的配置文件,那客户端工程是否可以及时接受新的配置信息呢?我们现在来做有一个测试,修改一下码云中的配置文件中mysql的端口 或者连接不同mysql服务器 ,然后测试数据依然可以查询出来,证明修改服务器中的配置并没有更新立刻到工程,只有重新启动程序才会读取配置。 那我们如果想在不重启微服务的情况下更新配置如何来实现呢? 我们使用SpringCloudBus来实现配置的自动更新。

2.2 代码实现

2.2.1 配置服务端

(1)修改ly_config工程的pom.xml,引用依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

(2)修改application.yml ,添加配置

spring:
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    virtual-host: /leyou
    username: leyou
    password: leyou
management: #暴露触发消息总线的地址
  endpoints:
    web:
      exposure:
        include: bus-refresh  #固定配置不要改成其它 例如:refresh

2.2.2 配置客户端

我们还是以商品微服务模块为例,加入消息总线

(1)修改ly_item_service工程 ,引入依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

(2)在码云的配置文件中配置rabbitMQ的地址:

spring:
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    virtual-host: /leyou
    username: leyou
    password: leyou

(3)启动ly_registry、ly_config、ly_item_service 看是否正常运行

(4)修改码云上的配置文件 ,将数据库连接IP 改为127.0.0.1 ,在本地部署一份数据库。

(5)postman测试 Url: http://127.0.0.1:12000/actuator/bus-refresh Method: post

(6)再次观察输出的数据是否是读取了本地的mysql数据。

2.2.3 自定义配置的读取

(1)修改码云上的配置文件,增加自定义配置

ly:
  sms:
    ip: 127.0.0.1

(2)在ly_item_service工程中新建controller

@RestController
public class TestController {
    @Value("${sms.ip}")
    private String ip;

    @RequestMapping(value = "/ip", method = RequestMethod.GET)
    public String ip() {
        return ip;
    }
}

(3)运行测试看是否能够读取配置信息 ,OK.

(4)修改码云上的配置文件中的自定义配置

sms:
  ip: 127.0.0.1

(5)通过postman测试 Url: http://127.0.0.1:12000/actuator/bus-refresh Method: post

测试后观察,发现并没有更新信息。

这是因为我们的 controller少了一个注解@RefreshScope 此注解用于刷新配置

@RefreshScope
@RestController
public class TestController {
    ///......
}

添加后再次进行测试。

2.2.4 完成乐优商城工程的配置集中管理

步骤:

(1)将每一个工程的配置文件提取出来,重命名

[外链图片转存失败(img-YYemaMsf-1568627793980)(F:/黑马102/JY/项目二资料/day12_服务鉴权及配置中心/笔记/assets/8_31.png)]

(2)将这些文件上传到码云

(3)修改每一个微服务工程,pom.xml中添加依赖

  <dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-config</artifactId>
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

(4)删除每一个微服务的application.yml

(5)为每一个微服务添加bootstrap.yml (参考ly_item_service工程)

(6)修改码云上的配置文件添加rabbitmq地址

spring:
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    virtual-host: /leyou
    username: leyou
    password: leyou

artifactId>


(4)删除每一个微服务的application.yml

(5)为每一个微服务添加bootstrap.yml  (参考ly_item_service工程)

(6)修改码云上的配置文件添加rabbitmq地址

spring:
rabbitmq:
host: 127.0.0.1
port: 5672
virtual-host: /leyou
username: leyou
password: leyou


标签:配置文件,spring,配置,leyou,springCloudBus,springConfig,config,cloud
来源: https://blog.csdn.net/prefect_start/article/details/100896083