SpringCloud-Alibaba 之 Nacos
并且 Nacos 与目前主流的开源生态都提供了很好的支持:
1、Nacos 是专为 Dubbo 而生的注册中心与配置中心
2、Nacos 会完全兼容 Spring Cloud
3、Nacos 支持 Service Mesh 集成,Kubernetes 集成
除此之外,阿里巴巴正在通过 Dubbo + Nacos 以及一系列开源项目打造服务发现、服务及流量管理、服务共享平台,未来还在不断地发展和演进,相信未来会有更多的地方上使用 Nacos。
单机部署
准备环境
Nacos 依赖 Java 环境来运行,所以部署前需要保证环境要求:
1、64 bit OS,支持 Linux/Unix/Mac/Windows,推荐选用 Linux/Unix。
2、64 bit JDK 1.8+
去 github 上搜索 nacos,发现 releases 发布版本
data:image/s3,"s3://crabby-images/cd1aa/cd1aafd3f20485c70bb08b4447780b6e1962a268" alt=""
解压运行
data:image/s3,"s3://crabby-images/7f07f/7f07f831d92a5ea31c9d2231f8c77ddd8a582b64" alt=""
这里 Nacos 单机部署方式使用命令?-m standalone?,如果是 Windows 命令,可以直接双击?startup.cmd?文件即可。
浏览器访问 http://{ip}:8848/nacos/index.html,点击就进入了 Nacos 的可视化管理界面,需要账号密码登录访问,默认都为****nacosdata:image/s3,"s3://crabby-images/f6d98/f6d98e87e0018d41f23f0562a8b5c86bbfab5317" alt=""
登录之后就能在网站侧边栏上看到 Nacos 的主要功能菜单:配置管理,服务管理,集群管理,命名空间。
data:image/s3,"s3://crabby-images/d1795/d1795b343ffb65c40a6b0f625b1c28d6976038cf" alt=""
服务提供者
通过一个简单的示例来感受一下如何将服务注册到 Nacos,其实和 Eureka 没有太大差别
POM
创建一个工程名为 shop-goods-service 的服务提供者项目,pom.xml 配置如下:
注:因为我们使用 Dubbo 的 RPC,所以也引用了 Dubbo;这个以后会讲
data:image/s3,"s3://crabby-images/5024f/5024f869b05d53e87a1592071e163c006a3b1d21" alt=""
data:image/s3,"s3://crabby-images/b9f21/b9f210ee2c45408c4f690e5173e16178080ff802" alt=""
Application
通过**@EnableDiscoveryClient 注解表明是一个 Nacos 客户端,该注解是 Spring Cloud 提供的原生注解**
data:image/s3,"s3://crabby-images/7209c/7209cb06cc42d768c61cb00529a8f6176f9ae8c3" alt=""
定义接口实现
data:image/s3,"s3://crabby-images/7efb3/7efb3429c297cdb957e40704b3808d7007d353fe" alt=""
data:image/s3,"s3://crabby-images/128dc/128dc08103d817e08309d038ac18d93673d88793" alt=""
data:image/s3,"s3://crabby-images/0bdcd/0bdcdc365ba23a5589b8c0b456f11f4e252b2271" alt=""
注意:GoodsServiceImpl 的接口实现类上面有 @Service 注解,是 org.apache.dubbo.config.annotation.Service
application.yml
data:image/s3,"s3://crabby-images/605c1/605c1dbcffb0d6d7e0641784e65f8880e7c3529b" alt=""
启动工程
通过浏览器访问?http://192.168.5.153:8848/nacos,即 Nacos Server 网址
data:image/s3,"s3://crabby-images/ae538/ae538cb6b962877c40930d36ad665c8f6c60c5ef" alt=""
你会发现一个服务已经注册在服务中了,服务名为 goods-provider。这个过程其实蛮简单的,跟之前 dubbo 的使用没什么不一样。
当然这个是服务提供者,要想看到效果,我们再来新建服务消费者
服务消费者
POM
这个 POM 文件和提供者很类似,因为消费者我们将用 web 演示,所以增加个依赖包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
Application
data:image/s3,"s3://crabby-images/bffd6/bffd609345a1b48090bcf6fa1ef8374a1a1abbef" alt=""
application.yml
data:image/s3,"s3://crabby-images/bccc4/bccc49291a9408c3d42a39962a188602e1f4a1d3" alt=""
注意:服务提供者和消费者,yml 配置中,在 2.1.x 后需要增加
spring.main.allow-bean-definition-overriding: true
服务消费
新建一个 Controller,请求某个商品 id 的基本信息。
data:image/s3,"s3://crabby-images/3af47/3af47e217bd86c13b26f3308e94915ec0cf0d95e" alt=""
注意:@Reference 这个注解是 org.apache.dubbo.config.annotation.Reference
评论