网关高可用

单点是系统高可用的大敌,单点往往是系统高可用最大的风险和敌人,应该尽量在系统设计的过程中避免单点。方法论上,高可用保证的原则是“集群化”,或者 叫“冗余”:只有一个单点,挂了服务会受影响;如果有冗余备份,挂了还有其他backup能够顶上。

 (1) 准备多个GateWay工程

server:
  port: 8080 #服务端口
-------------------------------------------
server:
  port: 8081 #服务端口
-------------------------------------------
spring:
  application:
    name: api-gateway #指定服务名
  cloud:
    gateway:
      routes:
      - id: product-service
        uri: lb://service-product  #根据微服务名从注册中心拉取微服务请求路径
        predicates:
        - Path=/product-service/**   #/product-service/product/1 重写为 /product/1 ---> 192.168.1.1:9001/product/1
        filters:  #配置路由过滤器
          - RewritePath=/product-service/(?<segment>.*), /$\{segment}  #路径重写的过滤器,yml中$ --> $\

      discovery:
        locator:
          enabled: true   #开启根据微服务名自动转发
          lower-case-service-id: true  #微服务名称小写形式呈现

#配置Eureka
eureka:
  client:
    register-with-eureka: false #是否将自己注册到注册中心
    service-url:
      defaultZone: http://localhost:9000/eureka/
      registry-fetch-interval-seconds: 10  # 从Eureka拉取服务器配置信息的周期,设置为 10s
  instance:
    prefer-ip-address: true #使用ip地址注册

 (2) 配置ngnix

#配置多台服务器(这里只在一台服务器上的不同端口)
upstream gateway {
    server 127.0.0.1:8081;
    server 127.0.0.1:8080;
}
#请求转向mysvr 定义的服务器列表
location / {
    proxy_pass http://gateway;
}

上一页              下一页

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值