Nacos学习笔记

3 篇文章 0 订阅
1 篇文章 0 订阅

当前文档为学习笔记,编辑中

Nacos简介

名字的由来

Naming + Configuration Service => Nacos

基本简介

一个更易于构件云原生应用的动态服务发现、配置管理和服务管理平台。 ——摘自Nacos github

即 注册中心 + 配置中心,代替 Eureka + Config + Bus

下载地址

中文官网:https://nacos.io/zh-cn/
官网:https://github.com/alibaba/Nacos
下载地址:https://github.com/alibaba/nacos/tags

当前我使用的版本是1.3.2,官网可能下载慢,我会上传上来,但是考虑到日后可能进行版本更新,故而附上官网地址和下载地址用户可自行下载

各注册中心的比较

服务注册与发现框架CAP模型控制台管理社区活跃度
EurekaAP支持
ZookeeperCP不支持
ConsulCP支持
NacosAP支持

这里提到了CAP模型,详见这里

安装并运行Nacos

  1. 下载:Nacos-1.3.2
  2. 安装:无需安装,解压后直接启动
  3. 启动:
    下载完毕后是个zip压缩包,解压后如图所示
    在这里插入图片描述
    进入bin文件夹,如图所示
    在这里插入图片描述
    cmd后缀为windos启动文件,sh为Linux启动文件,所以下载后的nacos两系统通用
  4. 访问:启动完毕后,访问 http://127.0.0.1:8848/nacos
  5. 登录:账号密码:nacos/nacos

服务注册中心

官网文档

https://spring.io/projects/spring-cloud-alibaba#learn

服务提供者

接下来我会在eclipse中新建一个项目,项目的完整代码将在下面展示,当然,后续我也把会项目源码打包上传上来;

  1. 新建项目
    项目名称:mjchen-nacos9001
  2. 完成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>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.2.9.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>com.cloud</groupId>
	<artifactId>naocs9001</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>naocs9001</name>
	<description>Demo project for Spring Boot</description>

	<properties>
		<java.version>1.8</java.version>
		<spring-cloud-alibaba.version>2.2.1.RELEASE</spring-cloud-alibaba.version>
		<maven-jar-plugin.version>3.1.1</maven-jar-plugin.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.cloud</groupId>
			<artifactId>spring-cloud-dependencies</artifactId>
			<version>Hoxton.SR6</version>
			<type>pom</type>
			<scope>import</scope>
		</dependency>
		<!-- <dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</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-config</artifactId>
		</dependency> -->
		<dependency>
			<groupId>com.alibaba.cloud</groupId>
			<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
		</dependency>
		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>

		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-devtools</artifactId>
			<scope>runtime</scope>
			<optional>true</optional>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-configuration-processor</artifactId>
			<optional>true</optional>
		</dependency>
		<dependency>
			<groupId>org.projectlombok</groupId>
			<artifactId>lombok</artifactId>
			<optional>true</optional>
		</dependency>
		<dependency>
			<groupId>junit</groupId>
			<artifactId>junit</artifactId>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
			<exclusions>
				<exclusion>
					<groupId>org.junit.vintage</groupId>
					<artifactId>junit-vintage-engine</artifactId>
				</exclusion>
			</exclusions>
		</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>
		</dependencies>
	</dependencyManagement>

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

</project>

  1. 我这里的配置文件是 properties
server.port = 9001

# 配置服务名
spring.application.name = nacos-payment-provider
# 配置nacos地址
spring.cloud.nacos.discovery.server-addr = 127.0.0.1:8848
# 监控全部打开(监控啥我忘了,日后再说)
management.endpoints.web.exposure.include = *    
  1. 编写主启动类,主要是 @EnableDiscoveryClient
package com.cloud.naocs9001;

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

@SpringBootApplication
@EnableDiscoveryClient
public class Naocs9001Application {

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

}

  1. 书写业务类
package com.cloud.naocs9001.controller;

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

@RestController
public class PaymentController {

	@Value("${server.port}")
	private String serverPort;

	@GetMapping("/payment/nacos/{id}")
	public String getPayment(@PathVariable("id") Integer id) {
		return "nacos registry,serverPort: " + serverPort + "\t id = " + id;
	}
}
  1. 测试
    a. 测试nacos是否启动成功,及访问8848端口看能不能访问管理系统
    b. 测试服务是否注册进了nacos,即查看nacos服务,看有没有 nacos-payment-provider 服务
  2. 负载均衡
    根据上述的步骤,重新创建一个相同的项目9002,来试一下负载均衡。

服务注册中心对比

在这里插入图片描述
在这里插入图片描述
123

服务配置中心

基础配置

  1. 新建项目
  2. POM
  3. YML
  4. 主启动
  5. 业务类
  6. 在Nacos中添加配置信息
    Nacos中的匹配规则
    理论:
    Nacos中的dataid的组成格式及与SpringBoot配置文件中的匹配规则
    dataId的完整格式如下:
${prefix}-${spring.profile.active}.${file-extension}

spring.profile.active也可以为空,此时就变成了下面的格式,但是不推荐!

${prefix}.${file-extension}

在这里插入图片描述
在这里插入图片描述

实操:

测试
自带动态刷新
分类配置

集群和持久化配置(★★★)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值