本地开发的Spring Cloud应用或者Dubbo应用托管到SAE时,您可以使用SAE的注册中心,也可以自建Nacos提供服务注册与发现功能。本文介绍如何搭建Nacos注册中心,并将应用部署在SAE进行托管。

前提条件

  • 已安装yum。
  • 执行应用程序前,请确保您Nacos注册中心的访问端口(如8848)已添加至您的安全组。

背景信息

某创业公司现在需要将微服务应用托管至SAE,但期望使用自建Nacos注册中心,不使用SAE注册中心。

本文以将Spring Cloud应用托管到SAE中的Demo应用ProviderConumser为例,指导您如何在单机上自建Nacos服务注册中心,将服务应用托管至SAE。

如果集群部署请参考集群部署说明

说明 服务注册中心使用优先级:SAE服务注册中心>MSE的Nacos服务注册中心>自建Nacos。不推荐使用自建Nacos,与SAE服务注册中心和MSE的Nacos服务注册中心相比,自建Nacos不仅需要购买各种搭建所需的资源,还需要投入尽力进行维护,耗费资源,增加运维成本。

步骤一:环境准备

Nacos依赖Java环境来运行。如果您是从代码开始构建并运行Nacos,请确保是在以下版本环境中安装使用。
  • 64 bit OS,支持Linux/Unix/Mac/Windows,推荐选用Linux/Unix/Mac。
  • 64 bit JDK 1.8及以上版本。
  1. 查询可安装的JDK。
    yum -y list java*
  2. 安装JDK。
    yum install -y java-latest-openjdk-devel.x86_64
  3. 配置JAVA_HOME。
    export JAVA_HOME=jdk-install-dir
    
    export PATH=$JAVA_HOME/bin:$PATH

步骤二:Nacos安装

  1. 下载Nacos。
    wget https://github.com/alibaba/nacos/releases/download/1.1.3/nacos-server-1.1.3.zip
  2. 解压Nacos并进入nacos/bin文件。
    unzip nacos-server-1.1.3.zip
    cd nacos/bin
    说明 如果服务器上没有Unzip工具,请执行 yum install unzip,并在安装后键入 Y
    (不推荐)自建Nacos服务注册中心_自建 Nacos 服务注册中心_最佳实践_Serverless 应用引擎 阿里云技术文档 第1张
  3. 启动Nacos。
    sh startup.sh -m standalone
    (不推荐)自建Nacos服务注册中心_自建 Nacos 服务注册中心_最佳实践_Serverless 应用引擎 阿里云技术文档 第2张

步骤三:服务注册与发现

Nacos启动后,提供了服务注册发现功能,需要在应用侧指定服务注册中心。在应用程序执行后,系统会依据所设服务注册中心,自动进行服务注册与发现。

注意 执行应用程序前,请确保您Nacos注册中心的访问端口(如8848 )已添加至您的安全组。
  1. 在服务应用侧指定注册中心,并运行应用Provider和Consumer。
    打开src\main\resources路径下的文件application.properties,指定Nacos Server的IP地址。
    • Provider

      修改前:

      spring.application.name=service-provider
      server.port=18081
      eureka.client.serviceUrl.defaultZone=http://127.0.0.1:8761/eureka/                            

      修改后

      spring.application.name=service-provider
      server.port=18081
      spring.cloud.nacos.discovery.server-addr=47.96.156.159:8848                            
    • Consumer

      修改前

      spring.application.name=service-consumer
      server.port=18082
      eureka.client.serviceUrl.defaultZone=http://127.0.0.1:8761/eureka/                            

      修改后

      spring.application.name=service-consumer
      server.port=18082
      spring.cloud.nacos.discovery.server-addr=47.96.156.159:8848                            
  2. 服务验证。
    • Linux/Unix/Mac 系统
      curl -X GET 'http://47.96.156.159:8848/nacos/v1/ns/instance/list?serviceName=service-provider'

      service-provider为服务名。47.96.156.159:8848为安装Nacos的主机IP地址。

      服务发现成功。

      (不推荐)自建Nacos服务注册中心_自建 Nacos 服务注册中心_最佳实践_Serverless 应用引擎 阿里云技术文档 第3张
    • Windows系统

      在浏览器中输入http://c:18082/echo-rest/{自定义变量}http://127.0.0.1:18082/echo-feign/{自定义变量}

      当出现类似下图页面表示服务注册、发现成功。

      (不推荐)自建Nacos服务注册中心_自建 Nacos 服务注册中心_最佳实践_Serverless 应用引擎 阿里云技术文档 第4张

      127.0.0.1:18082为运行Provider和Consumer的主机IP地址和访问端口。

步骤四:应用托管至SAE

将本地服务Provider和Consumer应用程序编译为WAR或者JAR包或者镜像,并部署到SAE,具体操作请参见应用部署概述

说明
  • 使用自建Nacos时请确保SAE的网络与自建Nacos的网络互通。
  • 使用自建Nacos为服务注册中心,在部署应用时建议使用镜像方式或者JAR包方式,并配置启动参数-Dnacos.use.endpoint.parsing.rule=false-Dnacos.use.cloud.namespace.parsing=false
    • 如采用镜像方式,请将-Dnacos.use.endpoint.parsing.rule=false-Dnacos.use.cloud.namespace.parsing=false配置在镜像文件中。
    • 如果JAR包方式,请在部署时启动命令中设置。(不推荐)自建Nacos服务注册中心_自建 Nacos 服务注册中心_最佳实践_Serverless 应用引擎 阿里云技术文档 第5张

如果您不熟悉如何制作Docker镜像,具体操作请参见制作应用容器Docker镜像

如果应用托管失败请查看日志变更记录应用监控定位问题。