用Zuul开发微服务网关
data:image/s3,"s3://crabby-images/71153/7115343cc00ccaedec23509f1110820c050c6d76" alt=""
这三个依赖以及web一定要有
data:image/s3,"s3://crabby-images/44c32/44c320778ea2f886710d802a50cf7d9c87014f78" alt=""
修改成这个,然后从同一配置中心获取api-gateway服务的配置
data:image/s3,"s3://crabby-images/0eac0/0eac0946052546d1d8b40acc3850149c53ea7362" alt=""
启动项目,确认能正常启动后,在API-gateway服务的启动类加上EnableZuulProxy注解,再次启动项目
data:image/s3,"s3://crabby-images/15f32/15f32a761ce96c46f1f6900c8eb6303642f7dded" alt=""
现在我启动的服务有eureka(8761)、config(8088)、product(8080)、API-gateway(8060),没有这些服务的请看我之前的文章。
先通过直接访问product(8080)项目,看看product/list接口是否正常,如下所示,正常返回数据
data:image/s3,"s3://crabby-images/ef51c/ef51cc96e6e11b67b4a9f55bf87d5c36f27550e6" alt=""
现在通过API-gateway(8060)服务访问product服务的product/list接口,也能返回数据
完整路径:8060/product/product/list
即:API-gateway服务端口/对应的服务名称/实际的URL
data:image/s3,"s3://crabby-images/e87b3/e87b3ff41a22bb62fd9fb5d711e31be7dd8a5789" alt=""
如果不想直接显示对应服务名称,可以采用如下配置进行,例如product服务,我现在通过zuul访问时采用myProduct访问
data:image/s3,"s3://crabby-images/6d5ae/6d5ae5416b54b345e8757724843293684026e4e8" alt=""
通过myProduct方式访问成功
data:image/s3,"s3://crabby-images/54e23/54e234485e04040a62a94d03b6888d46ce624178" alt=""
此外还有一种简洁的写法如下
data:image/s3,"s3://crabby-images/2cbce/2cbce548498243a8b318936f1f59d64df9ad46c3" alt=""
查看所有路由的访问规则:application/routes
data:image/s3,"s3://crabby-images/c31eb/c31ebe4114b847391d97d5480aae25026397509c" alt=""
data:image/s3,"s3://crabby-images/bc783/bc783b6c6365f203ce40b5da4e21cc38b9404faa" alt=""
禁止某些路由被访问:
比如禁止访问product服务里面有个product/test接口地址
data:image/s3,"s3://crabby-images/8eea8/8eea8061a41cff2262e33e392a78f44d3eba71b3" alt=""
这个地址就被禁止访问了
data:image/s3,"s3://crabby-images/8bfea/8bfea0859628e55d3179d4485ab113fa630ef662" alt=""
上面的配置由于有别名所以要写两个地址,其实也可以用通配符的方式
data:image/s3,"s3://crabby-images/ed68a/ed68ab05a38ce2d6cd43a07d78b31453630250b8" alt=""
如果product想要获得http请求的敏感信息如cookie等,还需要配置一下sensitiveHeaders,如下面的,留空即可
data:image/s3,"s3://crabby-images/95e57/95e578eb436ba11dfd50e8b41171ad43d80e3a75" alt=""
zuul的高可用
api-gateway的本质也是一个微服务,所以它的高可用和普通服务一样,都是部署多个服务节点,然后注册到Eureka Server,对内照样是通过Ribbon的负载均衡策略进行转发,对外就采用Nginx+Zuul的混搭,用Nginx去做集群的负载均衡、转发。
代码: https://github.com/hmilyos/springCloud-api-gateway.git base分支