源碼地址:GitHub·點這裏||GitEE·點這裏java
Alibaba-Cloud致力於提供微服務開發的一站式解決方案。此項目包含開發分佈式應用微服務的必需組件,方便開發者經過SpringCloud編程模型輕鬆使用這些組件來開發分佈式應用服務。只須要添加一些註解和少許配置,就能夠將SpringCloud應用接入阿里微服務解決方案,經過阿里中間件來迅速搭建分佈式應用系統。node
默認支持 WebServlet、WebFlux, OpenFeign、RestTemplate、SpringCloudGateway,Zuul,Dubbo和RocketMQ限流降級功能的接入,能夠在運行時經過控制檯實時修改限流降級規則,還支持查看限流降級 Metrics 監控。mysql
適配 Spring Cloud 服務註冊與發現標準,默認集成了 Ribbon 的支持。git
支持分佈式系統中的外部化配置,配置更改時自動刷新。github
基於 Spring Cloud Stream 爲微服務應用構建消息驅動能力。web
使用 @GlobalTransactional 註解, 高效而且對業務零侵入地解決分佈式事務問題。spring
提供秒級、精準、高可靠、高可用的定時(基於Cron表達式)任務調度服務。同時提供分佈式的任務執行模型,如網格任務。網格任務支持海量子任務均勻分配到全部 Worker(schedulerx-client)上執行。sql
一個更易於構建雲原生應用的動態服務發現、配置管理和服務管理平臺。數據庫
把流量做爲切入點,從流量控制、熔斷降級、系統負載保護等多個維度保護服務的穩定性。編程
一款開源的分佈式消息系統,基於高可用分佈式集羣技術,提供低延時的、高可靠的消息發佈與訂閱服務。
Apache Dubbo 是一款高性能 Java RPC 框架。
阿里巴巴開源產品,一個易於使用的高性能微服務分佈式事務解決方案。
阿里雲對象存儲服務(Object StorageService,簡稱OSS),是阿里雲提供的海量、安全、低成本、高可靠的雲存儲服務。您能夠在任何應用、任什麼時候間、任何地點存儲和訪問任意類型的數據。
阿里中間件團隊開發的一款分佈式任務調度產品,提供秒級、精準、高可靠、高可用的定時(基於 Cron 表達式)任務調度服務。
Nacos 致力於發現、配置和管理微服務。幫助開發者快速實現動態服務發現、服務配置、服務元數據及流量管理。敏捷構建、交付和管理微服務平臺。首先下載 Nacos 並啓動 Nacos server。
參考文章: Nacos組件,環境搭建和入門案例詳解
版本 2.1.x.RELEASE 對應的是 SpringBoot2.1.x版本。版本2.0.x.RELEASE對應的是SpringBoot2.0.x版本。PS一般學習新的東西,最容易讓人犯迷糊的地方就是版本對應關係,問題很差排查,通常均可以參考官網的給的樣例。
node08-nacos-server
node08-nacos-clien
配置內容以下:
my: name: cloud info: alibaba spring: datasource: type: com.alibaba.druid.pool.DruidDataSource druid: driverClassName: com.mysql.jdbc.Driver url: jdbc:mysql://localhost:3306/data_one username: root password: 123
核心內容:DataID、文件格式、文件內容的配置。這裏還配置了一個MySQL數據源。
(1)、服務端配置
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2.1.1.RELEASE</version> </dependency>
spring: application: name: node08-nacos-server cloud: nacos: discovery: server-addr: 127.0.0.1:8848
這裏的name
配置和上面DataID
一致,就能夠讀取上述配置內容。
@RestController public class ServerWeb { private static Logger logger = LoggerFactory.getLogger(ServerWeb.class) ; @RequestMapping(value = "/web/getMsg",method = RequestMethod.GET) public String getMsg (@RequestParam("name") String name){ logger.info("8001 服務被調用..."); return "Hello:" + name ; } }
@SpringBootApplication // SpringCloud原生註解@EnableDiscoveryClient開啓服務註冊發現功能 @EnableDiscoveryClient public class ApplicationServer { public static void main(String[] args) { SpringApplication.run(ApplicationServer.class,args) ; } }
(2)、客戶端配置
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>2.1.1.RELEASE</version> </dependency> <!-- Feign組件 --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>2.1.3.RELEASE</version> </dependency>
這裏也能夠基於Feign模式,訪問上述服務端提供的接口服務 。
提供接口配置
@Configuration public class RestConfig { @LoadBalanced @Bean public RestTemplate restTemplate() { return new RestTemplate(); } }
這裏用法和SpringCloud原生框架生態相同 。
請求方法
@RestController public class ClientWeb { @Resource private RestTemplate restTemplate ; @RequestMapping(value = "/web/getMsgV1/{name}",method = RequestMethod.GET) public String getMsgV1 (@PathVariable String name){ String reqUrl = "http://node08-nacos-server:8001/web/getMsg/"+name ; return restTemplate.getForObject(reqUrl,String.class) ; } }
Feign接口配置
@FeignClient("node08-nacos-server") public interface MsgFeign { @GetMapping("/web/getMsg") String getMsg (@RequestParam(name = "name") String name); }
這裏用法依舊和SpringCloud原生框架生態相同 。
請求方法
@RestController public class ClientWeb { @Resource private MsgFeign msgFeign ; @RequestMapping(value = "/web/getMsgV2/{name}",method = RequestMethod.GET) public String getMsgV2 (@PathVariable String name){ return msgFeign.getMsg(name) ; } }
@SpringBootApplication @EnableDiscoveryClient @EnableFeignClients(basePackages={"cloud.nacos.client.feign"}) public class ApplicationClient { public static void main(String[] args) { SpringApplication.run(ApplicationClient.class,args) ; } }
經過Nacos的配置管理能夠將整合架構體系內配置,集中統一在Nacos中存儲管理。分離的多環境配置,靈活的權限管理。
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId> <version>2.1.1.RELEASE</version> </dependency>
spring: application: name: node08-nacos-server cloud: nacos: discovery: server-addr: 127.0.0.1:8848 config: server-addr: 127.0.0.1:8848 file-extension: yaml
這裏的核心配置是config
配置。
這裏就是Spring框架原生的讀取方式。
@RestController @RefreshScope public class ValueWeb { @Value("${my.name:}") private String myName ; @Value("${my.info:}") private String myInfo ; @RequestMapping("/getNameInfo") public String getNameInfo (){ return myName+":"+myInfo ; } }
配置JDBC鏈接
這裏基於Druid鏈接池,配置JdbcTemplate數據庫訪問API。
@Configuration public class DruidConfig { @Value("${spring.datasource.druid.url}") private String dbUrl; @Value("${spring.datasource.druid.username}") private String username; @Value("${spring.datasource.druid.password}") private String password; @Value("${spring.datasource.druid.driverClassName}") private String driverClassName; /** * Druid 鏈接池配置 */ @Bean public DruidDataSource dataSource() { DruidDataSource datasource = new DruidDataSource(); datasource.setUrl(dbUrl); datasource.setUsername(username); datasource.setPassword(password); datasource.setDriverClassName(driverClassName); return datasource; } /** * JDBC操做配置 */ @Bean(name = "jdbcTemplate") public JdbcTemplate jdbcTemplate (@Autowired DruidDataSource dataSource){ return new JdbcTemplate(dataSource) ; } }
測試方法
@RestController public class JdbcWeb { @Resource private JdbcTemplate jdbcTemplate ; @RequestMapping("/getJdbc") public List<String> getJdbc (){ String sql = "select phone from d_phone" ; List<String> phoneEntityList = jdbcTemplate.queryForList(sql,String.class) ; return phoneEntityList ; } }
上面兩個使用案例走下來,感受和原生SpringCloud的用法區別不大,總體上手難度也不過高,畢竟AlibabaCloud框架是在SpringCloud框架基礎上。適配了阿里不少開源組件,在微服務框架組件選擇上,根據業務需求和團隊的熟悉程序選擇便可。
GitHub地址:知了一笑 https://github.com/cicadasmile/spring-cloud-base GitEE地址:知了一笑 https://gitee.com/cicadasmile/spring-cloud-base
推薦閱讀:微服務架構