server集群<--------->應用集群
1 搭建注冊中心(集群)
Maven
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.1.RELEASE</version>
</parent>
<!-- 管理依賴 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Finchley.M7</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<!--SpringCloud eureka-server -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
</dependencies>
<!-- 注意: 這里必須要添加, 否者各種依賴有問題 -->
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/libs-milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
1.1
server1 配置文件
###服務端口號
server:
port: 8100
###eureka 基本信息配置
eureka:
instance:
###注冊到eurekaip地址
hostname: 127.0.0.1
client:
serviceUrl:
defaultZone: http://server2_IP:port/eureka/,http://server3_IP:port/eureka/,.....
###因為自己是為注冊中心,不需要自己注冊自己
register-with-eureka: true
###因為自己是為注冊中心,不需要檢索服務
fetch-registry: true
server2 配置文件
###服務端口號
server:
port: 8200
###eureka 基本信息配置
spring:
application:
name: eureka-server
eureka:
instance:
###注冊到eurekaip地址
hostname: 127.0.0.1
client:
serviceUrl:
defaultZone: http://server1_IP:port/eureka/,http://server3_IP:port/eureka/,.....
###因為自己是為注冊中心,不需要自己注冊自己
register-with-eureka: true
###因為自己是為注冊中心,不需要檢索服務
fetch-registry: true
ps:
defaultZone: 指定地址 注冊到其他server,server之間互相注冊
3 啟動配的幾個server服務
@EnableEurekaServer @SpringBootApplication public class AppEureka { public static void main(String[] args) { SpringApplication.run(AppEureka.class, args); } }
現在可以登陸服務去看一下頁面效果

二 配置應用
1 maven
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.1.RELEASE</version>
</parent>
<!-- 管理依賴 -->
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Finchley.M7</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<!-- SpringBoot整合Web組件 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- SpringBoot整合eureka客戶端 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
</dependencies>
<!-- 注意: 這里必須要添加, 否者各種依賴有問題 -->
<repositories>
<repository>
<id>spring-milestones</id>
<name>Spring Milestones</name>
<url>https://repo.spring.io/libs-milestone</url>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
</repositories>
2 配置文件 指定注冊到哪個server ,name 指定自己在注冊中心叫什么名字
ps :若是一個應用部署在兩台機器 那么name:app-xxxxx指定相同 即可輪訓訪問應用
###服務啟動端口號 server: port: 8000 ###服務名稱(服務注冊到eureka名稱) spring: application: name: app-itmayiedu-member ###服務注冊到eureka地址 eureka: client: service-url: defaultZone: http://localhost:8100/eureka,... ###因為該應用為注冊中心,不會注冊自己 register-with-eureka: true ###是否需要從eureka上獲取注冊信息 fetch-registry: true
3 啟動服務(只提供服務:無法調用別人的服務)
@SpringBootApplication @EnableEurekaClient public class AppMember { public static void main(String[] args) { SpringApplication.run(AppMember.class, args); } }
4 調用其他服務(修改了啟動方式)
@SpringBootApplication @EnableEurekaClient public class AppOrder { public static void main(String[] args) { SpringApplication.run(AppOrder.class, args); } @Bean @LoadBalanced RestTemplate restTemplate() { return new RestTemplate(); }
@LoadBalanced就能讓這個RestTemplate在請求時擁有客戶端負載均衡的能力
public String getOrder() { // order 使用rpc 遠程調用技術 調用 會員服務 String memberUrl = "http://app-itmayiedu-member/getMember"; String result = restTemplate.getForObject(memberUrl, String.class); System.out.println("會員服務調用訂單服務,result:" + result); return result; }
