

在虚拟机(IP地址为192.168.10.100)中成功安装并运行Nacos,并且可以正常访问。服务可以在Nacos中正常注册和发现,但是在调用服务时出现UnknownHostException错误,具体错误信息如下图所示:
java.net.UnknownHostException: {service-name}
在Spring Cloud 2020.0.1.0之后的版本中,不再使用Netflix组件,因此Ribbon不再用于实现负载均衡。我们需要在消费者服务端添加以下依赖:
<!-- 升级spring cloud之后,Nacos消费者服务依赖该组件 -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>确保服务注册正常:首先确保所有服务在Nacos中注册和发现都正常,没有任何异常日志。
添加必要的依赖:在消费者服务的pom.xml文件中,添加spring-cloud-starter-loadbalancer依赖。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
</dependency>配置Nacos客户端:确保Nacos客户端配置正确,包括Nacos服务器地址和命名空间等信息。以下是一个示例配置:
spring:
cloud:
nacos:
discovery:
server-addr: 192.168.10.100:8848使用负载均衡注解:在服务调用端,使用Spring Cloud的@LoadBalanced注解配置RestTemplate,以启用负载均衡。
@Bean
@LoadBalanced
public RestTemplate restTemplate() {
return new RestTemplate();
}检查主机名解析:确保虚拟机和Docker容器中主机名解析正常。如果服务名不能被正确解析,可能需要在/etc/hosts文件中添加相关服务名和IP地址的映射。
服务注册代码示例:
@RestController
@RequestMapping("/api")
public class MyController {
@Autowired
private RestTemplate restTemplate;
@GetMapping("/call")
public String callService() {
// 假设调用的服务名为 "my-service"
return restTemplate.getForObject("http://my-service/endpoint", String.class);
}
}Nacos配置示例:
spring:
application:
name: my-consumer
cloud:
nacos:
discovery:
server-addr: 192.168.10.100:8848
loadbalancer:
ribbon:
eureka:
enabled: false在使用Spring Cloud和Nacos时,请注意以下几点:
/etc/hosts文件。@LoadBalanced注解配置RestTemplate,以启用Spring Cloud的负载均衡功能。通过以上步骤和注意事项,可以有效解决虚拟机中Nacos服务调用时出现的UnknownHostException问题,确保服务的正常调用和运行。