springcloud(2)服務提供者配置及叢集和資訊顯示改善
阿新 • • 發佈:2020-10-28
作為分散式的服務提供者自然是需要多個叢集作為支撐。同時將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進行註解。