- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章SpringCloud 微服务最佳开发实践由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
现在基于SpringCloud的微服务开发日益流行,网上各种开源项目层出不穷。我们在实际工作中可以参考开源项目实现很多开箱即用的功能,但是必须要遵守一定的约定和规范.
本文结合我们实际的开发中遇到的一些问题整理出了一份微服务开发的实践规范,欢迎各位大佬拍砖指点.
1.所有项目必须要有一个统一的parent模块 。
所有微服务工程都依赖这个parent,parent用于管理依赖版本,maven仓库,jar版本的统一升级维护 。
在parent下层可以有 core,starter,rate-limit 等自定义模块 。
2.core 核心包的作用:
注意:core包所有依赖的scope必须是provided,避免传递依赖,同时配合Condition注解按条件加载Bean 如 @ConditionalOnClass(Ribbon.class),@ConditionalOnBean(StringRedisTemplete.class) 。
3.starter模块 。
如果你每个服务都需要依赖10几个starter,可以建一个统一的starter模块帮他们统一依赖进来,管理依赖集,简化依赖 。
4.rate-limit模块 。
用于放置非通用的自开发组件 。
5.正确区分Release版本 和 Snapshot版本 。
说明:如果是Snapshot版本,那么在mvn deploy时会自动发布到快照版本库中,而使用快照版本的模块,在不更改版本号的情况下,直接编译打包时,Maven会自动从镜像服务器上下载最新的快照版本.
如果是Release版本,那么在mvn deploy时会自动发布到正式版本库中,而使用正式版本的模块,在不更改版本号的情况下,编译打包时如果本地已经存在该版本的模块则不会主动去镜像服务器上下载.
简而言之:
Release : 正式版,有bug不能再继续使用这个版本号 。
Snapshot:快照版,有bug可以继续使用同一版本号,可以自动升级,推荐使用 。
规范服务间通过引入sdk调用,服务消费者需要依赖生产者提供的api,配合snapshot方便升级 。
1
2
3
|
account
account-api
account-service
|
account-api 模块中放消费方需要用到的东西,api接口,vo,入参等... 。
1
2
3
|
public
interface
AccountApi {
...
}
|
account-service实现account-api提供的接口 。
1
2
3
4
5
6
7
|
@RestController
@Log4j2
@Api
(tags =
"用户接口"
)
@RequiredArgsConstructor
(onConstructor =
@__
(
@Autowired
))
public
class
AccountController
implements
AccountApi {
...
}
|
消费者通过feign调用生产者,直接集成生产者提供的接口并处理熔断 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
@Component
@FeignClient
(name =
"account-service"
,fallbackFactory = AccountClientFallbackFactory.
class
)
public
interface
AccountClient
extends
AccountApi {
...
}
@Component
public
class
AccountClientFallbackFactory
implements
FallbackFactory<AccountClient> {
@Override
public
AccountClient create(Throwable throwable) {
AccountClientFallback accountClientFallback =
new
AccountClientFallback();
accountClientFallback.setCause(throwable);
return
accountClientFallback;
}
}
@Slf4j
public
class
AccountClientFallback
implements
AccountClient {
@Setter
private
Throwable cause;
@Override
public
ResultData<AccountDTO> getByCode(String accountCode) {
log.error(
"查询失败,接口异常"
,cause);
AccountDTO account =
new
AccountDTO();
account.setAccountCode(
"000"
);
account.setAccountName(
"测试Feign"
);
return
ResultData.success(account);
}
}
|
一个 API 是一个开发者的 UI - 就像其他任何 UI 一样, 确保用户体验被认真的考虑过是很重要的! 。
可以使用以下两种格式:
域对象需要遵循以下几条约束:
在网关层对接口进行访问控制,访问控制的规则分为:
pb - public 所有请求均可访问 。
pt - protected 需要进行token认证通过后方可访问 。
pv - private 无法通过网关访问,只能微服务内部调用 。
df - default 网关请求token认证,并且请求参数和返回结果进行加解密 。
版本:
以微服务为力度,整个服务进行升级 。
例如,一个微服务有如下API 。
GET /v1/pb/user 。
POST /v1/pb/user 。
PUT /v1/pb/user 。
如果 POST /v1/pb/user 需要升级,则需要将整个微服务 /v1 升级到 /v2,同时保证版本兼容的api老版本可以继续访问 。
GET /v2/pb/user 等价于 GET /v1/pb/user 。
POST /v1/pb/user 标记为已废弃 。
POST /v2/pb/user 。
PUT /v2/pb/user 等价于 PUT /v1/pb/user 。
代码实现:
1.GET方式{version}可以是任意值,v1,v2均可,如:@GetMapping("/{version}/pb/user") 。
2.POST方法强制使用 V1 ,并标记为已废弃,但是仍可使用 。
1
2
|
@Deprecated
@PostMapping(
"/v1/pb/user"
)
|
3.POST {version}应是当前版本,只能是v2 。
1
|
@PostMapping(
"/{version}/pb/user"
)
|
/pv/**
等特殊请求开发联调的时候需要将服务器流量导入到本地,结合nacos的元数据与请求头可实现服务实例的筛选。参考此文实现:http://t.hk.uy/2c6 。
到此这篇关于SpringCloud 微服务最佳开发实践的文章就介绍到这了,更多相关SpringCloud 微服务内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://www.cnblogs.com/jianzh5/p/14985985.html 。
最后此篇关于SpringCloud 微服务最佳开发实践的文章就讲到这里了,如果你想了解更多关于SpringCloud 微服务最佳开发实践的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我们正在创建一个 n 层 Silverlight LOB 应用程序,并且正在考虑使用 .NET RIA 服务。我们不清楚这与我们当前的 WCF 服务 API 的关系在哪里。我们当前的架构是: 银光
上下文:我在celery + rabbitmq堆栈上有一个主工作系统。 系统已docker化(此处未提供worker服务) version: '2' services: rabbit:
我是 Windows Azure 新手,我正在尝试将我的 Web 应用程序部署到 Windows Azure。在我的应用程序中,我使用了一些 Web 服务,现在我想知道如何在 Windows Azur
因此,根据我对服务的了解,自定义对象似乎是写入服务以返回数据的方式。如果我正在编写将用于 1) 填充数据库或 2) 为网站提供信息的服务,是否有返回数据集/数据表而不是包含所有这些的自定义对象列表的用
我在 google 和 stackoverflow 上都找过答案,但似乎找不到。我正在尝试将 azure 实验的输出获取到应用程序。我使用 ibuildapp 和谷歌表单制作了该应用程序。如何使用 g
我不小心删除了 kubernetes svc: service "kubernetes" deleted 使用: kubectl delete svc --all 我该怎么办?我只是想删除服务,以便
我正在努力确定解决网络服务问题的最有效方法。 我的情况:我正在开发一个 Android 应用程序,它通过 Web 服务从 mysql 数据库(在我自己的服务器 PC 上)存储和检索数据。用户按下提交按
我一直在翻阅 Android 文档,我很好奇。什么时候绑定(bind)服务而不是不绑定(bind)服务?它提供了哪些优点/限制? 最佳答案 When would you bind a service
我试图从架构的角度理解 hive,我指的是 Tom White 关于 Hadoop 的书。 我遇到了以下关于配置单元的术语:Hive Services、hiveserver2、metastore 等。
我的问题:安装服务后我无法导航到基地址,因为服务不会继续运行(立即停止)。我需要在服务器或我的机器上做些什么才能使 baseAddress 有效吗? 背景:我正在尝试学习如何使用 Windows 服务
我正在努力就 Web 服务的正确组织做出决定。我应该有多个 ASMX 来代表 Web 服务中的不同功能,还是应该有一个 ASMX? 如果我有多个 ASMX,这不构成多个 Web 服务吗? 如果我只有一
我正在从事一个在 azure 平台上提供休息服务的项目。该服务由 iPhone 客户端使用,这是选择其余方法的重要原因之一。 我们希望通过 AccessControlService(ACS) 并使用
我是 Ionic 新手,正在使用 Ionic 3.9.2 我有几个终端命令来为我的 ionic 应用程序提供服务,但是,我没有发现这两个命令之间有任何区别。 ionic serve 和 ionic s
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 8 年前。 Improve this ques
作为项目的一部分,我期待着问这个问题。我过去有开发和使用 Web 服务的经验,并且非常熟悉这些服务。但是,有人告诉我,作为下一个项目的一部分,我将需要使用“安全”的 Web 服务。您能否提供一些见解,
我浏览了很多关于这个问题的信息,但找不到解决方案。这里的问题是,我想使用 Apache Cordova 和 Visual Studio 连接到 wcf。因此,如果有人找到合适的工作解决方案,请发布链接
我在 Windows 服务中托管了一个 WCF(从 MS 网站示例中选取),我可以使用 SOAP UI 访问和调用方法。但是,当我尝试使用 jquery 从 Web 应用程序调用相同的方法时,我不断收
我们构建了一个 Android 应用程序,它从 Android 向我的 PHP 服务器发送 HTTP 请求。作为响应,Web 服务将 JSON 对象发送到 Android 应用程序以显示结果。 就像其
我想在 android 应用程序中调用 soap web 服务,它需要一个枚举值作为参数,它是一个标志枚举。如何从 Android 应用程序将一些值作为标志枚举传递给此 Web 服务方法? 我使用 K
我尝试在模拟器上安装 Google Play。我已按照 Google Dev Site 中的说明进行操作. 使用 ADV 管理器似乎没问题,设备的目标是 Google API 版本 22,但是当我运行
我是一名优秀的程序员,十分优秀!