docker化sentinel-dashboard+nacos注册中心

简介: docker化sentinel-dashboard+nacos注册中心

1.先把Sentinel克隆代码到本地

2.把克隆好的代码分支切换到release-1.7。如图所示:

image.png

3.通过idea工具打开克隆的项目(需要等待一段时间,maven需要下载很多依赖包)

4.项目导入成功后,打开sentinel-dashboard模块中的pom.xml,把sentinel-datasource-nacos依赖的scope那一行删掉(作用就是打包的时候把sentinel-datasource-nacos打进去,这样才能把规则写入nacos注册中心)

image.png

5.按照下图所示,把sentinel-dashboard/src/test/java/com/alibaba/csp/sentinel/dashboard/rule/nacos这个包里面的所有java文件都复制sentinel-dashboard/src/main/java/com/alibaba/csp/sentinel/dashboard/rule

image.png

6.如下图所示,把FlowControllerV2中的两个指定的名字分别改成FlowRuleNacosProvider对象和FlowRuleNacosPublisher对象对应的bean名称

image.png

7.修改前端代码:

image.png

这个修改是有原因的,没修改的时候是这样的:

image.png

修改后是这样的:

image.png

这样才能访问到FlowControllerV2。

至此,当前sentinel-dashboard可以访问localhost上的nacos实例,所以我们下一步需要修改成动态配置目标nacos

8.新增一个NacosProperties

image.png

package com.alibaba.csp.sentinel.dashboard.rule.nacos;
import org.apache.commons.lang3.StringUtils;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
/** @author zouwei */
@Component
@ConfigurationProperties(prefix = "nacos.server")
public class NacosProperties {
    private static final String NACOS_SERVER_ADDR = "NACOS_SERVER_ADDR";
    private static final String NACOS_GROUP_ID = "NACOS_GROUP_ID";
    private static final String NACOS_NAMESPACE = "NACOS_NAMESPACE";
    private static final String NACOS_PORT = "NACOS_PORT";
    private static final String NACOS_IP = "NACOS_IP";
    private String ip = "localhost";
    private String port = "8848";
    private String namespace;
    private String groupId = "DEFAULT_GROUP";
    public String getIp() {
        String nacosIp = getEnv(NACOS_IP);
        if (StringUtils.isNotBlank(nacosIp)) {
            return nacosIp;
        }
        return ip;
    }
    public void setIp(String ip) {
        this.ip = ip;
    }
    public String getPort() {
        String nacosPort = getEnv(NACOS_PORT);
        if (StringUtils.isNotBlank(nacosPort)) {
            return nacosPort;
        }
        return port;
    }
    public void setPort(String port) {
        this.port = port;
    }
    public String getNamespace() {
        String nacosNamespace = getEnv(NACOS_NAMESPACE);
        if (StringUtils.isNotBlank(nacosNamespace)) {
            return nacosNamespace;
        }
        return namespace;
    }
    public void setNamespace(String namespace) {
        this.namespace = namespace;
    }
    public String getGroupId() {
        String nacosGroupId = getEnv(NACOS_GROUP_ID);
        if (StringUtils.isNotBlank(nacosGroupId)) {
            return nacosGroupId;
        }
        return groupId;
    }
    public void setGroupId(String groupId) {
        this.groupId = groupId;
    }
    public String getServerAddr() {
        String nacosServerAddr = getEnv(NACOS_SERVER_ADDR);
        if (StringUtils.isNotBlank(nacosServerAddr)) {
            return nacosServerAddr;
        }
        return this.getIp() + ":" + this.getPort();
    }
    private static String getEnv(String key) {
        return System.getenv(key);
    }
}
复制代码

9.修改以下三个类

image.png

image.png

image.png

10.添加nacos相关配置

image.png

这四个和nacos相关的配置根据自己的实际情况配置。

到这一步,就已经达到了动态配置目标nacos的目的了。接下来,就是打包和docker化。

11:打包

在idea中找到Terminal,进入sentinel-dashboard中,执行以下命令打包:

mvn clean package
复制代码

执行完毕后,在target中会生成sentinel-dashboard.jar,这个就是我们需要的jar包

image.png

12:准备好docker-compose.yml和Dockerfile

docker-compose.yml

version: "3"
services:
  sentinel-dashboard:
    build: ./sentinel
    container_name: sentinel-dashboard
    ports:
      # 对应Dockerfile中的192.168.2.231:8086及8080端口配置
      - "8086:8080"
    environment:
      # nacos服务地址及端口(根据自身情况配置)
      - NACOS_SERVER_ADDR=192.168.2.231:8848
      # nacos服务namespace(根据自身情况配置)
      - NACOS_NAMESPACE=d1191f93-910a-47cc-8684-234e2b30909b
      # nacos服务group id(根据自身情况配置)
      - NACOS_GROUP_ID=SENTINEL_GROUP
复制代码

Dockerfile

FROM openjdk
MAINTAINER 作者 <邮箱地址>
RUN mkdir /usr/src/sentinel-dashboard
COPY sentinel-dashboard.jar /usr/src/sentinel-dashboard
WORKDIR /usr/src/sentinel-dashboard
EXPOSE 8080
ENTRYPOINT ["java", "-Dserver.port=8080", "-Dcsp.sentinel.dashboard.server=192.168.2.231:8086", "-Dproject.name=sentinel-dashboard", "-jar", "sentinel-dashboard.jar"]
复制代码

以上配置中192.168.2.231:8086为宿主机IP和映射出来的8086端口,其实就是指向sentinel-dashboard服务,该配置可自定义。

13.启动sentinel-dashboard服务

执行以下命令启动服务:

docker-compose up -d sentinel-dashboard
复制代码

通过访问指定的192.168.2.231:8086进入sentinel登录页面

image.png

输入默认的用户名:sentinel 密码:sentinel

image.png

至此,就可以通过sentinel-dashboard和nacos就可以实现流控规则的持久化和动态配置了。


相关文章
|
5月前
|
Cloud Native Java Nacos
springcloud/springboot集成NACOS 做注册和配置中心以及nacos源码分析
通过本文,我们详细介绍了如何在 Spring Cloud 和 Spring Boot 中集成 Nacos 进行服务注册和配置管理,并对 Nacos 的源码进行了初步分析。Nacos 作为一个强大的服务注册和配置管理平台,为微服务架构提供
1203 14
|
12月前
|
Java Nacos 数据库
使用 nacos 搭建注册中心及配置中心
使用 nacos 搭建注册中心及配置中心
178 5
|
12月前
|
NoSQL Java Nacos
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
SpringCloud集成Seata并使用Nacos做注册中心与配置中心
552 3
|
8月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评。然而,“客户端不发送心跳检测”是使用中常见的问题之一。本文详细探讨了该问题的原因及解决方法,包括检查客户端配置、网络连接、日志、版本兼容性、心跳检测策略、服务实例注册状态、重启应用及环境变量等步骤,旨在帮助开发者快速定位并解决问题,确保服务正常运行。
136 5
|
8月前
|
网络安全 Nacos 开发者
Nacos作为流行的微服务注册与配置中心,“节点提示暂时不可用”是常见的问题之一
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,“节点提示暂时不可用”是常见的问题之一。本文将探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务的正常运行。通过检查服务实例状态、网络连接、Nacos配置、调整健康检查策略等步骤,可以有效解决这一问题。
159 4
|
8月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,实际使用中常遇到“客户端不发送心跳检测”的问题。本文深入探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务正常运行。通过检查客户端配置、网络连接、日志、版本兼容性、心跳策略、注册状态、重启应用和环境变量等步骤,系统地排查和解决这一问题。
165 3
|
8月前
|
安全 Nacos 数据库
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改。本文详细探讨了这一问题的原因及解决方案,包括限制公网访问、使用HTTPS、强化数据库安全、启用访问控制、监控和审计等步骤,帮助开发者确保服务的安全运行。
375 3
|
9月前
|
弹性计算 数据库连接 Nacos
阿里云ECS服务器在docker中部署nacos
docker pull nacos 失败,docker部署nacos遇到的问题,nacos数据库连接,nacos端口映射
498 1
|
10月前
|
Kubernetes Nacos 容器
nacos注册不上
我正在使用开源的Nacos,并已在Kubernetes中部署了Nacos服务,通过端口映射可在集群外访问Nacos控制台。Kubernetes使用NodePort类型暴露了8848、9848、9849、7848和9555端口,但在尝试注册时遇到问题,出现“Client not connected, current status: STARTING”的错误,导致启动失败。
101 1
|
12月前
|
Nacos 微服务
Zookeeper 的 ZAB 协议 以及 zookeeper 与 nacos 注册中心比对
Zookeeper 的 ZAB 协议 以及 zookeeper 与 nacos 注册中心比对
148 4