一,注册中心nacos的使用
- 引入坐标
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
2.在应用的src/main/resources/application.yml配置文件中配置 Nacos Server 地址
spring:
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
3.使用 @EnableDiscoveryClient 注解开启服务注册与发现功能(在启动类上)
@SpringBootApplication
@EnableDiscoveryClient
public class ProviderApplication {
public static void main(String[] args) {
SpringApplication.run(ProviderApplication.class, args);
}
}
4.启动nacos服务,启动项目 ,访问http://127.0.0.1:8848/nacos就能看到注册的服务了
二,openfeign
- 引入坐标
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
2.创建feign包,用来存放所有的远程调用接口
3.创建远程调用的接口CouponFeignService
@FeignClient("gulimall-coupon")
public interface CouponFeignService {
@RequestMapping("/coupon/coupon/member/list")
public R getCoupon();
}
@FeignClient("gulimall-coupon")表示调用哪个服务的接口 @RequestMapping("/coupon/coupon/member/list")这里的地址需要些调用接口的全路径名
4.在启动类上使用@EnableFeignClients开启openfeign,然后就可以直接调用了。
@EnableFeignClients(basePackages = "com.atguigu.gulimall.member.feign")
@SpringBootApplication
@EnableDiscoveryClient
public class GulimallMemberApplication {
public static void main(String[] args) {
SpringApplication.run(GulimallMemberApplication.class, args);
}
}
@EnableFeignClients(basePackages = "com.atguigu.gulimall.member.feign")扫描存放所有远程接口的路径
三,配置中心nacos的使用
-
引入坐标
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
2. 在应用的 /src/main/resources/bootstrap.properties 配置文件中配置nacos信息
spring.application.name=gulimall-coupon
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
3. 在nacos配置中心创建 gulimall-coupon.properties配置
4. 编写配置文件内容
coupon.user.name=zhangsan
coupon.user.age=22
5.在代码中引入配置的属性,我们可以看到读的是配置中心的配置
@Value("${coupon.user.name}")
String userName;
@Value("${coupon.user.age}")
int age;
注:假如本地有application.properties,配置中心也有配置文件,则先找配置中心上的,如果配置中心上没有则读取本地的。
6.配置中心的命名空间和分组的使用,在配置中心上简历工作空间和分组
在项目的bootstrap.properties中配置命名空间和分组
spring.cloud.nacos.config.namespace=dbe4050f-d41c-4749-98d0-37698659840c
spring.cloud.nacos.config.group=prod
注:命名空间默认是public
7.读取多个配置中心的配置文件
在项目的bootstrap.properties中引入多个配置文件
spring.cloud.nacos.config.ext-config[0].data-id=datasource.yml
spring.cloud.nacos.config.ext-config[0].group=dev
spring.cloud.nacos.config.ext-config[0].refresh=true
spring.cloud.nacos.config.ext-config[1].data-id=mybatis.yml
spring.cloud.nacos.config.ext-config[1].group=dev
spring.cloud.nacos.config.ext-config[1].refresh=true
spring.cloud.nacos.config.ext-config[2].data-id=other.yml
spring.cloud.nacos.config.ext-config[2].group=dev
spring.cloud.nacos.config.ext-config[2].refresh=true
注:spring.cloud.nacos.config.ext-config[0].data-id 引入的那个配置文件,[0]表示引入的第一个文件
spring.cloud.nacos.config.ext-config[0].group 这个配置文件在那个分组里
spring.cloud.nacos.config.ext-config[0].refresh 是否自动刷新,不用启动项目