Nacos入门

Nacos官网

首先我们需要安装nacos:快速开始

github下载地址:Releases · alibaba/nacos (github.com)

我使用windows学习nacos,所以下载zip结尾的包。

如果github访问慢,我的gitee上面的cloud2020项目有nacos安装包:cloud2020

我使用nacos-server-1.4.2版本

下载后解压,进入nacos/bin目录

image-20210525193611787

进入cmd

image-20210525193716151

注意要单机启动,否则会报错

image-20210525193932200

启动成功,访问之:nacos地址

image-20210525194009684

用户名和密码均为:nacos

建议直接看cloud2020,其中的cloudalibaba-provider-payment9001cloudalibaba-provider-payment9002cloudalibaba-consumer-nacos-order83cloudalibaba-config-nacos-client3377

模块均为nacos相关。

nacos文档写的很简略,我们看看spring的文档吧,我用的2.1.2版本,因此文档为:spring cloud alibaba2.1.2

由文档可知,首先我们需要在父pom中引入如下依赖:

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-alibaba-dependencies</artifactId>
            <version>2.1.0.RELEASE</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

对于服务注册和发现我们需要在子项目pom中引入如下:

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

以上的不完整,看看文档写的完整版:

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>open.source.test</groupId>
    <artifactId>nacos-discovery-test</artifactId>
    <version>1.0-SNAPSHOT</version>
    <name>nacos-discovery-test</name>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>${spring.boot.version}</version>
        <relativePath/>
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
    </properties>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring.cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
            <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>
        </dependencies>
    </dependencyManagement>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

其中dependencyManagement部分应该写入父pom中,在子pom中引入web,actuator,nacos-discovery等依赖。

application.yml:

server:
  port: 9001

spring:
  application:
    name: nacos-payment-provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 #配置Nacos地址
management:
  endpoints:
    web:
      exposure:
        include: '*'

我们需要写,当前微服务端口,微服务名,nacos地址,暴露端口给actuator。

对于服务提供者:主启动类额外添加@EnableDiscoveryClient,controller与正常的一样

对于服务消费者:主启动类也是需要添加@EnableDiscoveryClient,然后我们需要将RestTemplate注入spring:

    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }

对于controller有点小变动:

        @GetMapping("/echo/app-name")
        public String echoAppName(){
            //Access through the combination of LoadBalanceClient and RestTemplate
            ServiceInstance serviceInstance = loadBalancerClient.choose("nacos-provider");
            String path = String.format("http://%s:%s/echo/%s",serviceInstance.getHost(),serviceInstance.getPort(),appName);
            System.out.println("request path:" +path);
            return restTemplate.getForObject(path,String.class);
        }

我们要远程调用提供者的服务,我们要用restTemplate.getForObject(path,String.class)方法,path为提供者接口地址。

cloud2020中启动cloudalibaba-provider-payment9001,cloudalibaba-consumer-nacos-order83模块,从nacos服务列表可看到

image-20210525202403816

未完待续~~~🍍🍍🍍🍍

posted @   KeBoom  阅读(150)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
点击右上角即可分享
微信分享提示
主题色彩