资讯专栏INFORMATION COLUMN

天气数据API微服务 | 从0开始构建SpringCloud微服务(7)

zorro / 2962人阅读

摘要:本章主要讲解天气数据微服务的实现。在我们拆分成微服务架构之后调用第三方接口的行为由天气数据采集微服务中的定时任务进行。因此在天气数据微服务中我们的天气数据直接从缓存中进行获取,若在缓存中获取不到对应城市的数据,则直接抛出错误。

照例附上项目github链接

本项目实现的是将一个简单的天气预报系统一步一步改造成一个SpringCloud微服务系统的过程,本节主要讲的是单块架构改造成微服务架构的过程,最终将原来单块架构的天气预报服务拆分为四个微服务:城市数据API微服务,天气数据采集微服务,天气数据API微服务,天气预报微服务。

本章主要讲解天气数据API微服务的实现。


天气数据API微服务的实现 配置pom文件

对原来单块架构的天气预报服务进行改进,去除多余的依赖,最终的pom文件如下:





    4.0.0



    com.demo

    sifoudemo02

    0.0.1-SNAPSHOT

    jar



    sifoudemo02

    Demo project for Spring Boot



    

        org.springframework.boot

        spring-boot-starter-parent

        2.0.5.RELEASE

         

    



    

        UTF-8

        UTF-8

        1.8

    



    

        

            org.springframework.boot

            spring-boot-devtools

            true

        

     

        

            org.springframework.boot

            spring-boot-starter-web

        



        

            org.springframework.boot

            spring-boot-starter-test

            test

        

        

        

            org.slf4j

            slf4j-jdk14

            1.7.7

            

        

        

            org.springframework.boot

            spring-boot-starter-data-redis

        

    



    

        

            

                org.springframework.boot

                spring-boot-maven-plugin

                

                    true

                

                

            

        

     







提供接口

在service中保留如下接口:

(1)根据城市Id查询天气的接口getDataByCityId

(2)根据城市名称查询天气的接口getDataByCityName

注意:原来我们的天气数据是先从缓存中获取的,若查询不到则调用第三方接口获取天气信息,并将其保存到缓存中。

在我们拆分成微服务架构之后调用第三方接口的行为由天气数据采集微服务中的定时任务进行。

因此在天气数据API微服务中我们的天气数据直接从缓存中进行获取,若在缓存中获取不到对应城市的数据,则直接抛出错误。

@Service
public class WeatherDataServiceImpl implements WeatherDataService {
    private final static Logger logger = LoggerFactory.getLogger(WeatherDataServiceImpl.class);  
    
    private static final String WEATHER_URI = "http://wthrcdn.etouch.cn/weather_mini?";
    
    @Autowired
    private StringRedisTemplate stringRedisTemplate;
    
    @Override
    public WeatherResponse getDataByCityId(String cityId) {
        String uri = WEATHER_URI + "citykey=" + cityId;
        return this.doGetWeahter(uri);
    }

    @Override
    public WeatherResponse getDataByCityName(String cityName) {
        String uri = WEATHER_URI + "city=" + cityName;
        return this.doGetWeahter(uri);
    }
    
    private WeatherResponse doGetWeahter(String uri) {
        String key = uri;
        String strBody = null;
        ObjectMapper mapper = new ObjectMapper();
        WeatherResponse resp = null;
        ValueOperations  ops = stringRedisTemplate.opsForValue();
        // 先查缓存,缓存有的取缓存中的数据
        if (stringRedisTemplate.hasKey(key)) {
            logger.info("Redis has data");
            strBody = ops.get(key);
        } else {
            logger.info("Redis don"t has data");
            // 缓存没有,抛出异常
            throw new RuntimeException("Don"t has data!");
        }

        try {
            resp = mapper.readValue(strBody, WeatherResponse.class);
        } catch (IOException e) {
            //e.printStackTrace();
            logger.error("Error!",e);
        }
        
        return resp;
    }

}

在controller中提供根据城市Id和名称获取天气数据的接口。

@RestController
@RequestMapping("/weather")
public class WeatherController {
    @Autowired
    private WeatherDataService weatherDataService;
    
    @GetMapping("/cityId/{cityId}")
    public WeatherResponse getWeatherByCityId(@PathVariable("cityId") String cityId) {
        return weatherDataService.getDataByCityId(cityId);
    }
    
    @GetMapping("/cityName/{cityName}")
    public WeatherResponse getWeatherByCityName(@PathVariable("cityName") String cityName) {
        return weatherDataService.getDataByCityName(cityName);
    }
}



文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/73603.html

相关文章

  • 天气预报服务 | 0开始构建SpringCloud服务(8)

    摘要:本章主要讲解天气预报微服务的实现。获取城市列表改为由城市数据微服务来提供数据改为由城市数据微服务提供数据深圳猪猪的天气预报 照例附上项目github链接 本项目实现的是将一个简单的天气预报系统一步一步改造成一个SpringCloud微服务系统的过程,本节主要讲的是单块架构改造成微服务架构的过程,最终将原来单块架构的天气预报服务拆分为四个微服务:城市数据API微服务,天气数据采集微服务,...

    hyuan 评论0 收藏0
  • 0开始构建SpringCloud服务(1)

    摘要:照例附上项目链接本项目实现的是将一个简单的天气预报系统一步一步改造成一个微服务系统的过程,第一节将介绍普通天气预报系统的简单实现。创建在其中提供如下接口根据城市获取城市天气数据的接口。配置创建的配置类。 照例附上项目github链接 本项目实现的是将一个简单的天气预报系统一步一步改造成一个SpringCloud微服务系统的过程,第一节将介绍普通天气预报系统的简单实现。 数据来源: 数...

    Joonas 评论0 收藏0
  • 架构~服务

    摘要:接下来继续介绍三种架构模式,分别是查询分离模式微服务模式多级缓存模式。分布式应用程序可以基于实现诸如数据发布订阅负载均衡命名服务分布式协调通知集群管理选举分布式锁和分布式队列等功能。 SpringCloud 分布式配置 SpringCloud 分布式配置 史上最简单的 SpringCloud 教程 | 第九篇: 服务链路追踪 (Spring Cloud Sleuth) 史上最简单的 S...

    xinhaip 评论0 收藏0
  • 架构~服务 - 收藏集 - 掘金

    摘要:它就是史上最简单的教程第三篇服务消费者后端掘金上一篇文章,讲述了通过去消费服务,这篇文章主要讲述通过去消费服务。概览和架构设计掘金技术征文后端掘金是基于的一整套实现微服务的框架。 Spring Boot 配置文件 – 在坑中实践 - 后端 - 掘金作者:泥瓦匠链接:Spring Boot 配置文件 – 在坑中实践版权归作者所有,转载请注明出处本文提纲一、自动配置二、自定义属性三、ran...

    church 评论0 收藏0

发表评论

0条评论

zorro

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<