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就可以实现流控规则的持久化和动态配置了。


相关文章
|
1天前
|
安全 Linux Nacos
使用Docker运行Nacos并安装cpolar内网穿透工具实现远程访问
使用Docker运行Nacos并安装cpolar内网穿透工具实现远程访问
|
1天前
|
安全 Linux Nacos
如何使用公网地址远程访问内网Nacos UI界面查看注册服务
如何使用公网地址远程访问内网Nacos UI界面查看注册服务
21 0
|
1天前
|
数据安全/隐私保护 Docker Sentinel
docker安装Sentinel
docker安装Sentinel
|
1天前
|
算法 Nacos Docker
docker部署nacos集群
docker部署nacos集群
29 0
|
1天前
|
负载均衡 Cloud Native Java
Nacos 注册中心(2023旧笔记)
Nacos 注册中心(2023旧笔记)
18 0
|
1天前
|
Java Nacos 数据库
Docker 安装 Nacos
Docker 安装 Nacos
24 0
|
1天前
|
安全 Linux Nacos
如何在CentOS使用Docker运行Nacos容器并实现无公网IP远程访问UI界面
如何在CentOS使用Docker运行Nacos容器并实现无公网IP远程访问UI界面
|
1天前
|
Dubbo Java 应用服务中间件
深度剖析:Dubbo使用Nacos注册中心的坑
2020年笔者在做微服务部件升级时,Dubbo的注册中心从Zookeeper切换到Nacos碰到个问题,最近刷Github又有网友提到类似的问题,就在这篇文章里做个梳理和总结。
深度剖析:Dubbo使用Nacos注册中心的坑
|
1天前
|
SpringCloudAlibaba Java Nacos
SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)
SpringCloud Alibaba微服务 -- Nacos使用以及注册中心和配置中心的应用(保姆级)
|
1天前
|
Dubbo Java 应用服务中间件
双活工作下的数据迁移:Nacos注册中心实战解析
这篇内容介绍了如何使用NacosSync组件进行双活项目中的注册中心数据迁移。首先,准备包括64位OS、JDK 1.8+、Maven 3.2+和MySQL 5.6+的环境。接着,获取并解压NacosSync安装包,配置数据库连接,启动服务,并通过访问特定URL检查系统状态。然后,通过NacosSync控制台进行集群配置,添加Zookeeper和Nacos集群,并设置同步任务。当数据同步完成后,Dubbo客户端(Consumer和Provider)更新配置以连接Nacos注册中心。最后,迁移完成后,原有的Zookeeper集群可下线,整个过程确保了服务的平滑迁移。
43 1