Nacos---nacos作为注册中心(Spring Cloud)

本人正在构建的一个开源的项目地址:教育之星

首先说下nacos即可作为注册中心,也可以作为配置中心,所以这里的客户端需要注意jar包的引入。

首先服务端的启动,直接官网下载就行:https://github.com/alibaba/nacos/releases

自己选择版本就行,我这里下载的1.1.4的版本

启动之后访问:http://localhost:8848/nacos

账号,密码都是:nacos

接下来可客户端的配置:

新建2个服务,a和b

外层POM文件配置:

 <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
    <java.version>1.8</java.version>
    <spring-cloud.version>Finchley.SR4</spring-cloud.version>
    <spring-boot.version>2.0.5.RELEASE</spring-boot.version>
  </properties>

  <dependencies>
    <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
    <dependency>
      <groupId>org.projectlombok</groupId>
      <artifactId>lombok</artifactId>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>fastjson</artifactId>
      <version>1.2.47</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-core</artifactId>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
    </dependency>
    <dependency>
      <groupId>commons-lang</groupId>
      <artifactId>commons-lang</artifactId>
      <version>2.6</version>
    </dependency>
    <dependency>
      <groupId>commons-collections</groupId>
      <artifactId>commons-collections</artifactId>
      <version>3.2.2</version>
    </dependency>
  </dependencies>

  <!-- spring cloud 配置 -->
  <dependencyManagement>
    <dependencies>
      <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-dependencies</artifactId>
        <version>${spring-boot.version}</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
      <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-dependencies</artifactId>
        <version>${spring-cloud.version}</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
    </dependencies>
  </dependencyManagement>

a服务

POM文件配置

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.alibaba.cloud/spring-cloud-starter-alibaba-nacos-discovery -->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.0.0.RELEASE</version>
        </dependency>

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

yml文件配置,如果只是作为注册中心的话,bootstrap和application都行。如果要作为配置中心的话,最好使用bootstrap

spring:
  application:
    name: nacosA
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
      config:
        server-addr: 127.0.0.1:8848
        file-extension: yaml
server:
  port: 8661

这里注意:需要制定2个地址,1个是注册中心的地址,1个是配置中心地址。如果无需配置中心可以无需指定。指定配置文件类型,yaml和properties

启动类:

@SpringBootApplication
@EnableDiscoveryClient
@EnableFeignClients
public class AApplication {

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

这里使用的openFeign来进行服务之间的调用,不是使用的官网介绍的restTemplate。

新建测试请求:

@RestController
public class AController {

    @Autowired
    private BService bService;

    @GetMapping("/ta")
    public String testA(){
        return "testA";
    }

    @GetMapping("/a2b")
    public String testUserAToB(){
        return bService.testB();
    }
}

新建FeignClient

@FeignClient(name = "nacosB")
public interface BService {

    @GetMapping("/tb")
    String testB();
}

启动服务即可

b服务的配置和a服务雷同

调用http://localhost:8661/a2b

返回正确。

这里注意application name的命名。如果使用-线的话,可能会存在一定的问题。 导致服务不能被注册和发现

发布了183 篇原创文章 · 获赞 37 · 访问量 16万+

猜你喜欢

转载自blog.csdn.net/zhuwei_clark/article/details/104245809