首页 > 其他分享 >Getway实现nacos注册及服务转发

Getway实现nacos注册及服务转发

时间:2024-04-26 15:11:20浏览次数:15  
标签:spring boot nacos alibaba 转发 Getway com cloud

Getway实现nacos注册及服务转发

首先创建一个module——kiba-getway,如下图:

image

我们新建的项目缺少resources文件夹,打开project structure——moudules,右键java,创建文件夹,如下图:

image

然后选择resources,再点击【mark a directory as a resources root】,设置resource root,如下图:

image

然后修改pom里的组件版本,文件代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.kibaframework</groupId>
    <artifactId>kiba-getway</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>kiba-getway</name>
    <description>kiba-getway</description>
    <properties>
        <java.version>1.8</java.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> 
        <spring.boot.version>2.3.12.RELEASE</spring.boot.version>
        <spring.cloud.version>Hoxton.SR11</spring.cloud.version> 
        <spring.cloud.alibaba.version>2.2.10-RC1</spring.cloud.alibaba.version> 
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
        <!-- Nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>com.alibaba.nacos</groupId>
                    <artifactId>nacos-client</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>com.alibaba.nacos</groupId>
            <artifactId>nacos-client</artifactId>
        </dependency>



        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.20</version>
        </dependency>
        <dependency>
            <groupId>cn.hutool</groupId>
            <artifactId>hutool-all</artifactId>
            <version>5.8.16</version>
            <scope>compile</scope>
        </dependency>
    </dependencies>
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>${spring.cloud.alibaba.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>${spring.boot.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring.cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency> 
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>${spring.boot.version}</version>
                <configuration>
                    <mainClass>com.example.kibagetway.KibaGetwayApplication</mainClass>
                    <skip>true</skip>
                </configuration>
                <executions>
                    <execution>
                        <id>repackage</id>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

</project>

然后在resources下添加bootstrap.yml文件,编写内容如下:

spring:
  application:
    name: kiba-gateway
  cloud:
    nacos:
      discovery:
        server-addr: 10.1.0.145:8848
        username: nacos
        password: nacos
        auto-register: true
        reactive:
          enabled: false #关闭响应式发现服务,不需要返回消息,增加注册速度,简化复杂度
    gateway:
      discovery:
        locator:
          enabled: true #网关能够通过特定的机制发现和使用其他服务。该配置会将其他服务自动根据服务名进行映射
      httpclient:
        max-header-size: 104857600
    loadbalancer:
      retry:
        enabled: true #启动负载均衡重试


上文设置了gateway.discovery.locator.enabled=true。所以会将其他服务自动根据服务名进行映射。

项目结构很简单,如下图:

image

然后启动项目,将网关注册进nacos,如下。

image

我的nacos里已经有一个服务了。正常请求地址——localhost:8588/user/getFiegn,如下图:

image

请求网关地址——localhost:9010/app-kiba-feign/user/getFiegn,如下图:

image

网关成功转发了请求。

注:getway项目一定要最后启动,他是在启动时进行一次服务扫描,然后将服务信息自动配置进去的。如果先启动getway,那么后面启动的服务,将无法被注册进网关。


注:此文章为原创,任何形式的转载都请联系作者获得授权并注明出处!



若您觉得这篇文章还不错,请点击下方的【推荐】,非常感谢!

https://www.cnblogs.com/kiba/p/18160147

标签:spring,boot,nacos,alibaba,转发,Getway,com,cloud
From: https://www.cnblogs.com/kiba/p/18160147

相关文章

  • Sentinel如何持久化数据到Nacos?
    默认情况下Sentinel只能接收到Nacos推送的消息,但不能将自己控制台修改的信息同步给Nacos,如下图所示:但是在生成环境下,我们为了更方便的操作,是需要将Sentinel控制台修改的规则也同步到Nacos的,所以在这种情况下我们就需要修改Sentinel的源码,让其可以实现和Nacos的双向......
  • 碎片和水位线回收的验证过程 转发 https://www.modb.pro/db/1780420808865845248
    1、数据库基础内容表空间-数据文件-段-区-块一个表空间由一个或者多个数据文件组成高水位线和表碎片的示意图其中被划掉的字代表delete删除,其中耶就是后续的insert,只会在末尾增加,而不是填充被删除的字段,这样就会导致数据库在搜寻数据时会浪费很多资源。整理碎片后大概是这......
  • 移动语义和引用折叠、完美转发
    移动构造、移动赋值C++11新增了移动语义新特性,移动语义允许在不复制数据的情况下转移资源的所有权。在这之前,对象通过拷贝构造函数或拷贝赋值运算符进行传递,发生大量的数据复制,导致性能下降。以常用的string对象为例,#include<cstring>#include<iostream>classstring{pub......
  • 微服务:nacos服务注册与发现
    服务治理的三个角色:服务提供者:订阅服务服务消费者:注册服务注册中心:记录与监控服务状态,推送服务变更信息。提供者定时发送心跳检测,心跳检测失败,就会向消费者推送变更提供者通过负载均衡的算法选择消费者 搭建nacos:1.在sql表中执行-----------------------......
  • SpringCloud进行nacos的服务注册和服务管理案例
    SpringCloud服务注册pom.xml<!--SpringCloud服务注册和发现--><dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2.2.8.RELEASE</version>......
  • 3.Nacos安装
    Nacos安装前环境准备Nacos依赖java环境来运行。如果您使从代码开始构建并运行Nacos,还需要为此配置Maven环境,请确保是在以下环境中安装使用:64bitOS,支持Linux/Unix/Mac/Windows,推荐使用Linux/Unix/Mac。64bitJDK1.8;下载&配置。Maven3.2x+;下载&配置。下载源码......
  • 1.nacos配置中心
    什么是配置应用程序在启动和运行的时候往往需要读取一些配置信息,配置基本上伴随着应用程序的整个声明周期,比如数据库连接参数、启动参数、定制化业务参数等。配置的特点配置是独立于程序的制度变量配置对于程序是只读的,程序通过读取配置来改变自己的行为,但是程序不改变配置......
  • Nacos安装指南
    1.Windows安装开发阶段采用单机安装即可。1.1.下载安装包在Nacos的GitHub页面,提供有下载链接,可以下载编译好的Nacos服务端或者源代码:GitHub主页:https://github.com/alibaba/nacosGitHub的Release下载页:https://github.com/alibaba/nacos/releases如图:1.2.解压将这个包解......
  • Nacos高可用集群搭建与使用
    参考:https://blog.csdn.net/Alwayszmx/article/details/122291741一、Nacos简介Nacos致力于帮助您发现、配置和管理微服务。Nacos提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。Nacos帮助您更敏捷和容易地构建、交付和管理微服务......
  • 06、M-LAG正常工作场景流量转发
    M-LAG正常工作场景流量转发M-LAG双活系统建立成功后即进入正常的工作,M-LAG主备设备负载分担共同进行流量的转发,转发行为没有区别。下面介绍M-LAG在正常工作情况下是如何进行流量转发的。单播流量转发单播流量转发包括二层已知单播转发和三层单播转发。如图1所示,M-LAG双活系......