Spring Cloud Gateway + Nacos(1)简单配置
当初我学习时候就是参考这位大佬的博客: Nacos集成Spring Cloud Gateway 基础使用
现在学习到spring cloud alibaba 使用nacos做服务中心,dubbo做通信,大体流程就是:
先制定要的接口打包上传到云。提供者和消费者都依赖这个接口包
而后新建提供者模块来实现接口,再将服务注册到nacos上面
新建消费者模块来使用接口,消费者去nacos上面寻找提供者根据服务名
消费者到nacos和nacos到提供者都是使用dubbo通信实现。
本篇博客只介绍网关到消费者。首先先创建消费者如下:
1. 新建maven模块nacos-consumer1添加pom依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--nacos注册发现依赖-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--如果使用本地nacos,此依赖可以省略,因为云端nacos启动时候会检测云端配置-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2. 在resources下新建文件bootstrap.yml文件
注:nacos是区分yaml和yml格式的,虽然本地加载时候是会区分的,但是使用云端配置时候就得严格使用yml文件类型,而且本地yaml文件是没有代码提醒的。至于application.yml、application.properties和bootstrap.yml的区别可以百度了解。
server:
port: 8011 #consumer2的端口是8012
spring:
application:
name: nacos-consumer
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
namespace: 5467517c-4121-4275-b459-b92a7a12f508
# nacos上面新建命名空间的id
config: # 本地一般不需要配置中心,如果使用云nacos会报找不到配置的错误,
#这时候需要配置上,或者config.enable: false关闭即可
server-addr: 127.0.0.1:8848
namespace: 5467517c-4121-4275-b459-b92a7a12f508
consumer2上面只是端口不一样,服务名nacos-consumer是一样的,为了测试负载均衡。
3. 创建controller类com.example.controller.HelloController.java
@RestController
@RequestMapping("/testhello")
public class HelloController {
@GetMapping("/hello")
public String HelloController(){
// consumer2则修改返回值为consumer2
return "This is nacos-consumer1";
}
}
4. 创建启动类com.example.NacosConsumerOneApplication
@SpringBootApplication
public class NacosConsumerOneApplication {
// consumer创建Two,有区分即可
public static void main(String[] args) {
SpringApplication.run(NacosConsumerOneApplication.class, args);
}
}
5. 接下来创建网关模块nocas-gateway,引入pom依赖
<!--nacos注册发现依赖-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--如果使用本地nacos,此依赖可以省略,因为云端nacos启动时候会检测云端配置-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
6. 然后在resources下面创建bootstrap.yml文件
server:
port: 8001
spring:
application:
name: nacos-consumer
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
namespace: 5467517c-4121-4275-b459-b92a7a12f508
# nacos上面新建命名空间的id
config: # 本地一般不需要配置中心,如果使用云nacos会报找不到配置的错误,
#这时候需要配置上,或者config.enable: false关闭即可
server-addr: 127.0.0.1:8848
namespace: 5467517c-4121-4275-b459-b92a7a12f508
gateway:
discovery:
locator:
enabled: true #默认false,开启后可以通过ip:port/服务名称/接口地址进行服务转发
# 即: localhost:8001/nacos-consumer/testhello/hello
lower-case-service-id: true #把服务名转换为小写,Eureka 中默认都是大写
#但是nacos不会自动全部转换为大写,除非手动写成大写,所以也可以不写。
routes: # 路由转发:最重要的地方
- id: nacos-gateway-provider #路由的ID,没有固定规则但要求唯一,建议配合服务名
uri: lb://nacos-consumer #匹配后提供服务的路由地址,lb代表负载均衡
predicates:
- Path=/testhello/hello #断言,路径相匹配的进行路由转发
比起消费者来说,网关这里就多了gateway部分,那么将其中可以省略的地方省去就是添加:
server:
port: 8001
spring:
application:
name: nacos-consumer
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
namespace: 5467517c-4121-4275-b459-b92a7a12f508
# nacos上面新建命名空间的id
config: # 本地一般不需要配置中心,如果使用云nacos会报找不到配置的错误,
#这时候需要配置上,或者config.enable: false关闭即可
server-addr: 127.0.0.1:8848
namespace: 5467517c-4121-4275-b459-b92a7a12f508
gateway:
routes: # 路由转发:最重要的地方
- id: nacos-gateway-provider #路由的ID,没有固定规则但要求唯一,建议配合服务名
uri: lb://nacos-consumer #匹配后提供服务的路由地址,lb代表负载均衡
predicates:
- Path=/testhello/hello #断言,路径相匹配的进行路由
7. 接下来创建com.example.NacosGatewayApplication.java
@SpringBootApplication
public class NacosGatewayApplication {
public static void main(String[] args) {
SpringApplication.run(NacosGatewayApplication.class, args);
}
}
8. 启动两个消费者,一个网关测试端口
本地nacos登录 http://127.0.0.1:8848/nacos/index.html ,账号密码都是nacos就可以看到配置和服务.
可以通过 http://localhost:8011 和 8012/testhello/hello 测试消费者,就是两个正常的controller
网关启动后通过网关 localhost:8001.testhello/hello 能转发到上面其中一个
测试 http://localhost:8001/testhello/hello 并且不断刷新显示内容会在两个消费者之间相互切换。这就是
负载均衡,当然是默认的负载均衡算法,我们也可以自定义。
9. 在标题6中若开启了gateway.discovery.locator.enabled=true
那么网关可以将 http://localhost:8001/nacos-consumer/testhello/hello 识别转发,若关闭则404.

这就是gateway+nacos最基础的配置方法,之后会大概写谓词predicates中的内容和过滤器filter的笔记。
学无止境,代码与生活,谁也不能亏待了。 2021-05-12 22:48:40 星期三
Spring Cloud Gateway + Nacos(1)简单配置的更多相关文章
- Spring Cloud 整合 nacos 实现动态配置中心
上一篇文章讲解了Spring Cloud 整合 nacos 实现服务注册与发现,nacos除了有服务注册与发现的功能,还有提供动态配置服务的功能.本文主要讲解Spring Cloud 整合nacos实 ...
- Spring Cloud Gateway+Nacos,yml+properties两种配置文件方式搭建网关服务
写在前面 网关的作用不在此赘述,举个最常用的例子,我们搭建了微服务,前端调用各服务接口时,由于各服务接口不一样,如果让前端同事分别调用,前端同事会疯的.而网关就可以解决这个问题,网关屏蔽了各业务服务的 ...
- Spring Cloud Gateway 跨域 CORS 配置方式实现
网上找了一堆文章全是说这样写无效 globalcors: cors-configurations: '[/**]': allowCredentials: true allowedOriginPatte ...
- springcloud3(五) spring cloud gateway动态路由的四类实现方式
写这篇博客主要是为了汇总下动态路由的多种实现方式,没有好坏之分,任何的方案都是依赖业务场景需求的,现在网上实现方式主要有: 基于Nacos, 基于数据库(PosgreSQL/Redis), 基于Mem ...
- Spring Cloud Gateway 没有链路信息,我 TM 人傻了(上)
本系列是 我TM人傻了 系列第五期[捂脸],往期精彩回顾: 升级到Spring 5.3.x之后,GC次数急剧增加,我TM人傻了 这个大表走索引字段查询的 SQL 怎么就成全扫描了,我TM人傻了 获取异 ...
- Spring Cloud Gateway的动态路由怎样做?集成Nacos实现很简单
一.说明 网关的核心概念就是路由配置和路由规则,而作为所有请求流量的入口,在实际生产环境中为了保证高可靠和高可用,是尽量要避免重启的,所以实现动态路由是非常有必要的:本文主要介绍 Spring Clo ...
- Spring Cloud gateway 六 Sentinel nacos存储动态刷新
微服务当前这么火爆的程度,如果不能学会一种微服务框架技术.怎么能升职加薪,增加简历的筹码?spring cloud 和 Dubbo 需要单独学习.说没有时间?没有精力?要学俩个框架?而Spring C ...
- 搭建一套ASP.NET Core+Nacos+Spring Cloud Gateway项目
前言 伴随着随着微服务概念的不断盛行,与之对应的各种解决方案也层出不穷.这毕竟是一个信息大爆发的时代,各种编程语言大行其道,各有各的优势.但是有一点未曾改变,那就是他们服务的方式,工作的时候各 ...
- 通过Nacos动态刷新Spring Cloud Gateway的路由
通过Nacos动态刷新Spring Cloud Gateway的路由 一.背景 二.解决方案 三.实现功能 四.实现步骤 1.网关服务的实现 1.pom文件 2.bootstrap.yml配置文件 3 ...
随机推荐
- python基础学习之列表的功能方法
列表:list 格式 li = [1,2,3,4,5,6] 列表内部随意嵌套其他格式:字符串.列表.数字.元组.字典. 列表内部有序,且内容可更改 a = [1,2,3,4] a[0] = 5 ...
- CodeMonkey少儿编程第7章 函数
目标 了解函数是什么 掌握如何定义一个函数 函数是什么 本章我们学习一个新的概念----函数. 你可以简单的将函数看作为一个黑匣子,给它输入参数后,它将会按照一定的规则,执行相应的指令或输出数据. 让 ...
- springboot系列五:springboot整合mybatisplus jsp
一.用IDEA创建项目 1.添加pom.xml <?xml version="1.0" encoding="UTF-8"?> <project ...
- where / having / group by / order by / limit 简单查询
目录 1.基础查询 -- where 2. group by 与 统计函数 3. having 4.where + group by + having + 函数 综合查询 5. order by + ...
- flutter兼论
Flutter是Google开发的一套全新的跨平台.开源UI框架,支持iOS.Android系统开发,并且是未来新操作系统Fuchsia的默认开发套件.自从2017年5月发布 第一个版本以来,目前Fl ...
- UML类图画法整理
一 类图画法 1.类图的概念 显示出类.接口以及他们的静态结构和关系,用于描述系统的结构化设计. 2.类 类是对一组具有相同属性.操作.关系和语义对象的抽象,是面向对象的核心,包括名称.属性和方法.如 ...
- 2019看雪CTF 晋级赛Q2第四题wp
上次参加2019看雪CTF 晋级赛Q2卡在了这道题上,虽然逆出算法,但是方程不会解,哈哈哈哈,果然数学知识很重要呀,现在记录一下. 首先根据关键信息,根据错误提示字符串定位到这里: 1 int __t ...
- 14、MyBatis教程之全部(包括所有章节)
MyBatis 3.5.5 教程 1.环境准备 jdk 8 + MySQL 5.7.19 maven-3.6.1 IDEA 学习前需要掌握: JDBC MySQL Java 基础 Maven Juni ...
- 真会C#微信小程序的习题数据JSON文件下载链接
完全没有精力去维护了,所以小程序停掉,集中精力做一件事. 链接: https://pan.baidu.com/s/1xL45KxDzR5oEQM6nwBA5rw 提取码: qv6n
- 【SqlServer】管理全文索引(FULL TEXT INDEX)
Sql Server中的全文索引(下面统一使用FULLTEXT INDEX来表示全文索引),是一种特定语言搜索索引功能.它和LIKE的不一样,LIKE主要是根据搜索模板搜索数据,它的效率比FULLTE ...