#分布式

分布式文件系统之GPFS

   GPFS是IBM公司通过完善和发展其TigerShark文件系统发展而来。GPFS通过共享磁盘结构来实现其强大的扩展性。一个GPFS系统由许多集群节点组成,GPFS文件系统和应用程序在上面运行。这些节点通过交互网络架构(SwitchFabric)网络连接磁盘。所有节点对所有磁盘拥有相...
代码星球 ·2020-10-21

SpringBoot 使用Sharding-JDBC进行分库分表及其分布式ID的生成

为解决关系型数据库面对海量数据由于数据量过大而导致的性能问题时,将数据进行分片是行之有效的解决方案,而将集中于单一节点的数据拆分并分别存储到多个数据库或表,称为分库分表。分库可以有效分散高并发量,分表虽然无法缓解并发量,但仅跨表仍然可以使用数据库原生的ACID事务。而一旦跨库,涉及到事务的问题就会变得无比复杂。1.使用...

分布式数据库设计

DDB设计的两个问题1)分段–分割关系成“段”;逻辑上2)分配–将段置放到站点;物理存储上•目标–优化响应时间/吞吐量/费用/… 分段元则假若有全局关系R被分段为子关系(片段)集合, –完整性,分片之后,不能丢失元素–不相交性,每一个元素只能分配到唯一的一个分段–重构性,存在函数g使得R=g(F1,...
代码星球 ·2020-10-20

分布式存储Seaweedfs源码分析

基于源码版本号0.67,【Seaweedfs以前旧版叫Weedfs】。Seaweedfs 是一个非常优秀的由golang开发的分布式存储开源项目,虽然在我刚开始关注的时候它在github.com上面只有star50+,但是我觉得这个项目是一个几千star量级的优秀开源项目。 Seaweedfs&nb...

redis 分布式锁的 5个坑,真是又大又深

引言最近项目上线的频率颇高,连着几天加班熬夜,身体有点吃不消精神也有些萎靡,无奈业务方催的紧,工期就在眼前只能硬着头皮上了。脑子浑浑噩噩的时候,写的就不能叫代码,可以直接叫做Bug。我就熬夜写了一个bug被骂惨了。由于是做商城业务,要频繁的对商品库存进行扣减,应用是集群部署,为避免并发造成库存超买超卖等问题,采用&nb...

redis分布式锁深度剖析(超时情况)

redis加锁命令:SETNXresource_namemy_random_valuePX30000这个命令的作用是在只有这个key不存在的时候才会设置这个key的值(NX选项的作用),超时时间设为30000毫秒(PX选项的作用)这个key的值设为“my_random_value”。这个值必须在...

python中,用Redis构建分布式锁

在实际应用场景中,我们可能有多个worker,可能在一台机器,也可能分布在不同的机器,但只有一个worker可以同时持有一把锁,这个时候我们就需要用到分布式锁了。这里推荐python的实现库,Redlock-py(Python实现).正常情况下,worker获得锁后,处理自己的任务,完成后自动释放持有的锁,是不是感觉有...
代码星球 ·2020-10-02

RedLock算法-使用redis实现分布式锁服务

在多线程共享临界资源的场景下,分布式锁是一种非常重要的组件。许多库使用不同的方式使用redis实现一个分布式锁管理。其中有一部分简单的实现方式可靠性不足,可以通过一些简单的修改提高其可靠性。这篇文章介绍了一种指导性的redis分布式锁算法RedLock,RedLock比起单实例的实现方式更加安全。在介绍RedLock算...

深入RPC分布式原理

前面几节讲的都是单机RPC服务的模式,无论是多线程也好多进程也好,它们都只能算是单点的设计。现代企业的关键性RPC服务是绝不可以只使用单点部署的。本节我们要对RPC服务进行分布式化,使得服务可以容忍个别节点故障仍能继续对外提供服务。    客户端当RPC服务部署在多个节点上时,客...
代码星球 ·2020-10-02

Redis 4.0.10 文档(分布式锁)

在许多环境中,分布式锁是一种非常有用的原语,其中不同的进程必须以互斥的方式与共享资源一起运行。有许多库和博客文章描述了如何使用Redis实现DLM(分布式锁管理器),但是每个库都使用不同的方法,而且许多库使用的是一种简单的方法,与稍微复杂的设计相比,可以获得较低的保障。此页面试图提供一种更典型的算法来使用Redis实现...
代码星球 ·2020-10-02

python分布式环境下的限流器

项目中用到了限流,受限于一些实现方式上的东西,手撕了一个简单的服务端限流器。服务端限流和客户端限流的区别,简单来说就是:1)服务端限流对接口请求进行限流,限制的是单位时间内请求的数量,目的是通过有损来换取高可用。例如我们的场景是,有一个服务接收请求,处理之后,将数据bulk到Elasticsearch中进行索引存储,b...

分布式链路追踪(Tracing)系统 – Jaeger在Golang中的使用

先从微服务说起目录 [隐藏]微服务Tracing在微服务中的作用为什么是Jaeger安装客户端在单体应用中实现Tracing.通过Grpc中间件使用在业务代码中使用通过Gin中间件中使用结语部署篇使用Elasticsearch作为存储后端相关文章一个完整的微服务体系至少需要包括:CI/CD也就是自动化部署服务...

Redlock:Redis分布式锁最牛逼的实现

说道Redis分布式锁大部分人都会想到:setnx+lua,或者知道setkeyvaluepxmillisecondsnx。后一种方式的核心实现命令如下:-获取锁(unique_value可以是UUID等)SETresource_nameunique_valueNXPX30000-释放锁(lua脚本中,一定要比较val...

consul实现分布式锁

分布式的CAP理论告诉我们“任何一个分布式系统都无法同时满足一致性(Consistency)、可用性(Availability)和分区容错性(Partitiontolerance),最多只能同时满足两项。”所以,很多系统在设计之初就要对这三者做出取舍。在互联网领域的绝大多数的场景中,都需要牺牲强...
代码星球 ·2020-09-24

分布式唯一ID生成常用方案

1.使用JAVA的UUID生成算法的核心思想是结合机器的网卡、当地时间、一个随记数来生成UUID。优点:本地生成,生成简单,性能好,没有高可用风险缺点:长度过长,字母和数字组合,存储冗余,且无序不可读,查询效率低2.数据库自增ID使用数据库的id自增策略,如MySQL的auto_increment、oracle的seq...
首页上一页...1011121314...下一页尾页