Spring Cloud Alibaba Nacos之服务注册中心

安装Nacos

官网下载

Windows 下启动Nacos

在这里插入图片描述
启动成功后访问 http://localhost:8848/nacos
默认密码账号 nacos
在这里插入图片描述

新建项目将服务注册进Nacos

创建服务提供者

建工程 cloudalibaba-provider-payment9001
在父pom中引入alibabaCloud依赖
在查看能看到
官网讲解
在这里插入图片描述

<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-alibaba-dependencies</artifactId>
	<version>2.1.0.RELEASE</version>
	<type>pom</type>
	<scope>import</scope>
</dependency>

添加服务9001里面的pom

<dependencies>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>

        <!--    引入自定义的api通用包,可以使用Payment支付Entity    -->
        <dependency>
            <groupId>com.example.common</groupId>
            <artifactId>cloud-api-commons</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
    </dependencies>

YML 配置文件

server:
  port: 9001

spring:
  application:
    name: nacos-provider-service
  cloud:
    nacos:
      discovery:
        server-addr: localhost:8848 # 配置nacos地址

management:
  endpoints:
    web:
      exposure:
        include: "*"


写主启动类

@SpringBootApplication
@EnableDiscoveryClient
public class NacosProviderMain9001 {
    public static void main(String[] args) {
        SpringApplication.run(NacosProviderMain9001.class,args);
    }
}

controller

@RestController
public class EchoController {

    @GetMapping(value = "/echo/{str}")
    public String echo(@PathVariable String str){
        return "Hello Nacos Discovery " + str;
    }
}

打开Nacos网页查看服务已经注册进去了
在这里插入图片描述

和建9001同样的步骤在建一个服务9002,为了学习Nacos的负载均衡

创建服务消费者

新建服务83
pom文件和 9001,9002 相同

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

# 消费者将要去访问微服务名称(注册成功进nacos的微服务提供者)
service-url:
  nacos-user-service: http://nacos-provider-service
public class OrederNacosController {

    @Resource
    private RestTemplate restTemplate;

    @Value("${service-url.nacos-user-service}")
    private String serverURL;

    @GetMapping(value = "/consumer/payment/nacos/{id}")
    public String getInfo(@PathVariable("id") Long id){
        log.info("**********");
        return restTemplate.getForObject(serverURL+"/payment/nacos/"+id,String.class);
    }
}

这里记得一点要加上 @LoadBalanced 注解 实现负载均衡

Ribbon 实现客户端 负载均衡的工具 (负载均衡 + RestTemplate调用)
在这里插入图片描述
从这里查看到 Nacos 整合了Ribbon 实现了负载均衡

@Configuration
public class ApplicationContextConfig {

    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
}

查看nacos 服务已经注册进去了
在这里插入图片描述
使用consumer访问 服务提供者看是否成功
成功访问到,刷新也有轮询负载均衡
在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值