微服务[6]
服务容错
原文地址:https://icyfenix.cn/distribution/traffic-management/failure.html Martin Fowler 与 James Lewis 提出的“微服务的九个核心特征”是构建微服务系统的指导性原则,但不是技术规范,并没有严格的约束力。在实际构
微服务部署策略
前言 部署单体式应用涉及在多个服务器上运行其副本,通常包括数个(N)物理或虚拟服务器,每个服务器上运行着若干(M)应用实例。尽管部署过程不像微服务应用那样直观,但与微服务相比,单体式应用的部署相对简单。 微服务应用则是由众多服务组成,每个服务可独立开发,使用不同的编程语言和框架。每个服务都是独立的应
微服务的事件驱动数据管理
1 微服务和分布式数据管理问题 微服务架构和分布式数据管理确实带来了一系列新的挑战,尤其是在维持数据一致性和处理跨服务交易方面。在单体应用中,关系型数据库提供的ACID事务特性确保了数据的一致性和完整性,但在微服务架构中,数据通常被分散到各个服务的私有数据库中,这就需要我们重新思考数据管理和一致性的
漫谈单体应用迁移到微服务架构
迁移单体式应用到微服务架构意味着经历一系列复杂的现代化过程,这与历代开发者持续追求技术革新的努力颇为相似。在进行迁移时,我们确实可以汲取过去的智慧并重用一些成熟的想法。 其中一个关键的策略是避免采取大规模重写代码的方式,即所谓的“大爆炸式”重写。这种方法仅在决定彻底颠覆现有系统,构建一套全新的基于微
【面试题120】你能说清楚分布式锁,进程锁,线程锁的区别吗?
在分布式集群系统的开发中,线程锁往往并不能支持全部场景的使用,必须引入新的技术方案分布式锁。 线程锁,进程锁,分布式锁 线程锁:大家都不陌生,主要用来给方法、代码块加锁。当某个方法或者代码块使用锁时,那么在同一时刻至多仅有有一个线程在执行该段代码。当有多个线程访问同一对象的加锁方法/代码块时,同一时
【面试题114】谈谈微服务的数据库设计思路吧
单独的数据库 微服务设计的一个关键是数据库设计,基本原则是每个服务都有自己单独的数据库,而且只有微服务本身可以访问这个数据库。它是基于下面三个原因。 优化服务接口:微服务之间的接口越小越好,最好只有服务调用接口(RPC或消息),没有其他接口。如果微服务不能独享自己的数据库,那么数据库也变成了接口的一