- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
其实也就是相当于之前用的 eureka 和 config (或者阿波罗)。
本篇提供给初学者,最快速最简单地去使用上nacos 。
1.首先以最快的速度 ,本地(windows环境) ,把我们的nacos 服务 跑起来。
网盘拿nacos 压缩包 :
nacos zip百度网盘为您提供文件的网络备份、同步和分享服务。空间大、速度快、安全稳固,支持教育网加速,支持手机端。注册使用百度网盘即可享受免费存储空间
https://pan.baidu.com/s/1vCbDPsGYZUdjG6J7pZ7Jrg 提取码: j3be
ps : 不想用我的也可以,去官方下一个即可,
① 去官网 Nacos 快速开始
② 看官方推荐版本,然后点击 release notes
③看自己是linux还是windows ,下载对应的包。(本篇是在windows做案例,用的zip)
5.访问这个 默认页地址,使用默认账号 nacos 密码nacos 登录即可 :
接下来 ,其余服务 注册到 nacos, 并使用。
快速创建一个springboot项目 ,
pom.xml 文件引入依赖 :
<properties>
<java.version>1.8</java.version>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
<spring.boot.version>2.1.0.RELEASE</spring.boot.version>
<spring.cloud.alibaba.version>2.1.0.RELEASE</spring.cloud.alibaba.version>
</properties>
<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>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>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
</dependencies>
bootstrap.yml 文件:
server:
port: 9010
spring:
profiles:
active: dev
application:
name: service-A
cloud:
nacos:
discovery:
server-addr: 192.168.230.61:8848
config:
file-extension: properties
server-addr: 192.168.230.61:8848
group: MY_DATA_GROUP
这里注意到了,我们要对应起来我们nacos里面的配置文件 :
service-A-dev.properties nacos配置文件名 是这样, 对应我们项目的yml文件里面几个参数。
来到我们刚才登录进入的Nacos ,新增一个配置文件:
DATA ID 和 GROUP 还有配置模式 选择 properties,里面随便放一个值作为参数获取测试用:
回到我们示例项目,快速写一个测试接口、获取配置参数的代码:
项目跑起来 :
其实可以看到从nacos拿配置文件的时候的一些命名规则
回到Nacos的页面,可以看到服务已经注册上来了:
调用测试接口:
以上是配置中心的作用,以及用到了一点注册中心,但是一个服务其实看不出来注册中心的作用。
事不宜迟,快速再创建一个项目,稍微改一下名字 ,改成 server-B ,我们通过serverB 调用server-A服务接口(其实不是每个服务都要用到配置中心,如果不用,就不需要在pom里面导入spring-cloud-starter-alibaba-nacos-config 这个jar的依赖) :
但是要想都注册到注册中心去,这个依赖是必要的:
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
简单写点代码,在B服务通过 注册中心服务名调用 A服务接口:
启动服务B ,可以看到注册中心服务列表里面注册上来了:
测试:
好了,该篇简单快速的应用nacos作为注册中心、配置中心文章,就到这吧。
前置内容 (1)、微服务理论入门和手把手带你进行微服务环境搭建及支付、订单业务编写 (2)、SpringCloud之Eureka服务注册与发现 (3)、SpringCloud之Zookeeper进行服
SpringCloud-实用篇 API:RestTemplate 跨服务调用的api 创建一个bean @Bean @LoadBalanced //负载均衡 public RestTemplate
微服务学习计划——SpringCloud 在学习并掌握了众多基础框架之后,我们的项目繁杂且难以掌握,那么我们就需要开启一门新的课程,也就是我们常说的微服务架构 随着互联网行业的发展,对服
目录 SpringCloud @FeignClient 参数详解 @FeignClient 注解常用参数 SpringCloud @FeignClient
Config 介绍 Spring Cloud Config项目是一个解决分布式系统的配置管理方案。它包含了Client和Server两个部分,server提供配置文件的存储、以接口的形式将配置文件
gateway跨域配置 gateway允许跨域的配置和zuul的不一样,记录一下。 版本 ?
SpringCloud 提取公共配置 在开发微服务项目时,通常会有很多服务,此时会用配置中心来管理这些服务的配置,但有些服务可能会有相同的配置,比如数据源配置,eureka server注册中心地
1、场景简述 笔者最近用到SpringCloud 服务网关的时候,进行服务网关的路由测试,发现无法路由自己设置的规则,测试的时候如下 通过错误排查发现,原来是路由规则写错了! 路由规则如
现在基于SpringCloud的微服务开发日益流行,网上各种开源项目层出不穷。我们在实际工作中可以参考开源项目实现很多开箱即用的功能,但是必须要遵守一定的约定和规范。 本文结合我们实际的开发中遇到
Feign传参注意 最近在用SpringCloud尝试重构以前的项目,使用Feign客户端组件来调用微服务,经常出现参数传不过去变成null的问题,网上查了一下发现feign在参数上的使用还是有一
SpringCloud 服务注册IP错误 1、错误原因 在服务注册的时候,是使用 spring.cloud.client.ipAddress 这个变量,如果本机有多个网卡,那么可能会把不是本机以
简介: gateway主要是做路由 负载,过滤 主要是替代zuul 1.x 性能比zuul好 zuul是基于 Servlet ,gateway是基于spring-webflux 用的netty+
1、场景 笔者就Zuul网关下实现其负载均衡与熔断机制(雪崩)进行实践,前提是已经导入zuul相关依赖 springboot版本:1.5.9.RELEASE springcloud版本:Da
版本说明 开源软件 版本 springboot 2.1.6.RELEASE jdk
今天做项目的时候,遇到一个问题,如果我调用某个服务的接口,但是这个服务挂了,同时业务要求这个接口的结果是必须的,那我该怎么办呢,答案是通过hystrix,但是又有一点,服务不是平白无故挂的(排除服务
前言 eureka是一种基于rest(具像状态传输)的服务,主要用于aws云中定位服务,以实现中间层服务器的负载平衡和故障转移。本文记录一个简单的服务注册与发现实例。 github地址:http
前言 zuul 是在spring cloud netflix平台上提供动态路由,监控,弹性,安全等边缘服务的框架,是netflix基于jvm的路由器和服务器端负载均衡器,相当于是设备和 netfl
简介 Zuul是Spring Cloud全家桶中的微服务API网关。 所有从设备或网站来的请求都会经过Zuul到达后端的Netflix应用程序 Zuul 主要提供路由(请求转发)和
简介 在分布式系统中,服务与服务之间依赖错综复杂,一种不可避免的情况就是某些服务将会出现失败。Hystrix是一个库,它提供了服务与服务之间的容错功能,主要体现在延迟容错和容错,从
简介 feign是声明式的web service客户端,它让微服务之间的调用变得更简单了,类似controller调用service。Spring Cloud集成了Ribbon和Eureka,
我是一名优秀的程序员,十分优秀!