nacos集群能启动成功,但是服务注册不了。

背景

在使用docker部署nacos集群+nginx反向代理时,遇到了如下问题。

报错内容

 failed to req API:/nacos/v1/ns/instance after all servers tried: failed to req API:xxx:80/nacos/v1/ns/instance. 
 
 code:400 msg: <html><body><h1>Whitelabel Error Page</h1><p>This application has no explicit mapping for /error, so you are seeing this as a fallback.</p><div id='created'>Wed Jan 11 20:08:02 CST 2023</div><div>There was an unexpected error (type=Bad Request, status=400).</div><div>receive invalid redirect request from peer 120.79.39.211</div></body></html>

在这里插入图片描述

解决办法

进入容器内部

docker exec -it [容器id] /bin/bash

修改nacos的配置文件

cd /home/nacos/conf
ll
vim application.properties 

application.properties 加入如下配置

### Specify local server's IP: 
nacos.inetutils.ip-address=本机ip

重启容器

docker restart [容器id]

所有nacos容器都如此操作。

nacos是一个开源的分布式服务发现、配置和管理平台,支持多种协议(Dubbo、gRPC、HTTP、Spring Cloud等)和多种数据存储方式(MySQL、Mongodb、Memory等)。nacos集群节点是指在nacos平台上运行的多个实例,这些实例可以通过互相通信来实现服务注册、发现和配置管理。以下是nacos集群节点的介绍和演示: 1. nacos集群节点的介绍 nacos集群节点可以通过以下步骤来实现: - 部署多个nacos实例,每个实例都有自己的IP地址和端口号。 - 将这些实例配置为集群模式,以便它们可以相互通信并共享数据。 - 配置负载均衡器,将请求分发到不同的nacos实例上,以实现负载均衡和高可用性。 2. nacos集群节点的演示 以下是一个简单的nacos集群节点演示: - 假设我们有三个nacos实例,它们的IP地址和端口号分别为:192.168.150.188:8848、192.168.150.189:8848和192.168.150.190:8848。 - 在每个实例的配置文件中,将cluster.enabled设置为true,以启用集群模式。 - 启动这三个实例,并确保它们都已成功启动。 - 配置nginx负载均衡器,将请求分发到这三个实例上。以下是一个简单的nginx配置文件示例: ```nginx http { upstream nacos_cluster { server 192.168.150.188:8848; server 192.168.150.189:8848; server 192.168.150.190:8848; } server { listen 80; server_name nacos.example.com; location / { proxy_pass http://nacos_cluster; } } } ``` - 保存并关闭nginx配置文件,并重新加载nginx配置。 - 现在,您可以通过访问http://nacos.example.com来访问nacos集群节点了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值