1. 程式人生 > 實用技巧 >springcloud(2)服務提供者配置及叢集和資訊顯示改善

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進行註解。