zoukankan      html  css  js  c++  java
  • API网关(一)

    API网关是对外服务的一个人口, 其隐藏了内部架构的实现, 是微服务架构中必不可 少的一个组件。API网关可以为我们管理大量的API接口, 还可以对接客户、适配协议、 进行安全认证、转发路由、限制流量、监控日志、防止爬虫、进行灰度发布等。

    随着业务的发展,服务越来越多,前端用户如何调用微服务就成了一个难题。比如用 户评估一个小区,评估完成之后需要展示小区详情、房价走势、成交数据、挂牌数据等, 这些信息都在不同的服务中,前端系统想要实现这么一个功能就需要和众多的服务进行交 互,调用它们提供的接口,这样性能肯定是低的。而且前端系统的逻辑更复杂了,它需要 知道所有提供信息的微服务。这个时候API网关的作用就体现出来了, 通过API聚合内部 服务, 提供统一对外的API接口给前端系统, 屏蔽内部实现细节。

    1.Zuul简介

    Zuul是Netflix OSS中的一员, 是一个基于JVM路由和服务端的负载均衡器。提供路由、监控、弹性、安全等方面的服务框架。Zuul能够与Eureka、Ribbon、Hystrix等组件配合使用。

    Zuul的核心是过滤器, 通过这些过滤器我们可以扩展出很多功能, 比如:

    ·动态路由:动态地将客户端的请求路由到后端不同的服务,做一些逻辑处理,比如聚合多个服务的数据返回。

    ·请求监控:可以对整个系统的请求进行监控,记录详细的请求响应日志,可以实时 统计出当前系统的访问量以及监控状态。

    ·认证鉴权:对每一个访问的请求做认证,拒绝非法请求,保护好后端的服务。

    ·压力测试:压力测试是一项很重要的工作,像一些电商公司需要模拟更多真实的用 户并发量来保证重大活动时系统的稳定。通过Zuul可以动态地将请求转发到后端服务的集群中,还可以识别测试流量和真实流量,从而做一些特殊处理。

    ·灰度发布:灰度发布可以保证整体系统的稳定,在初始灰度的时候就可以发现、调 整问题,以保证其影响度。

    2.使用Zuul构建微服务网关

    2.1 简单使用

    创建一个maven项目fangjia-fsh-api在pom.xml中增加Spring Cloud项目的依赖,然后加入Zuul的依赖:

    <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-zuul</artifactId>
            </dependency>

    配置文件信息:

    spring.application.name=fangjia-fsh-api
    server.port=2103
    #通过zuul.routes来配置路由转发,cxytiandi是自定义的名称
    #当访问cxytiandi/**开头的地址时就会跳转到http://baidu.com/上
    zuul.routes.cxytiandi.path=/cxytiandi/**
    zuul.routes.cxytiandi.url=http://baidu.com/

    接下来创建一个启动类,通过@EnableZuulProxy开启路由代理功能,代码如下:

    @SpringBootApplication
    @EnableZuulProxy
    public class ZuulApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(ZuulApplication.class, args);
        }
    }

    2.2 集成Eureka

    通过对上节的学习,我们已经可以简单的使用Zuul进行路由的转发了,在实际使用中我们通常是用Zuul来代理请求转发到内部的服务上去,同一为外部提供服务。

    内部服务的数量会很多,而且可以随时扩展,我们不可能增加一个服务就改一次路由的配置,所以也得通过结合Eureka来实现动态的路由转发功能。首先要添加Eureka的依赖:

    <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-starter-eureka</artifactId>
            </dependency>

    启动类不需要修改,因为@EnableZuulProxy已经自带了@EnableDiscoveryClient,只需在配置文件中增加Eureka的地址即可:

    eureka.client.serverUrl.defaultZone=http://yinjihuan:123456@master:8761/eureka/

    重启服务,我们可以通过默认的转发规则来访问Eureka中的服务。比如访问我们之前定义的hello接口,就相当于通过http://localhost:2013/fsh-house/house/hello来访问fsh-house服务中的hello接口。访问规则是“API网关地址+访问的服务名称+接口URI”。


    11

  • 相关阅读:
    1040 Longest Symmetric String (25)
    1068 Find More Coins (30)
    1045 Favorite Color Stripe (30)
    1008 数组元素循环右移问题 (20)
    1007. 素数对猜想
    1005. 继续(3n+1)猜想 (25)
    1001. 害死人不偿命的(3n+1)猜想 (15)
    递归经典面试题_ 小例
    简单实现_控制台小时钟
    使用Timer组件_实现定时更改窗体颜色
  • 原文地址:https://www.cnblogs.com/xc-xinxue/p/12459955.html
Copyright © 2011-2022 走看看