nacos使用

一、nacos下载,启动

官网:

版本选择1.1.4

注:不同版本对应的jar包不同,如果不对应,会出现很诡异的错误

下载安装包,解压,在conf目录中加入数据库的配置

#*************** Config Module Related Configurations ***************#
### If use MySQL as datasource:
spring.datasource.platform=mysql

### Count of DB:
db.num=1

### Connect URL of DB:
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true&useUnicode=true&useSSL=false&serverTimezone=UTC&allowPublicKeyRetrieval=true
db.user.0=root
db.password.0=123456

nacos只支持mysql数据库,在数据库中要自己建数据库,在conf目录有一个sql文件,运行。

上面这个文件,要改一些数据库配置:数据库名,用户名,密码

然后在bin目录中,点击startup.sh,运行

这个nacos版本默认就是以单体应用启动,有的版本可能以集群方式启动,如果没搭建集群,就不能以集群方式运行。

 以单体应用启动,写成bat文件,或者直接在cmd窗口运行。

startup.cmd -m standalone

二、使用

1、依赖导入

目前只到三个东西spring-boot,spring-cloud,spring-cloud-alibaba

因为nacos是Alibaba的,而我们可能会用到官方的其他组件,所以先导上

pom文件

    <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.4.1</spring-boot.version>
        <spring-cloud.version>2020.0.0</spring-cloud.version>
        <spring-cloud-alibaba.version>2021.1</spring-cloud-alibaba.version>

    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <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-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

    </dependencies>

    <dependencyManagement>
        <dependencies>
            <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>
            <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>

nacos可以作为注册和发现中心, 也能够作为配置中心,这里导入的依赖只有服务注册和发现中心。配置中心的会另外导。

 如果是作为集群搭建,还要导入依赖:

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-loadbalancer</artifactId>
        </dependency>

并且需要注入一个RestTemplate对象

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

2、代码、配置文件

1、在SpringBoot启动类上加入注解

@EnableDiscoveryClient

2、yml文件

server:
  port: 8081
spring:
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
  application:
    name: provider

 要保证每个服务运行的端口不一样

name属性就是在nacos中注册的服务名称

三、nacos用做配置中心

目标:从nacos中读取相关配置

从nacos中读取的配置,会被编译为yml文件形式,所以,可以直接使用yml注入读取使用。

 依赖导入:(导入此依赖,是下面的bootstrap文件生效)

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

bootstrap.yml

server:
  #项目端口号(boostrap.yml中配置后,可在application.yml中不配置)
  port: 8081

spring:
  application:
    # 会自动根据服务名拉取data-id对应的配置文件.如果data-id跟服务名不一致 就需要手动指定data-id
    # 跟服务名相同的data-id的配置文件,称之为默认的配置文件
    # 除了默认的配置文件,其他配置文件必须写上后缀
    name: provider
  cloud:
    nacos:
      discovery:
        server-addr: 192.168.126.132:8848
        # username: nacos
        # password: nacos
      config:
        prefix: ${spring.application.name}
        #指定nacos配置中心地址
        server-addr: 192.168.126.132:8848
        file-extension: yml # 使用的 nacos 配置集的 dataId 的文件拓展名,同时也是 Nacos 配置集的配置格式,默认为 properties
        namespace: 81ec829d-72b6-4dc1-b7db-f47ef1bf97e3  # 使用的 nacos 的命名空间,默认为 null
        group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
        # 共享配置集数组
        shared-configs:
          - data-id: nacos-client.yml
            group: DEFAULT_GROUP # 使用的 Nacos 配置分组,默认为 DEFAULT_GROUP
            refresh: true # 是否自动刷新配置,默认为 false

 yml注入(注解方式)

package com.csf.code.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RefreshScope//实时更新配置信息,不加则不会实时更新配置
public class ProviderController {

    @Value("${email.host}")
    private String host;
    @Value("${email.user}")
    private String user;
    @Value("${email.pwd}")
    private String password;

    @RequestMapping("/run")
    public String run() {
        return "🍜";
    }

    @RequestMapping("/")
    public String read(){
        System.out.println("host:"+host);
        System.out.println("user:"+user);
        System.out.println("password"+password);
        return "yes";
    }



}

访问/就现配置信息,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

无感_K

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值