Springcloud Netflix提供的服務進入維護模式,也就是一段時間內SpringcloudNetflix提供的服務和功能就這么多了,不在開發新的組件和功能。
SpringcloudAlibaba致力於提供微服務開發的一站式解決方案。方便開發者通過springcloud編程模型輕松使用這些組件開發分布式應用服務。依托於coud alibaba,只需要添加一些注解和少量配置,就可以將Spring cloud應用接入阿里微服務解決方案。其主要組件包括Sentinel、Nacos、RocketMQ、Dubbo、Seata、Alibaba Cloud OSS、Alibaba Cloud Scheduler、Alibaba Cloud SMS等。
阿里cloud項目官網:https://github.com/alibaba/spring-cloud-alibaba
1.Nacos簡介和安裝
1.簡介
一個更易於構建雲原生應用的動態服務發現、配置管理和服務管理平台。
Dynamic Naming And Configuration Service,實際上相當於注冊中心+配置中心的組合。相當Springcloud中Eureka + Config + Bus的組合。
nacos官網:https://nacos.io/zh-cn/
git官網:https://github.com/alibaba/nacos
2.安裝(我下載的版本是1.3.1)
(1)到https://github.com/alibaba/nacos/releases下載安裝包。如下:
nacos-server-1.3.1.zip
(2)解壓后啟動
直接運行bin/startup.cmd
(3)訪問測試,默認的端口是8848,可以在application.properties中進行修改
默認的賬號密碼都是:nacos
登錄之后如下:
2.支付訂單模塊使用nacos做注冊中心
0.父pom文件確定pom有下面坐標
<!--spring cloud alibaba 2.1.0.RELEASE--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-dependencies</artifactId> <version>2.1.0.RELEASE</version> <type>pom</type> <scope>import</scope> </dependency>
1.支付模塊
1.新建moudle
2.修改pom
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactId>cloud</artifactId> <groupId>cn.qz.cloud</groupId> <version>1.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>cloudalibaba-provider-nacos-payment9001</artifactId> <dependencies> <!--引入自己抽取的工具包--> <dependency> <groupId>cn.qz.cloud</groupId> <artifactId>cloud-api-commons</artifactId> <version>${project.version}</version> </dependency> <!--SpringCloud ailibaba nacos --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!-- SpringBoot整合Web組件 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <!--日常通用jar包配置--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> </project>
3.修改yml
server:
port: 9001
spring:
application:
name: nacos-payment-provider
cloud:
nacos:
discovery:
server-addr: localhost:8848 #配置Nacos地址
management:
endpoints:
web:
exposure:
include: '*'
4.主啟動類
package cn.qz.cloud.alibaba; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; /** * @Author: qlq * @Description * @Date: 21:51 2020/10/26 */ @EnableDiscoveryClient @SpringBootApplication public class PaymentMain9001 { public static void main(String[] args) { SpringApplication.run(PaymentMain9001.class, args); } }
5.業務類:
package cn.qz.cloud.alibaba.controller; import cn.qz.cloud.utils.JSONResultUtil; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; /** * @Author: qlq * @Description * @Date: 21:52 2020/10/26 */ @RestController @RequestMapping("/nacos/payment") public class PaymentController { @Value("${server.port}") private String serverPort; @GetMapping(value = "/getServerPort") public JSONResultUtil<String> getServerPort() { return JSONResultUtil.successWithData(serverPort); } }
6.啟動后查看nacos服務列表
2.創建模塊cloudalibaba-provider-nacos-payment9002和上面構成集群
啟動后查看nacos服務列表:
3.創建訂單服務調用上面支付服務
1.新建訂單模塊cloudalibaba-consumer-nacos-order83
2.修改pom
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactId>cloud</artifactId> <groupId>cn.qz.cloud</groupId> <version>1.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>cloudalibaba-consumer-nacos-order83</artifactId> <dependencies> <!--SpringCloud ailibaba nacos --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!--引入自己抽取的工具包--> <dependency> <groupId>cn.qz.cloud</groupId> <artifactId>cloud-api-commons</artifactId> <version>${project.version}</version> </dependency> <!-- SpringBoot整合Web組件 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <!--日常通用jar包配置--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> </project>
3.修改yml
server:
port: 83
spring:
application:
name: nacos-order-consumer
cloud:
nacos:
discovery:
server-addr: localhost:8848
#消費者將要去訪問的微服務名稱(注冊成功進nacos的微服務提供者)
service-url:
nacos-payment-provider: http://nacos-payment-provider
4.主啟動類:
package cn.qz.cloud.alibaba; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; /** * @Author: qlq * @Description * @Date: 22:27 2020/10/26 */ @EnableDiscoveryClient @SpringBootApplication public class OrderNacosMain83 { public static void main(String[] args) { SpringApplication.run(OrderNacosMain83.class, args); } }
5.業務類:
(1)配置類
package cn.qz.cloud.alibaba.config; import org.springframework.cloud.client.loadbalancer.LoadBalanced; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.web.client.RestTemplate; @Configuration public class ApplicationContextConfig { @Bean @LoadBalanced public RestTemplate getRestTemplate() { return new RestTemplate(); } }
(2)Controller
package cn.qz.cloud.alibaba.controller; import cn.qz.cloud.utils.JSONResultUtil; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.client.RestTemplate; import javax.annotation.Resource; @RestController @Slf4j @RequestMapping("/nacos/consumer/") public class OrderNacosController { @Resource private RestTemplate restTemplate; @Value("${service-url.nacos-payment-provider}") private String serverURL; @GetMapping(value = "/getServerPort") public JSONResultUtil<String> getServerPort() { return restTemplate.getForObject(serverURL + "/nacos/payment/getServerPort", JSONResultUtil.class); } }
6.啟動后測試
liqiang@root MINGW64 ~/Desktop $ curl http://localhost:83/nacos/consumer/getServerPort % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --: 0 0 0 0 0 0 0 0 --:--:-- 0:00:01 --:100 52 0 52 0 0 35 0 --:--:-- 0:00:01 --:--:-- 35{"success":true,"code":"200","msg":"","data":"9002"} liqiang@root MINGW64 ~/Desktop $ curl http://localhost:83/nacos/consumer/getServerPort % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:100 52 0 52 0 0 666 0 --:--:-- --:--:-- --:--:-- 1106{"success":true,"code":"200","msg":"","data":"9001"}
當然訂單模塊也可以用feign來進行服務調用。
補充:各注冊中心的異同點
另外Nacos可以支持AP與CP模式。C是所有節點在同一時間看到的數據是一致的;而A的定義是所有的請求都會得到響應。nacos默認是AP,如果需要切換CP如下:
$ curl -X PUT "http://localhost:8848/nacos/v1/ns/operator/switches?entry=serverMode&value=CP"
% Total % Received % Xferd Average Speed Time Time Time Current
Dload Upload Total Spent Left Speed
100 2 100 2 0 0 14 0 --:--:-- --:--:-- --:--:-- 16ok
3.nacos做配置中心
1.基本的使用
1.新建項目cloudalibaba-config-nacos-client3377
2.修改pom
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <artifactId>cloud</artifactId> <groupId>cn.qz.cloud</groupId> <version>1.0-SNAPSHOT</version> </parent> <modelVersion>4.0.0</modelVersion> <artifactId>cloudalibaba-config-nacos-client3377</artifactId> <dependencies> <!-- nacos config--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> </dependency> <!-- SpringCloud ailibaba nacos--> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!--引入自己抽取的工具包--> <dependency> <groupId>cn.qz.cloud</groupId> <artifactId>cloud-api-commons</artifactId> <version>${project.version}</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--監控--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId> </dependency> <!--熱部署--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> <scope>runtime</scope> <optional>true</optional> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> </dependencies> </project>
3.建立bootstrap.yml
server:
port: 3377
spring:
application:
name: nacos-config-client
cloud:
nacos:
discovery:
server-addr: localhost:8848 #Nacos服務注冊中心地址
config:
server-addr: localhost:8848 #Nacos作為配置中心地址
file-extension: yaml #指定yaml格式配置
#${prefix}-${spring.profile.active}.${file-extension}
# ${spring.application.name}-${spring.profile.active}.${file-extension}
# nacos-config-client-dev.yml
4.建立application.yml
spring:
profiles:
# active: prod
active: dev #表示開發環境
5.建立主啟動類:
package cn.qz.cloud.alibaba; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.client.discovery.EnableDiscoveryClient; @EnableDiscoveryClient @SpringBootApplication public class NacosConfigClientMain3377 { public static void main(String[] args) { SpringApplication.run(NacosConfigClientMain3377.class, args); } }
6.建立controller測試
package cn.qz.cloud.alibaba.controller; import cn.qz.cloud.utils.JSONResultUtil; import org.springframework.beans.factory.annotation.Value; import org.springframework.cloud.context.config.annotation.RefreshScope; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController @RefreshScope // 支持Nacos的動態刷新功能 @RequestMapping("/nacos/config/") public class ConfigClientController { @Value("${config.info}") private String configInfo; @GetMapping("/configInfo") public JSONResultUtil<String> configInfo() { return JSONResultUtil.successWithData(configInfo); } }
7.nacos建立配置文件:
(1)點擊如下按鈕:
(2)新建dataId為nacos-config-client-dev.ymal。 實際dataId的值為: ${prefix}-${spring.profile.active}.${file-extension},默認prefix是${spring.application.name},例如上面的對應nacos-config-client-dev.yaml
啟動后訪問測試:
$ curl http://localhost:3377/nacos/config/configInfo % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 101 0 101 0 0 404 0 --:--:-- --:--:-- --:--:-- 404{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=2!"}
(3)nacos新建dataId為nacos-config-client-prod.yaml的配置,內容如下:
修改applicaiton.yml中激活的版本,如下:
spring:
profiles:
active: prod
# active: dev #表示開發環境
測試:
$ curl http://localhost:3377/nacos/config/configInfo % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 102 0 102 0 0 502 0 --:--:-- --:--:-- --:--:-- 502{"success":true,"code":"200","msg":"","data":"nacos-config-client-prod文件,ymal類型。version=1!"}
2.nacos按組group分組方案
nacos允許通過group區分不同的配置文件。默認是組DEFAULT_GROUP。
1.新建配置文件並且指定組
2.bootstrap.yml指定組和application.yml指定激活的開發環境
server: port: 3377 spring: application: name: nacos-config-client cloud: nacos: discovery: server-addr: localhost:8848 #Nacos服務注冊中心地址 config: server-addr: localhost:8848 #Nacos作為配置中心地址 file-extension: yaml #指定yaml格式配置 group: group1
spring:
profiles:
# active: prod
active: dev #表示開發環境
3.啟動測試:
$ curl http://localhost:3377/nacos/config/configInfo % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 108 0 108 0 0 532 0 --:--:-- --:--:-- --:--:-- 532{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=1!group1!"}
3.按namespace分組
nacos還支持按namespace分組,namespace包含group,group包含dataId。 類似於java的package。
1.新建一個namespace
2.該namespace下面新建配置文件,dataId為 nacos-config-client-dev.yaml
新建的配置如下:
3.修改bootstrap.yaml,指定group和namespace
server: port: 3377 spring: application: name: nacos-config-client cloud: nacos: discovery: server-addr: localhost:8848 #Nacos服務注冊中心地址 config: server-addr: localhost:8848 #Nacos作為配置中心地址 file-extension: yaml #指定yaml格式配置 group: group1 namespace: namespace-dev
4.重啟后測試
$ curl http://localhost:3377/nacos/config/configInfo % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 139 0 139 0 0 684 0 --:--:-- --:--:-- --:--:-- 684{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=1!group1!namespace為【namespace-dev】"}
5.修改配置內容的版本為2:
config:
info: nacos-config-client-dev文件,ymal類型。version=2!group1!namespace為【namespace-dev】
6.保存后測試:(說明自動更新為nacos配置文件中的內容)
$ curl http://localhost:3377/nacos/config/configInfo % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 139 0 139 0 0 139 0 --:--:-- --:--:-- --:--:-- 135k{"success":true,"code":"200","msg":"","data":"nacos-config-client-dev文件,ymal類型。version=2!group1!namespace為【namespace-dev】"}