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-servermsa-weather-city-servermsa-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

  1. 进入微服务根目录,如E:\workspace\workspace-study\springcloud-study\imooc-spring-cloud-study\msa-weather-collection-eureka
  2. 通过gradlew build命令进行构建
  3. 构建完成后可以看到在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命令进入该目录
  4. 再通过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的管理页面,可以看到:
在这里插入图片描述
一个微服务有多个实例,这样的话,即使其中一个实例挂掉,只要还有一个实例在运行,整个微服务就还是可用的,实现了分布式系统中的高可用

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值