Nacos作为微服务注册中心,爱不释手的感觉
我觉得Nacos用起来还不错
在使用SpringCloud做分布式微服务架构时,注册中心是必不可少的一个组件。目前可以用的主要有:Eureka、Consul、Zookeeper。今天,我们就来说一下Alibaba的Nacos怎么样?
下载与安装
安装:
- Windows 下载解压后(.zip),直接点击bin/start.bat就可以了。
- Linux下载解压后(.tar.gz),同样,也是运行 bin/start.sh 脚本。
打开控制台:
Nacos提供了一个可视化的操作平台,安装好之后,在浏览器中输入
http://localhost:8848就可以访问了,默认的用户名和密码都是nacos(我使用的1.2.0版本。默认将密码验证给关了,这个选项后边会说)
Nacos简介
Nacos是由阿里巴巴开源的一个好东西,直接贴上它的官网,就不再这么累赘了,毕竟是国人开发的,是有中文文档的,上边写的很全面。https://nacos.io/zh-cn/docs/quick-start.html
Nacos作为注册中心
它和Eureka不一样,并不需要创建新的web项目,而是和Zookeeper和Consul一样,只需要下载安装启动后,将我们的微服务注册进去就可以了。
创建两个微服务,一个客户端(调用者)和一个服务端(提供者),
- 引入依赖
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
- 在它们的配置文件中引入如下代码:
spring:
cloud:
nacos:
discovery:
# Nacos的地址
server-addr: localhost:8848
- 主启动类上添加(不管是哪种注册中心,这个一定要有):
@EnableDiscoveryClient
- 当然,在客户端还是要添加ribbon的负载均衡的,但是不用额外添加依赖,nacos已经添加了
@Configuration
public class AppConfig {
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
- 好了,打开Nacos的控制台,然后就可以看到这两个微服务了。

Nacos作为分布式配置中心
之前我们是使用SpringCloudConfig从github等仓库上拉取的配置文件,但是用了Nacos后,我们就可以从Nacos中直接配置了,是不是很方便啊。新建了一个项目,nacos-config-server-8002
pom.xml引入下边依赖
<!--分布式配置中心-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
application.yml中加入如下配置内容
spring:
profiles:
active: dev
添加一个bootstrap.yml
server:
port: 8002
spring:
application:
name: nacos-config-server-8002
cloud:
nacos:
discovery:
server-addr: localhost:8848
config:
server-addr: localhost:8848
# 配置文件类型,有yaml和properties ,注意一定是yaml,不是yml
file-extension: yaml
- application.yml中的配置是什么意思?
- 为什么要引入bootstrap.yml?
简单来说,这个配置是和application.yml是一样的,不这它要比appliation.yml先加载
Controller中的接口
@RestController
@RefreshScope //这是一个SpingCloud的原生注解,可以实现配置的动态刷新
public class InfoController {
/*
这个中的 : 的意思就是说,如果配置文件中没有,就直接使用后边的那个字符串,我写的是nothing
在本地项目中,我们并没有配置configInfo,
所以如果这时候调用http://localhost:8002/info
返回就是nothing
*/
@Value("${configInfo}")
private String configInfo;
/**
* 用做配置中心的演示
*
* @return
*/
@GetMapping("info")
public String getConfig() {
return configInfo;
}
}
Nacos中的几个空间概念:
NameSpaces(命名空间)
相当于我们一个项目中的包名,Nacos中可以新建多个命名空间。微服务注册的时候,可以通过配置
spring.cloud.nacos.discovery.namespace,当然,配置文件也可以配置namespace来指定对应的名称空间,如果不配置就是使用默认的public 空间。假如,你是好几个项目共用一个Nacos集群,就可以通过namespce来区分项目。
在Nacos的控制台的最下边有一个命名空间,你可以新建一个试,建完再次点击服务列表和配置列表上边会出现你的命令空间选择(如下图,我新建了一个space1的空间,public是默认的)

Group(分组)
相当于Java中的类名,同样,一个包下可以有多个类。不过这个只是相对于配置文件来说,对于服务注册没有这么一说。它有一个默认的分组就是DEFAULT_GROUP,在新建配置文件时就会有(如下图)
DataID
这个就相当于类中的方法,同样,一个类中就会有多个方法名。

我们的配置文件就是在上图中去添加的,下边是我截取了Nacos官方文档中对于DataID的说明:

新建一个配置文件试试
在配置列表中新建一个配置文件,如果你有多个命名空间,注意选择你的项目中连接的那个

只要点了右下角的发布,就会自动配置了,再次访问http://localhost:8002/info,就会看到已经更改了,这个是实时更改的。
这些都是很简单的操作,只要你自己做一次,就一定会使用了
Nacos的配置文件持久化
Nacos使用的是嵌入式数据库Derby,有关嵌入式数据库,可以参考在Spring中使用嵌入式数据库-H2,虽然数据库不同,但是原理操作方法一致。但是,我们想换成我们的mysql用来存储nacos的数据,可否?
导入数据到你本地的Mysql库
在Nacos安装包下的conf目录下有个nacos-mysql.sql文件,放到你的Mysql工具中执行一遍(它这个sql语句中建库,先建个库名叫nacos_config)
修改conf下的application.properties文件
### 98行左右,这个设置为true就是开启nacos启动的登录验证,默认用户名和密码就是nacos
nacos.core.auth.enabled=true
### 在最后添加如下:
spring.datasource.platform=mysql
db.num=1
db.url.0=jdbc:mysql://127.0.0.1:3306/nacos_config?characterEncoding=utf8&connectTimeout=1000&socketTimeout=3000&autoReconnect=true
db.user=root
db.password=123
以上这些内容全都来自于Nacos官网

这样,再次启动后Nacos后,你之前的配置文件就全都不见了,因为你配置了Mysql库。这样,你每次修改后,就会进Mysql库,这个库很简单的,你大概看一下就能明白了。
微信关注”小鱼与Java“,回复”SpingCloud“获取更多SpringCloud学习资料

Nacos作为微服务注册中心,爱不释手的感觉的更多相关文章
- 如何优化Spring Cloud微服务注册中心架构?
作者: 石杉的架构笔记 1.再回顾:什么是服务注册中心? 先回顾一下什么叫做服务注册中心? 顾名思义,假设你有一个分布式系统,里面包含了多个服务,部署在不同的机器上,然后这些不同机器上的服务之间要互相 ...
- 并发系列5-大白话聊聊Java并发面试问题之微服务注册中心的读写锁优化【石杉的架构笔记】
- Eureka 微服务注册中心搭建
本机IP为 192.168.1.102 1. 新建Maven项目 eureka 2. pom.xml <project xmlns="http://maven.apach ...
- Nacos笔记01——使用Nacos作为SpringCloud项目的服务注册中心
前言 刚学SpringCloud时使用eureka作为服务注册中心,随着网飞公司eureka2.x不再更新,以及最近在公司实习接触到的SpringCloud项目是使用Nacos来做服务注册中心的,所以 ...
- lms框架服务注册中心
服务注册中心原理 在分布式系统里的注册中心.原理是将部署服务的机器地址记录到注册中心,服务消费者在有需求的时候,只需要查询注册中心,输入提供的服务名,就可以得到地址,从而发起调用. 在微服务架构下,主 ...
- 用Nacos做微服务架构里的服务注册与发现中心
转自:https://www.jianshu.com/p/61608ff86344 Nacos 另一个非常重要的特性就是服务注册与发现,说到服务的注册与发现相信大家应该都不陌生,在微服务盛行的今天,服 ...
- 学习一下 SpringCloud (二)-- 服务注册中心 Eureka、Zookeeper、Consul、Nacos
(1) 相关博文地址: 学习一下 SpringCloud (一)-- 从单体架构到微服务架构.代码拆分(maven 聚合): https://www.cnblogs.com/l-y-h/p/14105 ...
- silky微服务框架服务注册中心介绍
目录 服务注册中心简介 服务元数据 主机名称(hostName) 服务列表(services) 终结点 时间戳 使用Zookeeper作为服务注册中心 使用Nacos作为服务注册中心 使用Consul ...
- 微服务配置内容《网上copy》=========》如何创建一个高可用的服务注册中心
前言:首先要知道什么是一个高可用的服务注册中心,基于spring boot建成的服务注册中心是一个单节点的服务注册中心,这样一旦发生了故障,那么整个服务就会瘫痪,所以我们需要一个高可用的服务注册中心, ...
随机推荐
- numpy的array分割
import numpy as np A = np.arange(12).reshape(3,4) print(A) print(np.split(A,2,axis=1)) print(np.spli ...
- 使用Xshell进行vi编辑时,按下end、home和Delete不能使用,解决解决办法
使用Xshell连接到Linux进行vi编辑时,进入编辑模式,按下end键,光标无法移到行位,home也不能到行首,其它的Delete键也是不能使用,如何解决? Xshell选项设置如下: 文件→属性 ...
- 3名程序员被抓!开发“万能钥匙”APP,撬走3个亿
来自:程序员头条 报道 又有 3 名程序员被抓!开发"万能钥匙"APP,撬走 3 亿! 前几天,据央视新闻报道,上海公安机关接到共享单车企业报案,随后破获了一起共享单车万能解锁 A ...
- Tian Tian 菾菾 导游 陪同
自画像系列是梵高的代表作之一,他是一位自学成才的画家,下笔完全自由,主观提取了当时印象派画家学到的技巧,在这幅画中,我们可以看到,颜色在画中的堆叠,色彩与笔在画中表现的形态,都表现出,梵高在他作画中内 ...
- Linux用户组的添加及属性的更改
用户组的创建: 12345 groupadd [OPTION] 组名 -g GID 指明GID号:[GID_MIN, GID_MAX] -r 创建系统组 CentOS 6: ID<500 Cen ...
- Hackintosh Of Lenovo R720 15IKBN
Hackintosh Of Qftm 一个黑苹果爱好者的项目 定制:macOS Catalina 10.15.1 电脑配置 一键查看电脑配置(鲁大师.360驱动管理.Lenovo管家等) 规格 详细信 ...
- 曹工说Spring Boot源码(21)-- 为了让大家理解Spring Aop利器ProxyFactory,我已经拼了
写在前面的话 相关背景及资源: 曹工说Spring Boot源码(1)-- Bean Definition到底是什么,附spring思维导图分享 曹工说Spring Boot源码(2)-- Bean ...
- C++走向远洋——23(项目一,三角形,类)
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:sanjiaoxing.cpp * 作者:常轩 * 微信公众号: ...
- Javascript学习笔记-基本概念-语法、关键字和保留字、变量
语法 1.区分大小写 2.标识符 所谓标识符,就是指变量.函数.属性的名字,或者函数的参数. 命名规则: 第一个字符必须是一个字母.下划线(_)或一个美元符号($): 其他字符可以是字母.下划线.美元 ...
- 逐行分析jQuery2.0.3源码-完整笔记
概览 (function (){ (21 , 94) 定义了一些变量和函数 jQuery=function(); (96 , 293) 给jQuery对象添加一些方法和属性; (285 , 347) ...