本人正在构建的一个开源的项目地址:教育之星
首先说下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服务雷同
返回正确。
这里注意application name的命名。如果使用-线的话,可能会存在一定的问题。 导致服务不能被注册和发现