微服务和RPC有什么区别?

严格来说微服务属于RPC的一种,但是广义上的RPC指的是项目之间的调用。例如校园网系统中的各个系统就是用RPC调用的,所以RPC指的是项目之间的调用。RPC是把单体项目做了粗粒度的拆分,而微服务把单体项目拆分的更零碎。

因为RPC是独立系统之间的调用,所以不太注重事务的一致性。毕竟独立系统各自使用的数据库也不同,没办法组成全局的分布式事务。而微服务更注重分布式事务,微服务原本是一个系统,拆分出来的各个模块,所以模块之间应该有分布式事务。比如支付模块和代金券模块就应该被纳入到全局事务中。否则我们支付失败,但是代金券却使用成功了。按理说应该一起回滚,是吧。

你可能感兴趣的:(多端全栈代驾项目技术栈,微服务,rpc,java)