Spring Cloud学习笔记15——天气预报系统实现服务的注册与实现
开发环境
JDK8+
Gradle4+
Redis 3.2.100
Spring Boot 2.0.0.M3
Spring Cloud Starter Netflix Eureka Client Finchley.M2
创建项目
复制之前的msa-weather-collection-server
项目,将副本改名为msa-weather-collection-eureka
修改源码
修改build.gradle
配置,修改Spring Boot
版本、指定Spring Cloud
版本、添加Eureka Client
依赖、添加Spring Cloud
依赖管理:
//buildscript代码块中脚本优先执行
buildscript {
//ext用于定义动态属性
ext {
springBootVersion = '2.0.0.M3'
}
//使用了Maven的*仓库及Spring自己的仓库(也可以指定其他仓库)
repositories {
//mavenCentral()
maven{ url "https://repo.spring.io/snapshot" }
maven{ url "https://repo.spring.io/milestone" }
maven{ url "http://maven.aliyun.com/nexus/content/groups/public/" }
}
//依赖关系
dependencies {
//classpath声明了在执行其余的脚本时,ClassLoader可以使用这些依赖项
classpath("org.springframework.boot:spring-boot-gradle-plugin:${springBootVersion}")
}
}
//使用插件
apply plugin: 'java'
apply plugin: 'eclipse'
apply plugin: 'org.springframework.boot'
apply plugin: 'io.spring.dependency-management'
//指定了生成的编译文件的版本,默认是打成了jar包
group = 'com.study.spring.cloud'
version = '1.0.0'
//指定编译.java文件的JDK版本
sourceCompatibility = 1.8
//使用了Maven的*仓库及Spring自己的仓库(也可以指定其他仓库)
repositories {
//mavenCentral()
maven{ url "https://repo.spring.io/snapshot" }
maven{ url "https://repo.spring.io/milestone" }
maven{ url "http://maven.aliyun.com/nexus/content/groups/public/" }
}
ext {
springCloudVersion = 'Finchley.M2'
}
//依赖关系
dependencies {
//该依赖用于编译阶段
compile('org.springframework.boot:spring-boot-starter-web')
//HttpClient
compile('org.apache.httpcomponents:httpclient:4.5.6')
//Redis
compile('org.springframework.boot:spring-boot-starter-data-redis')
//Quartz
compile('org.springframework.boot:spring-boot-starter-quartz')
//Eureka Client
compile('org.springframework.cloud:spring-cloud-starter-netflix-eureka-client')
//该依赖用于测试阶段
testCompile('org.springframework.boot:spring-boot-starter-test')
}
//Spring Cloud依赖管理
dependencyManagement{
imports{
mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
}
}
其他三个微服务(msa-weather-data-server
、msa-weather-city-server
、msa-weather-report-server
)同上创建项目、修改源码操作,得到如下四个新的微服务:
修改天气数据采集微服务
修改com.study.spring.cloud.weather
包下的Application
类,加入@EnableDiscoveryClient
注解:
package com.study.spring.cloud.weather;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
/*
* @SpringBootApplication注解声明Spring Boot应用
* 作用等同于@Configuration, @EnableAutoConfiguration, @ComponentScan,
* 简化Spring配置
*/
@SpringBootApplication
//启用可发现的客户端
@EnableDiscoveryClient
//Application类一定要处于整个工程的根目录下,这样它才能根据配置去扫描子节点下的Spring的Bean
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
修改application.properties
配置文件:
#应用名称
spring.application.name=msa-weather-collection-eureka
#注册服务器的URL
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
修改天气数据API微服务
修改com.study.spring.cloud.weather
包下的Application
类,加入@EnableDiscoveryClient
注解:
package com.study.spring.cloud.weather;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
/*
* @SpringBootApplication注解声明Spring Boot应用
* 作用等同于@Configuration, @EnableAutoConfiguration, @ComponentScan,
* 简化Spring配置
*/
@SpringBootApplication
//启用可发现的客户端
@EnableDiscoveryClient
//Application类一定要处于整个工程的根目录下,这样它才能根据配置去扫描子节点下的Spring的Bean
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
修改application.properties
配置文件:
#应用名称
spring.application.name=msa-weather-data-eureka
#注册服务器的URL
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
修改城市数据API微服务
修改com.study.spring.cloud.weather
包下的Application
类,加入@EnableDiscoveryClient
注解:
package com.study.spring.cloud.weather;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
/*
* @SpringBootApplication注解声明Spring Boot应用
* 作用等同于@Configuration, @EnableAutoConfiguration, @ComponentScan,
* 简化Spring配置
*/
@SpringBootApplication
//启用可发现的客户端
@EnableDiscoveryClient
//Application类一定要处于整个工程的根目录下,这样它才能根据配置去扫描子节点下的Spring的Bean
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
修改application.properties
配置文件:
#应用名称
spring.application.name=msa-weather-city-eureka
#注册服务器的URL
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
修改天气预报微服务
修改com.study.spring.cloud.weather
包下的Application
类,加入@EnableDiscoveryClient
注解:
package com.study.spring.cloud.weather;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
/*
* @SpringBootApplication注解声明Spring Boot应用
* 作用等同于@Configuration, @EnableAutoConfiguration, @ComponentScan,
* 简化Spring配置
*/
@SpringBootApplication
//启用可发现的客户端
@EnableDiscoveryClient
//Application类一定要处于整个工程的根目录下,这样它才能根据配置去扫描子节点下的Spring的Bean
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
修改application.properties
配置文件:
#热部署静态文件
spring.thymeleaf.cache=false
#应用名称
spring.application.name=msa-weather-report-eureka
#注册服务器的URL
eureka.client.service-url.defaultZone=http://localhost:8761/eureka/
运行
先在IDE
中启动micro-weather-eureka-server
,再通过命令行指定端口来启动其他四个微服务,避免IDE
启动全都要占据8080
端口,注意要先启动Redis
:
- 进入微服务根目录,如
E:\workspace\workspace-study\springcloud-study\imooc-spring-cloud-study\msa-weather-collection-eureka
- 通过
gradlew build
命令进行构建 - 构建完成后可以看到在
E:\workspace\workspace-study\springcloud-study\imooc-spring-cloud-study\msa-weather-collection-eureka\build\libs
目录下生成了msa-weather-collection-eureka-1.0.0.jar
,通过cd build\libs
命令进入该目录 - 再通过
java -jar msa-weather-collection-eureka-1.0.0.jar --server.port=8081
命令来指定端口运行该jar
包
四个微服务都同此操作,注意指定不同的运行端口。
访问http://localhost:8761
页面,可以看到Eureka
的管理页面:
同一个微服务可以在不同端口启动多个实例,例如进入E:\workspace\workspace-study\springcloud-study\imooc-spring-cloud-study\msa-weather-collection-eureka\build\libs
目录,运行java -jar msa-weather-collection-eureka-1.0.0.jar --server.port=8085
命令,刷新Eureka
的管理页面,可以看到:
一个微服务有多个实例,这样的话,即使其中一个实例挂掉,只要还有一个实例在运行,整个微服务就还是可用的,实现了分布式系统中的高可用