栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

使用nacos创建一个简单的微服务项目

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用nacos创建一个简单的微服务项目

暴风雨结束后,你不会记得自己是怎样活下来的,你甚至不确定暴风雨真的结束了。但有一件事是确定的:当你穿过了暴风雨,你就不再是原来那个人。 ​​​

nacos

nacos文档说明

简单来说,方便集成了很多东西使用简单。

下载地址:https://github.com/alibaba/nacos/releases

nacos安装非常简单,直接解压即可。


startup.cmd 点击运行,会报错,启动不了。
打开startup.cmd ,找到set MODE="cluster"修改为

set MODE=“standalone”
这样就可以运行,cluster是集群模式,standalone是单击模式,再次运行

点击开头的 http://172.30.10.232:8840/nacos 就可以打开nacos控制面板,默认用户名和密码都是nacos,
这里我改了服务的端口,不修改的默认的是8848,我电脑上运行着另一个nacos,所以我修改了端口。

这样我们成功的启动了nacos。
接下来创建一个简单的微服务基于nacos的项目,这里我使用的是idea



这里使用了《spring cloud Alibaba微服务实战》中的pom文件。引入了spring cloud 和 spring boot 以及test的依赖。



    4.0.0

    com.zuiuxi.nacos
    nacos-sample
    1.0-SNAPSHOT
    nacos-sample
    nacos-sample演示


    
        2.1.15.RELEASE
        2.1.2.RELEASE
        1.8
    
    
    

        
            
                org.springframework.cloud
                spring-cloud-dependencies
                Greenwich.SR6
                pom
                import
            

            
                org.springframework.boot
                spring-boot-dependencies
                ${spring.boot.version}
                pom
                import
            

            
                com.alibaba.cloud
                spring-cloud-alibaba-dependencies
                ${spring.cloud.alibaba.version}
                pom
                import
            

            
                org.springframework.boot
                spring-boot-starter-web
                ${spring.boot.version}
            
            
                org.springframework.boot
                spring-boot-starter-test
                ${spring.boot.version}
            
        
    

    

        
            
            
                org.apache.maven.plugins
                maven-compiler-plugin
                3.7.0
                
                    ${java.version}
                    ${java.version}
                    UTF-8
                
            
            
                org.springframework.boot
                spring-boot-maven-plugin
            
        
    

然后我们创建三个模块,两个服务消费方和一个服务提供方。



    
        nacos-sample
        com.zuiuxi.nacos
        1.0-SNAPSHOT
    
    4.0.0

    com.zuiuxi.nacos
    nacos-provider-sample8081
    0.0.1-SNAPSHOT
    nacos-provider-sample8081
    Spring Cloud Alibaba演示

    
        
            org.springframework.boot
            spring-boot-starter-web
        
        
        
        
            org.springframework.boot
            spring-boot-starter-actuator
        

        
            org.springframework.boot
            spring-boot-starter-test
            test
        

        
        
            com.alibaba.cloud
            spring-cloud-starter-alibaba-nacos-discovery
        
    


这里补全了一些描述,引入了springBoot和cloud-alibaba和健康监控actuator。

在模块nacos-provider-sample8081 新建applicaiton.yml文件,补充配置。注意这里的nacos服务地址,没有该端口应该是 8848

server:
  #程序端口号
  port: 8081
spring:
  application:
    #应用名称
    name: nacos-provider-sample
  cloud:
    nacos:
      discovery:
        #nacos地址
        server-addr: 127.0.0.1:8840
management:
  endpoints:
    web:
      exposure:
        #公开所有端点
        include: '*'

创建启动类

package com.zuiuxi.test;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;


@SpringBootApplication
@EnableDiscoveryClient
public class NacosProviderSampleApplicaion {

    public static void main(String[] args) {
        SpringApplication.run(NacosProviderSampleApplicaion.class, args);
    }
}

启动,nacos控制面板那里显示了这个服务.


创建controller

package com.zuiuxi.test.controller;

import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;


@RestController
public class TestController {

    @Value("${server.port}")
    private String port;

    @RequestMapping("/test")
    public String test() {
        return "hello world test " + port;
    }
}


这里我删除了父项目的src文件夹。在浏览器中输入 http://localhost:8081/test即可得到

同理在编写一个 nacos-provider-sample8082模块,和8081一样,只需要修改端口号即可。
启动之后,nacos实例这里显示两个
在浏览器中输入 http://localhost:8082/test即可得到


点击详情,显示两个服务提供模块已经创建成功。接下来编写消费者模块

这里使用RestTemplate + Ribbon 实现远程调用

package com.zuiuxi.test.config;

import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;


public class GenericCinfiguration {

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

这里@LoadBalanced 注解会使客户端具有负载均衡的能力

创建controller

@RestController
public class TestController {

    private final String SERVER_URL = "http://nacos-provider-sample";

    @Resource
    private RestTemplate restTemplate;

    @RequestMapping("/test")
    public String test(){
        return restTemplate.getForObject(SERVER_URL + "/test",String.class);
    }
}

启动消费模块


我们不断的去刷新 发现有时候是8082 有时候就是8081,实现了简单的负载均衡,nacos-discovery包整合了ribbon。

项目完整工程
自此基于nacos的一个简单的微服务就创建成功了。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/343071.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号