cloud Alibaba电商后台组件实战:Nacos2.0.3配置持久化与集群(跟着步骤走,绝对不会出错)

简介: cloud Alibaba电商后台组件实战:Nacos2.0.3配置持久化与集群(跟着步骤走,绝对不会出错)

Nacos2.0.3配置持久化与集群(跟着步骤走,绝对不会出错)

获取nacos


java 1.8 +

maven 3.2+

发行版github地址:https://github.com/alibaba/nacos/releases


选择最新的稳定版本 nacos2.0.3


下载解压即可

10.png



选择我们需要下载的对应安装包

2.png



注意 所有路径上的文件夹一定得是非中文无空格的不然会出现各种玄学的报错

3.png



打开mysql创建数据库 nacos-config(也可以自定义起名)库 执行这conf中的两个sql脚本文4.png

5.png



打开我们的conf 修改持久化文件

6.png



之后配置cluster.conf 我们要集群的地址 ip+端口

7.png



依次启动即可

8.png



查看 Nacos

9.png

服务注册进nacos client编写

创建新模块 e-commerce-naocs-client

所需依赖

   <dependencies>
       <!-- spring cloud alibaba nacos discovery 依赖 -->
       <dependency>
           <groupId>com.alibaba.cloud</groupId>
           <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
           <version>2.2.3.RELEASE</version>
       </dependency>
       <dependency>
           <groupId>com.imooc.ecommerce</groupId>
           <artifactId>e-commerce-mvc-config</artifactId>
           <version>1.0-SNAPSHOT</version>
       </dependency>
       <!-- 数据绑定 -->
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-configuration-processor</artifactId>
           <optional>true</optional>
       </dependency>
       <!-- nacos config -->
       <dependency>
           <groupId>com.alibaba.cloud</groupId>
           <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
       </dependency>
       <!-- zipkin = spring-cloud-starter-sleuth + spring-cloud-sleuth-zipkin-->
       <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-starter-zipkin</artifactId>
       </dependency>
       <dependency>
           <groupId>org.springframework.kafka</groupId>
           <artifactId>spring-kafka</artifactId>
           <version>2.5.0.RELEASE</version>
       </dependency>
       <!-- Ribbon -->
       <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-starter-netflix-ribbon</artifactId>
       </dependency>
       <!-- open feign -->
       <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-starter-openfeign</artifactId>
       </dependency>
       <!-- feign 替换 JDK 默认的 URLConnection 为 okhttp -->
       <dependency>
           <groupId>io.github.openfeign</groupId>
           <artifactId>feign-okhttp</artifactId>
       </dependency>
       <!-- 使用原生的 Feign Api 做的自定义配置, encoder 和 decoder -->
       <dependency>
           <groupId>io.github.openfeign</groupId>
           <artifactId>feign-gson</artifactId>
           <version>11.0</version>
       </dependency>
       <!-- 集成 hystrix -->
       <dependency>
           <groupId>org.springframework.cloud</groupId>
           <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
       </dependency>
   </dependencies>

编写对应配置文件


这里我们使用 bootstrap.yml应为nacos也可以上云配置我们要保证他优先被夹在,bootstrap优先级大于application 于是我们使用bootstrap

server:
  port: 8000
  servlet:
    context-path: /ecommerce-nacos-client
spring:
  application:
    name: e-commerce-nacos-client #注册到nacos的服务名称 之后的服务调用 等等 这里在naocs配置上云的时候 会师config的前缀
  cloud:
    nacos:
      discovery:
        server-addr:http: 192.168.3.8:8848,192.168.3.8:8858,192.168.3.8:8868 #要注册的nacos服务中心的地址
        enabled: true # 使用naocs作为服务注册中心
        namespace: e25fa4c3-8b0b-4eb5-ae4f-6d1b8c7fd7ea #e25fa4c3-8b0b-4eb5-ae4f-6d1b8c7fd7ea 对应nacos上的配置命名空间的id
#暴露端点
management:
  endpoints:
    web:
      exposure:
        include: '*'
  endpoint:
    health:
      show-details: always

编写一个查看nacos节点信息到方法

@Slf4j
@Service
public class NacosClientService {
    public final DiscoveryClient discoveryClient;
    public NacosClientService(DiscoveryClient discoveryClient) {
        this.discoveryClient = discoveryClient;
    }
    /*
     *  打印 nacos client 信息到日志中
     * */
    public List<ServiceInstance> getNacosClientinfo(String serviceid) {
        log.info("request naocs client to get service instance info:[{}]", serviceid);
        return discoveryClient.getInstances(serviceid);
    }

controller

@RestController
@Slf4j
@RequestMapping("/nacos-client")
public class NacosClinetController {
    private final NacosClientService nacosClientService;
    public NacosClinetController(NacosClientService nacosClientService) {
        this.nacosClientService = nacosClientService;
    }
    @GetMapping(value = "/service-instance")
    public List<ServiceInstance> logNacosClientinfo(@RequestParam(defaultValue = "e-commerce-nacos-client") String serviceid) {
        log.info("coming in log nacos client info :[{}]", serviceid);
        return nacosClientService.getNacosClientinfo(serviceid);
    }
}

这个时候我们用idea的访问脚本来看返回结果


编写脚本nacos-client.http


### 查询服务示例信息

### 查询服务示例信息
http://localhost:8000/ecommerce-nacos-client/nacos-client/service-instance
Accept: application/json

查看返回结果


HTTP/1.1 200 
Content-Type: application/json
Transfer-Encoding: chunked
Date: Fri, 03 Dec 2021 11:49:31 GMT
Keep-Alive: timeout=60
Connection: keep-alive
{
  "code": 0,
  "message": "",
  "data": [
    {
      "serviceId": "e-commerce-nacos-client",
      "host": "192.xxx.x.x",
      "port": 8000,
      "secure": false,
      "metadata": {
        "nacos.instanceId": "192.xxx.x.x#8000#DEFAULT#DEFAULT_GROUP@@e-commerce-nacos-client",
        "nacos.weight": "1.0",
        "nacos.cluster": "DEFAULT",
        "nacos.ephemeral": "true",
        "nacos.healthy": "true",
        "preserved.register.source": "SPRING_CLOUD"
      },
      "uri": "http://192.xxx.x.x:8000",
      "scheme": null,
      "instanceId": null
    }
  ]
}


相关文章
|
17天前
|
JSON Java Nacos
SpringCloud 应用 Nacos 配置中心注解
在 Spring Cloud 应用中可以非常低成本地集成 Nacos 实现配置动态刷新,在应用程序代码中通过 Spring 官方的注解 @Value 和 @ConfigurationProperties,引用 Spring enviroment 上下文中的属性值,这种用法的最大优点是无代码层面侵入性,但也存在诸多限制,为了解决问题,提升应用接入 Nacos 配置中心的易用性,Spring Cloud Alibaba 发布一套全新的 Nacos 配置中心的注解。
|
1月前
|
存储 人工智能 Java
Spring AI Alibaba 配置管理,用 Nacos 就够了
本文通过一些实操案例展示了 Spring AI Alibaba + Nacos 在解决 AI 应用中一系列复杂配置管理挑战的方案,从动态 Prompt 模板的灵活调整、模型参数的即时优化,到敏感信息的安全加密存储。Spring AI Alibaba 简化了对接阿里云通义大模型的流程,内置 Nacos 集成也为开发者提供了无缝衔接云端配置托管的捷径,整体上极大提升了 AI 应用开发的灵活性和响应速度。
231 13
|
1月前
|
负载均衡 应用服务中间件 Nacos
Nacos配置中心
Nacos配置中心
100 1
Nacos配置中心
|
1月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评
Nacos作为流行的微服务注册与配置中心,其稳定性与易用性广受好评。然而,“客户端不发送心跳检测”是使用中常见的问题之一。本文详细探讨了该问题的原因及解决方法,包括检查客户端配置、网络连接、日志、版本兼容性、心跳检测策略、服务实例注册状态、重启应用及环境变量等步骤,旨在帮助开发者快速定位并解决问题,确保服务正常运行。
48 5
|
1月前
|
监控 Java 测试技术
Nacos 配置中心变更利器:自定义标签灰度
本文是对 MSE Nacos 应用自定义标签灰度的功能介绍,欢迎大家升级版本进行试用。
158 11
|
1月前
|
网络安全 Nacos 开发者
Nacos作为流行的微服务注册与配置中心,“节点提示暂时不可用”是常见的问题之一
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,“节点提示暂时不可用”是常见的问题之一。本文将探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务的正常运行。通过检查服务实例状态、网络连接、Nacos配置、调整健康检查策略等步骤,可以有效解决这一问题。
37 4
|
1月前
|
Java 网络安全 Nacos
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。
Nacos作为流行的微服务注册与配置中心,其稳定性和易用性备受青睐。然而,实际使用中常遇到“客户端不发送心跳检测”的问题。本文深入探讨该问题的原因及解决方案,帮助开发者快速定位并解决问题,确保服务正常运行。通过检查客户端配置、网络连接、日志、版本兼容性、心跳策略、注册状态、重启应用和环境变量等步骤,系统地排查和解决这一问题。
53 3
|
1月前
|
安全 Nacos 数据库
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改
Nacos是一款流行的微服务注册与配置中心,但直接暴露在公网中可能导致非法访问和数据库篡改。本文详细探讨了这一问题的原因及解决方案,包括限制公网访问、使用HTTPS、强化数据库安全、启用访问控制、监控和审计等步骤,帮助开发者确保服务的安全运行。
55 3
|
2月前
|
JSON SpringCloudAlibaba Java
Springcloud Alibaba + jdk17+nacos 项目实践
本文基于 `Springcloud Alibaba + JDK17 + Nacos2.x` 介绍了一个微服务项目的搭建过程,包括项目依赖、配置文件、开发实践中的新特性(如文本块、NPE增强、模式匹配)以及常见的问题和解决方案。通过本文,读者可以了解如何高效地搭建和开发微服务项目,并解决一些常见的开发难题。项目代码已上传至 Gitee,欢迎交流学习。
184 1
Springcloud Alibaba + jdk17+nacos 项目实践
|
1月前
|
SQL 关系型数据库 数据库连接
"Nacos 2.1.0版本数据库配置写入难题破解攻略:一步步教你排查连接、权限和配置问题,重启服务轻松解决!"
【10月更文挑战第23天】在使用Nacos 2.1.0版本时,可能会遇到无法将配置信息写入数据库的问题。本文将引导你逐步解决这一问题,包括检查数据库连接、用户权限、Nacos配置文件,并提供示例代码和详细步骤。通过这些方法,你可以有效解决配置写入失败的问题。
87 0