热门标签 | HotTags
当前位置:  开发笔记 > 后端 > 正文

Seafile深入理解(一).如何理解异地分布式部署

把复杂的问题简单化,是大师的水平,是对技术的真正理解,所谓简单是能切中要害,深入浅出地表达,所以提炼产品的技术亮点,是与客户交流的基础功课。但并非高深的技术一定是复杂的,任何产品都有它“独特”的

把复杂的问题简单化,是大师的水平,是对技术的真正理解,所谓简单是能切中要害,深入浅出地表达,所以提炼产品的技术亮点,是与客户交流的基础功课。但并非高深的技术一定是复杂的,任何产品都有它“独特”的技术,关键是你条理地表达。我们常常遇到这样的情况,我们销售的产品使用起来非常“傻瓜”,好象没有什么可说的,客户认为太简单而没有技术含量,没有技术,靠什么竞争,比价格是很残酷的。     

核心的理解就是:每个地点的Seafile集群只需要和本地的数据库节点、对象存储节点通信就可以了,但是不同地点之间的数据是可以通过mariaDB集群和对象存储的自动数据同步来实现。



  Seafile通过异地的分布式部署,为中国、美国两地的用户提供网盘服务,同时保证两地用户访问到的数据是一致的。由于Seafile的数据存储在数据库和对象存储中,所以我们需要保证两地数据库和对象存储数据的一致性。

      如下图所示,数据库数据的一致性是通过MariaDB集群的方式来实现的,MariaDB集群是一个多主的数据库同步方案,数据的读写可以在任意一个数据库节点上进行,其它节点会自动对数据读写进行同步,以保证所有节点上数据的一致性。MariaDB集群至少需要三个数据库节点,下图中按照最小的三节点来部署,可以在中国部署两个数据库节点,在美国部署一个数据库节点。

      对象存储数据的一致性,通过Xsky内部技术来实现Xsky对象存储节点间数据的自动同步。

      除了保证两地数据的一致性,我们还需要在两地分别部署Seafile服务器集群对两地的用户提供Seafile网盘服务。两地的Seafile集群仅需要分别与本地的MariaDB节点和Xsky对象存储节点通信即可。


                                                

                 



推荐阅读
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 关于我们EMQ是一家全球领先的开源物联网基础设施软件供应商,服务新产业周期的IoT&5G、边缘计算与云计算市场,交付全球领先的开源物联网消息服务器和流处理数据 ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • Centos下安装memcached+memcached教程
    本文介绍了在Centos下安装memcached和使用memcached的教程,详细解释了memcached的工作原理,包括缓存数据和对象、减少数据库读取次数、提高网站速度等。同时,还对memcached的快速和高效率进行了解释,与传统的文件型数据库相比,memcached作为一个内存型数据库,具有更高的读取速度。 ... [详细]
  • 云原生应用最佳开发实践之十二原则(12factor)
    目录简介一、基准代码二、依赖三、配置四、后端配置五、构建、发布、运行六、进程七、端口绑定八、并发九、易处理十、开发与线上环境等价十一、日志十二、进程管理当 ... [详细]
  • 新注册腾讯云最长可免费使用CVM服务器半年
    腾讯旗下的云计算业务目前开始推出面向新用户的免费套餐活动,最长每位用户可免费使用CVM服务器半 ... [详细]
  • shell脚本实战 pdf_Shell 脚本操作数据库实战
    安装mariadb数据库(默认没有密码,直接mysql即可进入数据库管理控制台)yuminstallmariadbmariadb-serv ... [详细]
  • 数据库进入全新时代,腾讯云发布五大数据库提前布局
    8月28日,腾讯云数据库在京正式启动战略升级,宣布未来将聚焦云原生、自治、超融合三大战略方向,以用户为中心,联接未来。并在现场面向全球用户同步发布五大战略级新品,包括数据库智能管家 ... [详细]
  • MYsql_linux mysql
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了linuxmysql相关的知识,希望对你有一定的参考价值。一数据库安装查看:[[email pr ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
  • 本文介绍了如何使用php限制数据库插入的条数并显示每次插入数据库之间的数据数目,以及避免重复提交的方法。同时还介绍了如何限制某一个数据库用户的并发连接数,以及设置数据库的连接数和连接超时时间的方法。最后提供了一些关于浏览器在线用户数和数据库连接数量比例的参考值。 ... [详细]
  • 本文介绍了在Hibernate配置lazy=false时无法加载数据的问题,通过采用OpenSessionInView模式和修改数据库服务器版本解决了该问题。详细描述了问题的出现和解决过程,包括运行环境和数据库的配置信息。 ... [详细]
  • [译]技术公司十年经验的职场生涯回顾
    本文是一位在技术公司工作十年的职场人士对自己职业生涯的总结回顾。她的职业规划与众不同,令人深思又有趣。其中涉及到的内容有机器学习、创新创业以及引用了女性主义者在TED演讲中的部分讲义。文章表达了对职业生涯的愿望和希望,认为人类有能力不断改善自己。 ... [详细]
  • 本文介绍了高校天文共享平台的开发过程中的思考和规划。该平台旨在为高校学生提供天象预报、科普知识、观测活动、图片分享等功能。文章分析了项目的技术栈选择、网站前端布局、业务流程、数据库结构等方面,并总结了项目存在的问题,如前后端未分离、代码混乱等。作者表示希望通过记录和规划,能够理清思路,进一步完善该平台。 ... [详细]
  • mysql数据库生成表插件_screw 数据库文档生成工具
    简洁好用的数据库表结构文档工具在企业级开发中、我们经常会有编写数据库表结构文档的时间付出,从业以来,待过几家企业,关于数据库表结构文档状态:要么没有、要么有、但都是手写 ... [详细]
author-avatar
小志19841126_466
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有