Spring Cloud Alibaba Nacos 安装下载代码案例 入门9001集群负载均衡

1、官网安装Nacos:https://github.com/alibaba/nacos/releases

 2、启动Nacos

进入Nacos的bin目录  用cmd打开,默认是没这俩目录的,我选择是1.1.4版本1.1.4Nacos下贼地址,不知道新版本能不能启动, 

启动成功界面 ,访问

直接访问    http://localhost:8848/nacos  即可访问

代码案例

导入依赖

<!--SpringCloud ailibaba nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

创建application.yml文件,加入配置

server:
  port: 9001

spring:
  application:
    name: nacos-payment-provider
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848  # 配置Nacos地址
management:
  endpoints:
    web:
      exposure:
        include: '*'

这个时候随便写个Controller启动,之后就能在Nacos可视化界面 8848端口网页看到服务列表有这个服务了

这里可以建一个集群    nacos自带负载均衡,因为集成了Rabion

服务的消费者搭建

pom依赖加上:

<!--SpringCloud ailibaba nacos -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

配置文件  application.yml

server:
  port: 83


spring:
  application:
    name: nacos-order-consumer
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848


service-url:     #可以写上,解耦,也可以直接放在controller写个Strin final都行
  nacos-user-service: http://nacos-payment-provider

        启动类加上注解  

@EnableDiscoveryClient

写个配置文件去配置我们的RestTemplate  这个用来服务的调用, 

注意,如果这里的服务端有两个就一定要加上@LoadBanlanced  负载均衡 注解,不然服务消费者Consumer找不到提供者,会报错。

/**
 * @author Liuxiaowei
 * @date 2022年08月16日0:04
 */
@Configuration
public class ApplicationContextConfig {
    @Bean
    @LoadBalanced //负载均衡
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }
}

Controller类调用编写

/**
 * @author Liuxiaowei
 * @date 2022年08月16日0:05
 */
@RestController
@Slf4j
public class OrderNacosController {

//    public static final String SERVER_URL = "http://nacos-payment-provider";
    @Value("server.port")
    private String serverPort;
//这里我是直接在配置文件中配的,也可以直接写成上面的格式//    public static final String SERVER_URL = "http://nacos-payment-provider";
    @Value("${service-url.nacos-user-service}")   
    private String serverURL;
    @Resource
    private RestTemplate restTemplate;


    @GetMapping("/consumer/payment/nacos/{str}")
    public String getString(@PathVariable(value = "str") String string) {
        return restTemplate.getForObject(serverURL + "/payment/nacos/" + string, String.class);
    }

}

成功,自带负载均衡! 

Nacos和其他注册中心特性对比

猜你喜欢

转载自blog.csdn.net/weixin_46310452/article/details/126357340