工具 | 版本 |
---|---|
JDK | 1.8.0_301 |
MySQL | 5.7.36 |
IDEA | 2021.3.3 |
Maven | 3.8.5 |
SpringBoot | 2.7.1 |
SpringCloud | 2021.0.3 |
MyBatis-Plus | 3.2.0 |
Docker | 20.10.17 |
Nacos | 1.2.1 |
访问Nacos首页:http://localhost:8848/nacos/#/login
登录默认账户和密码:nacos
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
在 application.yml
中配置 Nacos server 的地址和应用名
spring:
datasource:
username: root
password: root
url: jdbc:mysql://192.168.10.129:3306/gulimall_sms?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai
driver-class-name: com.mysql.cj.jdbc.Driver
cloud:
nacos:
discovery:
server-addr: 127.0.0.1:8848
application:
name: gulimall-coupon
mybatis-plus:
mapper-locations: classpath:/mapper/**/*.xml
global-config:
db-config:
id-type: auto
server:
port: 7000
目的:让会员服务远程调用优惠券服务
想要远程调用别的服务
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
/**
* 这是一个声明式的远程调用
*/
@FeignClient(name = "gulimall-coupon")
public interface CouponFeignService {
@RequestMapping("/coupon/coupon/member/list")
public R membercoupons();
}
声明接口的每一个方法都是调用哪个远程服务的那个请求
@EnableFeignClients(basePackages = "com.atguigu.gulimall.member.feign")
@EnableDiscoveryClient
@SpringBootApplication
public class GulimallMemberApplication {
public static void main(String[] args) {
SpringApplication.run(GulimallMemberApplication.class, args);
}
}
坑:
这里启动失败了,报错是LoadBalance出错
解决办法:需要引入spring-cloud-loadbalancer依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-loadbalancer</artifactId>
<version>2.2.2.RELEASE</version>
</dependency>
<!-- 配置中心来做配置管理-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
spring.application.name=gulimall-coupon
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
写一个Controller方法
@RequestMapping("coupon/coupon")
public class CouponController {
@Autowired
private CouponService couponService;
@Value("${coupon.user.name}")
private String name;
@Value("${coupon.user.age}")
private Integer age;
@RequestMapping("/test")
public R test(){
return R.ok().put("name",name).put("age",age);
}
访问http://localhost:7000/coupon/coupon/test
发现读取的是系统变量的名字,并没有读取到我们在application.propertoes
中设置的
user.name=zhangsan2
user.age=20
注意:
要写上模块的前缀名coupon,才能读取到
coupon.user.name=zhangsan2
coupon.user.age=20
但是每次如果要修改配置就要去application.propertoes
中设置,这是很不方便的。因为微服务还要重启,这在生产中是不能接受的,所以我们采用Nacos来做统一的配置管理中心
使用注解:@RefreshScope
:动态获取并刷新配置
@RefreshScope
@RestController
@RequestMapping("coupon/coupon")
public class CouponController {
@Autowired
private CouponService couponService;
@Value("${coupon.user.name}")
private String name;
@Value("${coupon.user.age}")
private Integer age;
@RequestMapping("/test")
public R test(){
return R.ok().put("name",name).put("age",age);
}
注意:
@Value(“${配置项的名}”):获取到配置。
如果配置中心和当前应用的配置文件中都配置了相同的项,优先使用配置中心的配置。
默认:public(保留空间);默认新增的所有配置都在public空间。
1、开发,测试,生产:利用命名空间来做环境隔离。
启动微服务后发现系统会默认使用public下的gulimall-coupon.properties
文件
如果想要读取指定的命名空间下的gulimall-coupon.properties
文件,那就需要在
注意:在bootstrap.properties;配置上,需要使用哪个命名空间下的配置,
spring.cloud.nacos.config.namespace=9de62e44-cd2a-4a82-bf5c-95878bd5e871
默认所有的配置集都属于:DEFAULT_GROUP;
项目中的使用:每个微服务创建自己的命名空间,使用配置分组区分环境,dev,test,prod
spring.application.name=gulimall-coupon
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
spring.cloud.nacos.config.namespace=c57909ca-177f-4817-b4b6-17707f4c2237
spring.cloud.nacos.config.group=dev
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
三大组件:路由(Router)、断言(Predicate)、过滤(Filter)
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
配置nacos的注册中心地址
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
spring.application.name=gulimall-gateway
server.port=88
spring:
cloud:
gateway:
routes:
- id: test_route
uri: https://www.baidu.com
predicates:
- Query=url,baidu
- id: qq_route
uri: https://www.qq.com
predicates:
- Query=url,qq
访问:http://localhost:88/?url=qq
发现成功
访问:http://localhost:88/?url=baidu
发现也是成功的
至此:
Spring Cloud Alibaba整合 Nacos配置注册中心和Gateway网关路由成功