myclouds3.x技术预演系列:基于SpringCloudAlibaba和Nacos构建微服务入门实例。java
SpringCloudAlibaba简介git
Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。此项目包含开发分布式应用微服务的必需组件,方便开发者经过 Spring Cloud 编程模型轻松使用这些组件来开发分布式应用服务。依托 Spring Cloud Alibaba,您只须要添加一些注解和少许配置,就能够将 Spring Cloud 应用接入阿里微服务解决方案,经过阿里中间件来迅速搭建分布式应用系统。[more]github
Nacos简介spring
Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据及流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Nacos 是构建以“服务”为中心的现代应用架构 (例如微服务范式、云原生范式) 的服务基础设施。[more]编程
基于SpringCloudAlibaba和Nacos构建微服务入门实例bash
说明:以查询银行卡信息为业务背景,编写服务提供者服务。架构
@RestController @RequestMapping("bankCard") public class BankCardController { @GetMapping("findCardInfo") public BankCard findCardInfo(String cardNo, HttpServletRequest request) { System.out.println(cardNo); BankCard bankCard = new BankCard().setCardNo("5301001").setName("XC") .setBalance(BigDecimal.valueOf(1000000L)); return bankCard; } }
1.2. 服务启动类app
@EnableDiscoveryClient @SpringBootApplication public class ProviderApplication { public static void main(String[] args) { SpringApplication.run(ProviderApplication.class, args); } }
1.3. 配置文件和其它项目依赖关系分布式
能够直接访问实例源码。ide
@FeignClient(value = "myclouds-nacos-discovery-provider-example") public interface BankCardFeignClient { @GetMapping("bankCard/findCardInfo") BankCard findCardInfo(@RequestParam("cardNo") String cardNo); }
@RestController @RequestMapping("bankcard") public class BankCardConsumerController { @Autowired private BankCardFeignClient bankCardFeignClient; @GetMapping("findCardInfo") public BankCard findCardInfo(String cardNo) { BankCard bankCard = bankCardFeignClient.findCardInfo(cardNo); System.out.println(bankCard); return bankCard; } }
2.3. 消费服务启动类
@SpringBootApplication @EnableDiscoveryClient @EnableFeignClients public class ConsumerApplication { public static void main(String[] args) { SpringApplication.run(ConsumerApplication.class, args); } }
2.4. 配置文件和其它项目依赖关系
3.1 启动nacos。
startup.cmd
nacos控制台:http://127.0.0.1:9999/nacos 帐号/密码:nacos/nacos
3.2 分别启动服务提供者和服务消费者
进入nacos控制台,服务管理->服务列表 菜单便可看到本实例的银行卡查询业务的提供者服务和消费者服务的相关信息。以下图所示。
经过服务消费者访问服务:http://127.0.0.1:19000/bankcard/findCardInfo?cardNo=5301
写在最后
完整实例代码请访问个人myclouds代码仓库。https://gitee.com/osworks/myclouds