写点什么

Atlassian 的 Stash 数据中心为 Git 提供了高可用性及可伸缩性

  • 2015-04-19
  • 本文字数:2579 字

    阅读完需:约 8 分钟

Atlassian最近发布了Stash 数据中心,这是一个具有高可用性以及横向扩展能力的部署选择,用于本地源代码与Git 库管理解决方案 Stash 。这套系统能够在不产生停机时间的情况下直接添加新节点,以实现双主机方式(active/active)的集群以及即时的可伸缩性。

在 Stash 推出数据中心之前,JIRA 与 Confluence 的数据中心版本已经先行问世,数据中心版本服务是为企业级使用场景设计的,这些场景要求“高可用性,以及大规模使用情况下的良好性能”。这些服务提供了与单机版产品相同的终端用户特性,它们使用了非常类似的集群技术,以实现处理大量并发用户、实现应用程序弹性以及提高服务质量的优点。这些服务的许可方式是基于用户的数量,而不是服务器或CPU 的数量,这样就使得客户能够选择自定义的、灵活的基础设施,并且也易于估算成本。

Stash 服务器已经在“全球超过 1 万 3 千个组织中得到使用”,它包含了许多面向企业环境的特性,例如:

Stash 服务器已经为企业级的应用高可用性可伸缩性提供了详细的指南。而通过使用 Stash 数据中心集群,可以实现更高的能力。

InfoQ 有幸采访了 Atlassian 开发者工具部门的总经理 Eric Wittman ,谈及了 Atlassian 最新推出的数据中心服务。

InfoQ**:Stach服务器已经为一个单服务器上的数千个用户提供了横向扩展的能力,这些服务器已经用于各种小型与大型公司了。那么,在 Stash数据中心中进一步提升可伸缩性的主要动力是什么呢?**

Wittman:虽然你可以为大量的用户选择纵向扩展的方式,但纵向扩展受限于物理服务器的数量,而我们想避免这一点,为用户提供横向扩展的能力。一方面,我们的目的是让客户能够将扩展能力提高到 1 万个用户以上,而我们通过 Stash 数据中心提供更高的可伸缩性的另一个主要动力,是因为在各大组织不断推进它们的持续集成实践的情况下,在高峰期间,构建服务器对他们的 SCM 系统会产生极大的压力,新的数据中心将能够应对这种压力。

InfoQ**:在 Stash数据中心的文档中表示,它能够以近乎线性的方式横向扩展到至少 4个以上的节点,而由于服务价格是按照用户数量进行计算的,因此你鼓励客户“想要几个节点就加几个节点”。那么对于支持的用户数量是否存在上限呢?**

Wittman:我们对于 Stash 数据中心所支持的用户数量并没有设定上限。我们在测试中最多使用了 4 个节点,通过对它的可伸缩性进行衡量,我们就能得出一个集群能够处理的整体吞吐量。能够支持的用户数量不仅取决于节点的数量,也取决于来自于其它自动化系统的压力,例如持续集成。

InfoQ**:对 Git进行大规模化是一种很严峻的技术挑战。你是否能简单地提一下你们是如何实现这一点的,比例你们是否对 Git的默认行为进行了一些改变?**

Wittman:我们在多台机器上进行了横向扩展、添加了更多的 CPU 和内存,并且使用了本地磁盘缓存,这些都有助于缓解资源的占用,尤其是 Git 托管操作。此外,我们在集群节点上使用了额外的快速本地磁盘,这也为我们的 SCM 缓存带来了好处。除此这外,我们对 Git 本身并没有进行任何改变。

  • 在 Atlassian Summit 2014 大会上,Atlassian Stash 架构师 Stefan Saasen 进行了一场名为“大规模化 Git ”的演讲,对底层的 Git 概念、所面对的挑战和迁移进行了深入的探讨。

InfoQ**:Stash通常会与 Atlassian的其它工具共同使用,例如 JIRA和 Bamboo,这样可以更好地集成工作流。你们的客户当中是否有人仅仅单独使用 Stash**呢?

Wittman**:我们确实有些客户仅仅使用 Stash工具,并且从 Stash的细粒度权限控制中受益良多,但多数 Stash的客户不仅使用了 Stash中细粒度的代码访问控制能力,同时也与 JIRA和 Bamboo的工作流集成使用。**

InfoQ**:你的同事 Tim Pettersen 近期详细地说明了由 Stash与 Bitbucket所带来的“更好的 pull request 模型”,但要实现这个更复杂的算法,也需要额外的资源。你能否为我们总结一下为什么你们倾向于这种途径吗?**

Wittman:Stash 和 Bitbucket 中的 pull request 算法比起其它 Git 解决方案中的算法,具有两点主要的优势:

  1. 可以在 pull request 中显示出合并冲突,如果开发者的代码产生冲突,他们就可以共同讨论如何解决这个冲突。
  2. 审查者能够看到某个特性分支上的变更对 master 分支会产生怎样的影响,这样就能够对最终在产品中发布的代码有一个更好的认识,从而减少了最终会发布到客户手上的产品的缺陷数量。

InfoQ**:Atlassian已经在 Docker 上发布了 Stash ,目前还只用于评估的目的。这一系统是否也支持集群化的部署方式,你是否认为这一系统今后能够成为你们的产品部署选项中的一种?**

Wittman:Docker 部署方式目前还不支持集群化的部署,因为主要的目的是让开发者进行评估。我们将对使用 Docker 映像作为今后产品的一种部署选项进行评估,而这取决于 Docker 作为一个平台的成熟度,以及客户在这方面的需求。

Stash 3.8最近刚刚发布,进一步改善了一些操作的功能,引入了完全无头的(headless)上线过程,并且使用了JMX 性能计数器,可用于衡量“项目与库的数量、Git 的push 与pull 操作的数量,以及各种线程池方面的指标”。

Stash 数据中心的文档提供了更多的细节,包括与故障转移性能可伸缩性有关的章节以及一篇 FAQ 。Stash用户文档同样加入了更多细节内容,而开发者文档中则涵盖了通过插件或远程 REST API 对Stash 进行扩展的途径。在 Atlassian 支持门户中提供了常规的 Stash 支持资源,同样也提供了专门的企业服务与支持项目

查看英文原文: Atlassian’s Stash Data Center Offers High Availability and Scalability for Git

2015-04-19 07:452337
用户头像

发布了 428 篇内容, 共 178.2 次阅读, 收获喜欢 38 次。

关注

评论

发布
暂无评论
发现更多内容

JavaScript 基础(一):语法和程序结构

devpoint

JavaScript 函数 数据类型 3月月更

“养老”变“享老”,老龄人口高峰与养老产业爆发催生金融需求

易观分析

养老服务 养老金融

昆仑分布式数据库架构介绍

KunlunBase昆仑数据库

数据库 分布式数据库

昆仑分布式数据库技术特点

KunlunBase昆仑数据库

分布式数据库 国产数据库

10分钟快速玩转kunlun cluster

KunlunBase昆仑数据库

分布式数据库

昆仑分布式数据库Sequence功能及其实现机制

KunlunBase昆仑数据库

分布式数据库

Promise静态四兄弟,你学会了吗?

战场小包

JavaScript 前端 Promise 3月月更

云管理平台有哪些?建议选择哪家?

行云管家

云计算 多云 云管理

第九周作业

lv

企业IM首选移动数字化平台WorkPlus

WorkPlus

天翼云与龙芯完成产品兼容适配加速国产化云平台发展

天翼云开发者社区

海外主机是什么意思?与国内主机有什么区别?

行云管家

服务器 主机 服务器运维 海外 主机运维

史上最通俗,彻底搞懂字符乱码问题的本质

WorkPlus

昆仑分布式数据库技术优势

KunlunBase昆仑数据库

分布式数据库 国产数据库

经典的两阶段提交算法原理及缺陷

KunlunBase昆仑数据库

分布式数据库

广电行业如何上云?来抄作业!

天翼云开发者社区

分布式事务对于两阶段提交的错误处理

KunlunBase昆仑数据库

分布式数据库

主流移动端账号登录方式的原理及设计思路

WorkPlus

穿透、击穿、雪崩…Redis这么多问题,如何解决?

华为云开发者联盟

redis 缓存 缓存穿透 缓存击穿 缓存雪崩

云图说丨初识数据工坊DWR

华为云开发者联盟

大数据 数据处理 算子 数据工坊 工作流编排

CRM系统改善业务的方法

低代码小观

CRM 客户关系管理 企业管理系统 CRM系统 企业管理工具

天翼云TeleDB数据库为实现自主可控全面亮剑

天翼云开发者社区

31 家企业入选阿里云首期云原生加速器,共建云原生行业新生态

阿里巴巴中间件

云计算 阿里云 云原生 加速器 生态伙伴

墨天轮国产数据库沙龙 | 胡津铭:时序数据库DolphinDB,从量化金融到万物互联

墨天轮

数据库 时序数据库 DolphinDB 国产数据库

响应速度提升80%以上,甘肃省医保信息平台稳固上线有法宝

华为云开发者联盟

数据库 华为云 华为云数据库 智慧医疗 医保

应用环境能力 | 阿里巴巴DevOps实践指南

阿里云云效

阿里巴巴 阿里云 研发效能 开发

Linux下C++后台服务器开发

Linux服务器开发

C/C++ 后端开发 Linux服务器开发 C++后台开发 Linux后台开发

【51单片机】独立按键控制LED灯(四种形式)

謓泽

3月月更

C++ 内存管理中内存泄漏问题产生原因以及解决方法

Linux服务器开发

C/C++ 内存管理 内存泄漏 Linux服务器开发 Linux后台开发

为什么要选择昆仑分布式数据库?

KunlunBase昆仑数据库

国产数据库

无所不云,开启你的美好旅行新体验!

天翼云开发者社区

Atlassian的Stash数据中心为Git提供了高可用性及可伸缩性_安全_Steffen Opel_InfoQ精选文章