springcloud(2)服务提供者配置及集群和信息显示改善

作为分布式的服务提供者自然是需要多个集群作为支撑。同时将eureka页面里的显示信息进行一定的改善。

1.pom文件的依赖

<dependencies>  
        <dependency>
            <groupId>com.bai</groupId>
            <artifactId>cloud-api-common</artifactId>
            <version>${project.version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--监控-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
        </dependency>
        <!--eureka client-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <!--如果没写版本,从父层面找,找到了就直接用,全局统一-->
        </dependency>
        <!--mysql-connector-java-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--jdbc-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <!--热部署-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

2.yml文件

配置服务提供者的集群和eureka有点区别,在自己的yml文件中注册所有的eureka的地址。

instance-id是eureka界面里的应用名称。相比之前的名称做了一定的优化。

prefer-ip-address是增加了在点对应的应用名称的时候可以看出该服务对应的ip地址是什么。

server:
    port: 8001
spring:
  application:
    name: cloud-payment-service
  datasource:
    # 当前数据源操作类型
    type: com.alibaba.druid.pool.DruidDataSource
    # mysql驱动类
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://localhost:3306/cloud2020?serverTimezone=GMT%2B8
    username: root
    password: root
mybatis:
    mapper-locations: classpath*:mapper/*.xml
    type-aliases-package: com.bai.pojo
eureka:
    client:
      #表示是否将自己注册进EurekaServer默认为true
      register-with-eureka: true
      #是否从EurekaServer抓取已有的注册消息,默认为true,单节点无所谓,集群必须设置为true才能配合ribbon使用负载均衡
      fetch-registry: true
      service-url:
        #集群版
        defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/
        #单机版
#        defaultZone: http://localhost:7001/eureka
    instance:
      instance-id: payment8001
      prefer-ip-address: true

3.主启动类

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

后续在应用中会慢慢的把EnableEurekaClient注解替换成EnableDiscoveryClient使用。

4.discovery

服务发现discovery,将服务自身的一些信息暴露出来,自己可以访问到自己的一些信息,如服务名,端口号,地址。

在controller中进行测试。

 @Resource
    private DiscoveryClient discoveryClient;
@GetMapping("/payment/discovery")
    public Object discovery() {
         List<String> services = discoveryClient.getServices();
         for (String elment : services) {
             log.info("....elment:" + elment);
         }
         List<ServiceInstance> instances = discoveryClient.getInstances("CLOUD-PAYMENT-SERVICE");
         for(ServiceInstance elment:instances){
             log.info(elment.getServiceId()+"\t"+elment.getHost()+"\t"+elment.getPort()+"\t"+ elment.getUri());
         }
        return this.discoveryClient;
     }

可以在控制台上看到对应的一些信息。

同时主启动类中的EnableEurekaClient注解替换成EnableDiscoveryClient使用,

此后也是用EnableDiscoveryClient进行注解。

 本篇所有代码均在GitHub:

posted @ 2020-10-28 16:16  梦泽千秋  阅读(161)  评论(0编辑  收藏  举报