推广

第2篇:使用spring cloud gateway

iseeyu2年前 (2024-02-22)推广130

image.png

gateway作用类似这样. 通过设计一层gateway, 后面就可以挂n多个微服务, 不用考虑调用的是哪个微服务, gateway 都会帮你做好. 那么它和Nginx 有啥区别呢? 区别主要在:

  • 它是spring cloud生态的产品, 和spring 天然契合
  • 它的功能比Nginx 更多, 神马安全,监控/指标,和限流基本都是配置式实现. 而Nginx 要自己写脚本.
  • 它的性能比Nginx 稍弱. 如果只是路由到微服务, 用它更好. 如果需要提供静态资源, 那么还是Nginx更好.
  • 在前后端分离的架构设计中, 一般都会把他们共用. 例如我司用Vue做前端, 那么就是Vue -> Nginx -> Gateway -> 微服务 这样子的设计架构.

如下图:

image.png

(图形来自于网络, 感谢作者: https://lzyz.fun/bloglist/nginxs-gateway/ )

关于更多的功能介绍会在代码里体现.

gateway 工程主要代码介绍

工程在这里: https://gitee.com/xiaofeipapa/spring-cloud-demo
本章工程目录是: gateway-demo

代码结构图如下:

image.png

启动类代码

package org.xiaofeipapa.feimall.backGateway;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;

@SpringBootApplication
@EnableAutoConfiguration(exclude={DataSourceAutoConfiguration.class})
@EnableDiscoveryClient
public class BackGatewayApplication
{
    public static void main( String[] args )
    {
        SpringApplication.run(BackGatewayApplication.class, args);
    }
}

可以看到启动类代码和普通spring boot 工程的启动类代码区别不大, 也就是加了 @EnableDiscoveryClient 这个注解.

主要的实现功能在配置文件

注册到 Consul

打开 bootstrap.yml , 这是注册到Consul的配置文件. 和其他工程没什么区别

spring:
  application:
    name: back-gateway

  cloud:
    consul:
      host: localhost
      port: 8500
      discovery:
        # 健康检查 一定要配置 结合 spring-boot-starter-actuator 使用
        health-check-path: /actuator/health
        health-check-interval: 10s

实现路由功能

打开 application.yaml, 可以看到:

spring:
  profiles:
    active: dev
  cloud:
    gateway:
      routes:
        - id: user_route
          uri: lb://user-api
          predicates:
            - Path=/api/user/**
          filters:
            - RewritePath=/api/user/(?<segment>.*),/$\{segment}

        - id: order_route
          uri: lb://order-api
          predicates:
            - Path=/api/order/**
          filters:
            - RewritePath=/api/order/(?<segment>.*),/$\{segment}

        #...省略其他配置项

别看配置文件花里花哨, 其实很好理解:

  • -id: 表示一个唯一的名称. 不同service 的id 必须不同.
  • uri: lb 表示 Load balance 的意思. user-api 是我们之前在Consul 注册的服务名称(并且该服务可能有多个实例). 这一整段表示: gateway 会自动查找可用的实例以提供服务, 不用你操心.
  • predicates: 表示 uri的路径. 如果符合这个uri, 才会进行上述调用
  • filters : gateway 会有一系列的filter 对url 进行操作. 这里是一个简单操作: 将uri 重写. 这些概念如果熟悉springmvc 就会很熟悉, 不再赘述.

刚开始的时候不熟悉, 其实用久了也就是复制粘贴. 慢慢再理解加深下印象.

启动测试

现在, 在idea里启动 orderApi工程, 并且在命令行里启动另一个实例(实例命令如下):

# 请记得将maven/bin配置到环境路径
mvn package 
java -jar -Dspring.profiles.active=inst2  target/orderApi-0.0.1-SNAPSHOT.jar

启动 gateway 工程. 启动完毕之后, 你应该在Consul 里看到这样的服务:

image.png

用浏览器访 localhost:10000/api/order/hello , 你就会看到如下字样:

image.png

如果你再次敲击浏览器的回, 就会看到这样:

image.png

多次敲击浏览器的回车, 你会发现 11000 和 11003 交替出现. 这是很正常的, spring cloud 集成了 ribbon, 默认的负载均衡策略就是轮询. 如果你想了解更多的策略, 查手册改写这个工程即可.

测试性能

(如果你是windows 系统, 请自行安装 apache ab )

ab -n50000 -c5000 http://localhost:10000/api/order/hello

在我的电脑上, 第一次访问平均用时 3900 ms 左右, 第二次及以后的访问都在900ms. 这说明两个问题. 一, gateway 需要预热. 二, 预热完成之后, 性能还是不错的. (看了一下内存占用, 好家伙, 短时间增加了500m)

基础的gateway 教程就结束了. 下一章开始总结限流, 熔断这些高级知识.

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/56331.html

相关文章

搜索引擎的爬行问题知识

搜索引擎的爬行问题知识

搜索引擎的爬行搜索引擎怎么爬行? 关于搜索引擎的爬行问题,这个是初学者必须要了解的相关的情况,如果你是一个初学者的话,建议大家了解这方面的知识。 (一)、蜘蛛程序。 蜘蛛程序是搜索引擎的关键部分,它主要负责在网上进行定位和索引网页,这样的话就能够响应搜索者的搜索要求。成功的搜索...

史上最全安卓应用市场免费资源申请详解!

史上最全安卓应用市场免费资源申请详解!

  这是史上最全的安卓应用市场免费资源申请详解,干货满满,boss们多多关注! 主流应用市场首发资源 应用上线前,最好了解一下各个市场的上线规则,如果首发,应用市场一般会给予App免费且优质的展示坑位,一定程度上会促进App的下载量。 需要注意,有些市场是不接受联合首发的...

什么是万词霸屏?万词霸屏推广的优缺点有哪些?

想必很多做网络的朋友都听到过万词霸屏的推销电话,这是最近几年炒起来的一种推广方法。魔豆表示所谓的霸屏指的是当你搜索某个关键词的时候,别人看到的搜索引擎结果页面全部都是你的网页。这个词在网络推广领域早就有,后来被一类公司借用了,现在提起霸屏推广都知道是一种推广方式了。 什...

快手小游戏推广0门槛,新手一天赚700

大家好,我是铭则,前几天我开了今年第一个带的,也是最近手把手带的,组建团队搞得,就是快手小游戏合伙人项目,这个项目现在一共有30人报名了最早的报名的朋友,已经是了一个多星期了,说实话,收获真的是可以,快的操作了2天,就一天100多块,大约有8个人有每天100左右的收益,别看...

内容运营要怎么做?分享一个内容运营操作心得

谈谈运营的方向,在哪些平台上进行内容运营,以及做哪些内容的运营。内容运营包括图文运营和视频运营这两种形式。图文的运营,也就是你写相应的文章,在平台上发文章,包括微信公众号、百度百家号、知乎、简书、小红书,微博等,因为所有这些内容都可以面向搜索引擎收到。比如在微信上搜索可以搜...

营销型网站的首页怎么布局。

营销型网站的首页怎么布局。

对来说,首页是很重要的,一个营销型网站的首页应该要能体现出这个网站的主题,它能引导用户去访问整个网站的页面,具有一个指引的作用。那么应该如何去布局营销型网站的首页呢? 页面的层次设计用户访问网站究竟有什么样的目的呢?需要什么样的信息内容呢?那么,在网站首页中,就要按照内容的先后顺序,合理...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片