Alibaba——Nacos构建Spring项目+Sentinel控制台

一、什么是Nacos、Sentinel?

1、Nacos
Nacos 是阿里巴巴推出来的一个新开源项目,这是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。

架构如图:
在这里插入图片描述
2、Sentinel

Sentinel 是面向分布式服务架构的轻量级流量控制产品,主要以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度来帮助您保护服务的稳定性。

特性如图:

在这里插入图片描述
二、下载Nacos、Sentinel

1、下载Nacos
1.1、进入Nacos官网
在这里插入图片描述
1.2、下载成功后,进行解压文件
在这里插入图片描述
进入到bin目录下,输入cmd,并进入命令窗口

在这里插入图片描述
启动Nacos命令:.\startup.cmd -m standalone
在这里插入图片描述

1.3、访问Nacos地址:localhost:8848/nacos,账号、密码默认为:nacos
在这里插入图片描述
登录成功即可!

2、下载Sentinel——中文文档
1、Sentinel下载地址切记下载完成后,无需解压!!!!
在这里插入图片描述
2、启动Sentinel命令:首先进入到jar的存放位置,java -jar "jar包名称" --service.port=8081
在这里插入图片描述
3、访问Sentinel地址:localhost:8081,账号、密码默认为sentinel
在这里插入图片描述
完成!

三、Nacos
1、创建一个Server工程,勾选:服务注册中心、配置中心
在这里插入图片描述
如果创建的是一个maven项目,则在pom.xml中加入注册中心、配置中心的依赖,如下:

<!-- Spring Boot Web 依赖 -->
        <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.nacos</groupId>
	   		<artifactId>nacos-spring-context</artifactId>
	   		<version>1.0.0</version>
	   	</dependency>

2、在controller层,创建一个测试类
在这里插入图片描述

@RestController
@RefreshScope
public class Testcontr1ler() {
	@Value("${msg}")
	private String msg;

	@RequestMapping( "add")
	public Integer add(Integer num1, Integer num2) {
	system.out.println(msg);
	return num1 +num2;
	}
}

3、修改注册中心文件
在这里插入图片描述

#应用名称
spring.application. name=service
#Nacos帮助文档:https ://nacos.io/zh-cn/docs/concepts.html#Nacos认证信息
#Nacos服务发现与注册配置,其中子属性 server- addr指定 Nacos服务器主机和端口spring.cloud.nacos.discovery. server-addr=localhost:8848
#注册到nacos的指定namespace,默认为public
spring.cloud.nacos.discovery.namespace=public
#应用服务wEB访问端口
server-port-8080

4、修改配置中心文件
在这里插入图片描述

# Nacos帮助文档: https://nacos.io/zh-cn/docs/concepts.html
# Nacos认证信息
spring.cloud.nacos.config.contextPath=/nacos
# 设置配置中心服务端地址
spring.cloud.nacos.config.server-addr=localhost:8848
# Nacos 配置中心的namespace。需要注意,如果使用 public 的 namcespace ,请不要填写这个值,直接留空即可
# spring.cloud.nacos.config.namespace=

5、启动nacos,访问地址:localhost:8848

在nacos中添加新建配置,其中service与注册中心的名称保持一致,并点击提交
在这里插入图片描述
6、启动注册中心,访问地址:localhost:8090
在这里插入图片描述
7、新建一个消费者(Client)
在这里插入图片描述
如果创建的是一个maven项目,则在pom.xml中加入注册中心的依赖,如下:

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

8、修改消费者配置
在这里插入图片描述

#应用名称
spring- application. name=client
#Nacos帮助文档:https : //nacos.io/zh-cn/docs/concepts.html# Nacos认证信息
# Nacos 服务发现与注册配置,其中子属性server-addr 指定 Nacos服务器主机和端口spring.cloud.nacos.discovery.server- addr=localhost:8848
#注册到nacos的指定namespace,默认为public
spring.cloud.nacos.discovery.namespace=public
应用服务WEB访问端口
server - port=8081

9、在主类中,添加@LoadBalanced(负载均衡),并塞到容器中
在这里插入图片描述
10、新建一个controller类在这里插入图片描述

@RestController
public class Testcontroller {
   @Autowired
   private RestTemplate rt;
  @RequestMapping( "add")
  public Integer add(Integer num1,Integer num2){
  return rt.getForEntity( "http://service/add?num1-m “+num1+“&num2m"”+ num2,Integer .class ).getBody();
}
}

11、测试负载均衡,开启两个注册中心的端口,如下:
在这里插入图片描述
访问url地址:localhost:8081/add?num1=1&num2=2
在这里插入图片描述
四、Sentinel流量防卫兵(守卫者)
1、在命令窗口启动Sentinel:cmd并进入到存放jar包的位置 java -jar "jar包名称"
修改端口:--service.port=8081

url访问地址:localhost:8081,登录成功!!!!
在这里插入图片描述

2、在需要对某项目进行限流,则pom.xml 文件引入 Sentinel 依赖:
在这里插入图片描述

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

3、在application.properties中配置控制台信息
在这里插入图片描述

spring.cloud.sentinel.transport.port=8719
spring.cloud.sentinel.transport.dashboard=localhost:8081

4、测试请求add方法:localhost:8091/add?num1=1&num2=2
在这里插入图片描述
5、刷新Sentinel,就可以看到实时监控的状态
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值