springcloud-Alibaba使用Nacos实现服务注册调用

下载nacos,找到bin目录下startup.cmd启动nacos。正常启动如图,默认端口8848

 

idea中建立springboot服务提供者工程,依赖如下

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

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

    <!--  springboot 整合web组件-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!--  服务注册中心 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        <version>0.2.2.RELEASE</version>
    </dependency>
</dependencies>

application,yml文件

spring:
  cloud:
    nacos:
      discovery:
        ###服务注册地址
        server-addr: 127.0.0.1:8848
  application:
    ##服务名称
    name: member
server:
  port: 8081

编写一个服务接口

@RestController
public class UserService {
    @Value("${server.port}")
    private String serverPort;

    @RequestMapping("/getUser")
    @ResponseBody
    public String getUserName(){
        return "yuanping"+serverPort;
    }
}

然后启动工程,启动成功后打开nacos主页查看服务注册情况。这里我不同端口启动两个服务。只需要把application.yml文件端口改为8082就行。

访问地址

http://localhost:8848/nacos/index.html

同样的我再创建一个消费者工程,同样创建springboot工程,maven依赖。编写一个消费接口。这个代码是获取到nacos注册的所有实例,然后通过负载均衡算法发别请求不同的主机端口。

@RestController
public class OrderService {

    @Autowired
    private DiscoveryClient discoveryClient;
    @Autowired
    private RestTemplate restTemplate;

    private AtomicInteger atomicInteger = new AtomicInteger(0);
    @RequestMapping("/getOrderToMember")
    public String getOrderToMember() {
        // 1.根据服务名称  从服务注册中心获取 调用接口地址集群列表
        List<ServiceInstance> instances = discoveryClient.getInstances("member");
        ServiceInstance serviceInstance = instances.get(atomicInteger.incrementAndGet()%instances.size());
        URI uri = serviceInstance.getUri();// ip和端口号
        // 2.使用本地负载均衡器 选择一个地址调用
        // 3. 使用httpclient调用接口
        String result = restTemplate.getForObject(uri + "/getUser", String.class);
        return result;
    }
}

直接访问接口地址,即可访问另一个工程的应用接口。每刷一次就是另一个工程端口。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值