写在前面

网关的作用不在此赘述,举个最常用的例子,我们搭建了微服务,前端挪用各服务接口时,由于各服务接口不一样,若是让前端同事划分挪用,前端同事会疯的。而网关就可以解决这个问题,网关屏障了各营业服务的端口,对前端同事来说,他们只卖力挪用网关服务端口下的服务就可以了。本文简朴形貌若何使用Spring Cloud全家桶中的网关服务,再配以Nacos。关于Nacos简朴应用,可以看我其他博客。

服务提供者

从https://start.spring.io/下载一个原始的spring boot工程,若何下载就不在这里说了。添加依赖:

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
  <version>2.2.1.RELEASE</version>
</dependency>
<dependency>
  <groupId>com.alibaba.cloud</groupId>
  <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
  <version>2.2.1.RELEASE</version>
</dependency>

划分添加了web依赖、设置中央依赖和注册中央依赖。

设置文件如下:

 

server.port=8070
spring.application.name=service-provider
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848

 

启动类如下:

package com.chris.springboot;

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


@SpringBootApplication
@EnableDiscoveryClient
public class MySpringbootApplication {

    public static void main(String[] args) {
        SpringApplication.run(MySpringbootApplication.class, args);
    }
}

接口类如下:

package com.chris.springboot.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/provider")
@RefreshScope
public class ConfigController {

    @Value(value = "${Hello:123}")
    private String hello;

     @GetMapping("/helloProvider")
        public String helloProvider(){
            return hello;
        }
}

此服务为我的博客:https://www.cnblogs.com/ncwuwsh/p/12732516.html中的服务,可参看。

网关服务

从https://start.spring.io/下载一个原始的spring boot工程,若何下载就不在这里说了。添加依赖:

     <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.2.1.RELEASE</version>
        </dependency>

注重,万万不要添加web依赖。

设置文件可以使用properties,也可以使用yml花样。yml花样如下:

server:
  port: 8080
spring:
  application:
    name: api-gateway
  cloud:
    nacos: 
      discovery: 
        server-addr: 127.0.0.1:8848
    gateway:
      discovery:
        locator:
          enabled: true #解释gateway开启服务注册和发现的功效,而且spring cloud gateway自动凭据服务发现为每一个服务创建了一个router,这个router将以服务名开头的请求路径转发到对应的服务。
          lower-case-service-id: true #是将请求路径上的服务名设置为小写(由于服务注册的时刻,向注册中央注册时将服务名转成大写的了),好比以/service-hi/*的请求路径被路由转发到服务名为service-hi的服务上。
      routes:
        - id: gateway-service
          uri: lb://service-provider #此设置的值注册到Nacos中服务提供者的spring.application.name的值
          predicates:
            - Path=/provider/**

使用yml的同砚,一定要去查下yml的一些规则,好比 :后面,值的前面,一定要有空格,缩进不要使用tab键,而要用两个空格缩进等

下面是properties花样设置文件:

server.port=8080
spring.application.name=api-gateway
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
#解释gateway开启服务注册和发现的功效,而且spring cloud gateway自动凭据服务发现为每一个服务创建了一个router,这个router将以服务名开头的请求路径转发到对应的服务。
spring.cloud.gateway.discovery.locator.enabled=true
#是将请求路径上的服务名设置为小写(由于服务注册的时刻,向注册中央注册时将服务名转成大写的了),好比以/service-hi/*的请求路径被路由转发到服务名为service-hi的服务上。
spring.cloud.gateway.discovery.locator.lower-case-service-id=true
spring.cloud.gateway.routes[0].id=gateway-service
spring.cloud.gateway.routes[0].uri=lb://service-provider
spring.cloud.gateway.routes[0].predicates[0]=Path=/provider/**

下面是网关的启动类:

package com.chris.gatewayrouter;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.gateway.route.RouteLocator;
import org.springframework.cloud.gateway.route.builder.RouteLocatorBuilder;
import org.springframework.context.annotation.Bean;

@SpringBootApplication
@EnableDiscoveryClient
public class GatewayrouterApplication {

    public static void main(String[] args) {
        SpringApplication.run(GatewayrouterApplication.class, args);
    }
    
    @Bean
    public RouteLocator myRoutes(RouteLocatorBuilder builder) {
        return builder.routes().build();
    }

}

 

然后启动Nacos,服务提供者和网关服务,使用浏览器接见:http://127.0.0.1:8080/provider/helloProvider

搞定。

网关服务的其他高级应用,自己去看官网吧。

官网是最好的先生

 

,

诚信在线

诚信在线(www.ludiealliedinstitute.com)现已开放诚信在线手机版下载。游戏公平、公开、公正,用实力赢取信誉。

Allbet欧博官网声明:该文看法仅代表作者自己,与本平台无关。转载请注明:嘉兴娱乐:Spring Cloud Gateway+Nacos,yml+properties两种配置文件方式搭建网关服务
评论关闭

分享到:

东营家政:根本仙女下凡!土耳其正妹电竞选手引《英雄联盟》玩家热议