`
luckaway
  • 浏览: 138022 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

发表日:2008/7/23 作者:长野雅广(Masahiro Nagano) 原文链接:http:/

阅读更多
发表日:2008/7/30
作者:长野雅广(Masahiro Nagano)
原文链接:http://gihyo.jp/dev/feature/01/memcached/0005

前几次的文章在这里:

    * 第1次:http://tech.idv2.com/2008/07/10/memcached-001/
    * 第2次:http://tech.idv2.com/2008/07/11/memcached-002/
    * 第3次:http://tech.idv2.com/2008/07/16/memcached-003/
    * 第4次:http://tech.idv2.com/2008/07/24/memcached-004/

我是Mixi的长野。memcached的连载终于要结束了。到上次为止,我们介绍了与memcached直接相关的话题,本次介绍一些mixi的案例和实际应用上的话题,并介绍一些与memcached兼容的程序。

    * mixi案例研究
          o 服务器配置和数量
          o memcached进程
          o memcached使用方法和客户端
                + 通过Cache::Memcached::Fast维持连接
                + 公共数据的处理和rehash
    * memcached应用经验
          o 通过daemontools启动
          o 监视
          o memcached的性能
    * 兼容应用程序
          o Tokyo Tyrant案例
    * 总结

mixi案例研究

mixi在提供服务的初期阶段就使用了memcached。随着网站访问量的急剧增加,单纯为数据库添加slave已无法满足需要,因此引入了memcached。此外,我们也从增加可扩展性的方面进行了验证,证明了memcached的速度和稳定性都能满足需要。现在,memcached已成为mixi服务中非常重要的组成部分。
memcached-0005-01.png

图1 现在的系统组件
服务器配置和数量

mixi使用了许许多多服务器,如数据库服务器、应用服务器、图片服务器、反向代理服务器等。单单memcached就有将近200台服务器在运行。 memcached服务器的典型配置如下:

    * CPU:Intel Pentium 4 2.8GHz
    * 内存:4GB
    * 硬盘:146GB SCSI
    * 操作系统:Linux(x86_64)

这些服务器以前曾用于数据库服务器等。随着CPU性能提升、内存价格下降,我们积极地将数据库服务器、应用服务器等换成了性能更强大、内存更多的服务器。这样,可以抑制mixi整体使用的服务器数量的急剧增加,降低管理成本。由于memcached服务器几乎不占用CPU,就将换下来的服务器用作memcached服务器了。
memcached进程

每台memcached服务器仅启动一个memcached进程。分配给memcached的内存为3GB,启动参数如下:

/usr/bin/memcached -p 11211 -u nobody -m 3000 -c 30720

由于使用了x86_64的操作系统,因此能分配2GB以上的内存。32位操作系统中,每个进程最多只能使用2GB内存。也曾经考虑过启动多个分配2GB以下内存的进程,但这样一台服务器上的TCP连接数就会成倍增加,管理上也变得复杂,所以mixi就统一使用了64位操作系统。

另外,虽然服务器的内存为4GB,却仅分配了3GB,是因为内存分配量超过这个值,就有可能导致内存交换(swap)。连载的第2次中前坂讲解过了memcached的内存存储“slab allocator”,当时说过,memcached启动时指定的内存分配量是memcached用于保存数据的量,没有包括“slab allocator”本身占用的内存、以及为了保存数据而设置的管理空间。因此,memcached进程的实际内存分配量要比指定的容量要大,这一点应当注意。

mixi保存在memcached中的数据大部分都比较小。这样,进程的大小要比指定的容量大很多。因此,我们反复改变内存分配量进行验证,确认了3GB的大小不会引发swap,这就是现在应用的数值。
memcached使用方法和客户端

现在,mixi的服务将200台左右的memcached服务器作为一个pool使用。每台服务器的容量为3GB,那么全体就有了将近600GB的巨大的内存数据库。客户端程序库使用了本连载中多次提到车的Cache::Memcached::Fast,与服务器进行交互。当然,缓存的分布式算法使用的是 第4次介绍过的 Consistent Hashing算法。

    * Cache::Memcached::Fast - search.cpan.org

应用层上memcached的使用方法由开发应用程序的工程师自行决定并实现。但是,为了防止车轮再造、防止Cache::Memcached::Fast上的教训再次发生,我们提供了Cache::Memcached::Fast的wrap模块并使用。
通过Cache::Memcached::Fast维持连接

Cache::Memcached的情况下,与memcached的连接(文件句柄)保存在Cache::Memcached包内的类变量中。在mod_perl和FastCGI等环境下,包内的变量不会像CGI那样随时重新启动,而是在进程中一直保持。其结果就是不会断开与memcached的连接,减少了TCP连接建立时的开销,同时也能防止短时间内反复进行TCP连接、断开而导致的TCP端口资源枯竭。

但是,Cache::Memcached::Fast没有这个功能,所以需要在模块之外将Cache::Memcached::Fast对象保持在类变量中,以保证持久连接。

package Gihyo::Memcached;

use strict;
use warnings;
use Cache::Memcached::Fast;

my @server_list = qw/192.168.1.1:11211 192.168.1.1:11211/;
my $fast;  ## 用于保持对象

sub new {
    my $self  = bless {}, shift;
    if ( !$fast ) {
        $fast = Cache::Memcached::Fast->new({ servers => \@server_list });
    }
    $self->{_fast} = $fast;
    return $self;
}

sub get {
   my $self = shift;
   $self->{_fast}->get(@_);
}

上面的例子中,Cache::Memcached::Fast对象保存到类变量$fast中。
公共数据的处理和rehash

诸如mixi的主页上的新闻这样的所有用户共享的缓存数据、设置信息等数据,会占用许多页,访问次数也非常多。在这种条件下,访问很容易集中到某台memcached服务器上。访问集中本身并不是问题,但是一旦访问集中的那台服务器发生故障导致memcached无法连接,就会产生巨大的问题。

连载的第4次 中提到,Cache::Memcached拥有rehash功能,即在无法连接保存数据的服务器的情况下,会再次计算hash值,连接其他的服务器。

但是,Cache::Memcached::Fast没有这个功能。不过,它能够在连接服务器失败时,短时间内不再连接该服务器的功能。

my $fast = Cache::Memcached::Fast->new({
    max_failures     => 3,
    failure_timeout  => 1
});

在failure_timeout秒内发生max_failures以上次连接失败,就不再连接该memcached服务器。我们的设置是1秒钟3次以上。

此外,mixi还为所有用户共享的缓存数据的键名设置命名规则,符合命名规则的数据会自动保存到多台memcached服务器中,取得时从中仅选取一台服务器。创建该函数库后,就可以使memcached服务器故障不再产生其他影响。
memcached应用经验

到此为止介绍了memcached内部构造和函数库,接下来介绍一些其他的应用经验。
通过daemontools启动

通常情况下memcached运行得相当稳定,但mixi现在使用的最新版1.2.5 曾经发生过几次memcached进程死掉的情况。架构上保证了即使有几台memcached故障也不会影响服务,不过对于memcached进程死掉的服务器,只要重新启动memcached,就可以正常运行,所以采用了监视memcached进程并自动启动的方法。于是使用了daemontools。

daemontools是qmail的作者DJB开发的UNIX服务管理工具集,其中名为supervise的程序可用于服务启动、停止的服务重启等。

    * daemontools

这里不介绍daemontools的安装了。mixi使用了以下的run脚本来启动memcached。

#!/bin/sh

if [ -f /etc/sysconfig/memcached ];then
        . /etc/sysconfig/memcached
fi

exec 2>&1
exec /usr/bin/memcached -p $PORT -u $USER  -m $CACHESIZE -c $MAXCONN $OPTIONS

监视

mixi使用了名为“nagios”的开源监视软件来监视memcached。

    * Nagios: Home

在nagios中可以简单地开发插件,可以详细地监视memcached的get、add等动作。不过mixi仅通过stats命令来确认memcached的运行状态。

define command {
command_name                   check_memcached
command_line                   $USER1$/check_tcp -H $HOSTADDRESS$ -p 11211 -t 5 -E -s 'stats\r\nquit\r\n' -e 'uptime' -M crit
}

此外,mixi将stats目录的结果通过rrdtool转化成图形,进行性能监视,并将每天的内存使用量做成报表,通过邮件与开发者共享。
memcached的性能

连载中已介绍过,memcached的性能十分优秀。我们来看看mixi的实际案例。这里介绍的图表是服务所使用的访问最为集中的memcached服务器。
memcached-0005-02.png

图2 请求数
memcached-0005-03.png

图3 流量
memcached-0005-04.png

图4 TCP连接数

从上至下依次为请求数、流量和TCP连接数。请求数最大为15000qps,流量达到400Mbps,这时的连接数已超过了10000个。该服务器没有特别的硬件,就是开头介绍的普通的memcached服务器。此时的CPU利用率为:
memcached-0005-05.png

图5 CPU利用率

可见,仍然有idle的部分。因此,memcached的性能非常高,可以作为Web应用程序开发者放心地保存临时数据或缓存数据的地方。
兼容应用程序

memcached的实现和协议都十分简单,因此有很多与memcached兼容的实现。一些功能强大的扩展可以将memcached的内存数据写到磁盘上,实现数据的持久性和冗余。连载第3次 介绍过,以后的memcached的存储层将变成可扩展的(pluggable),逐渐支持这些功能。

这里介绍几个与memcached兼容的应用程序。

repcached
    为memcached提供复制(replication)功能的patch。
Flared
    存储到QDBM。同时实现了异步复制和fail over等功能。
memcachedb
    存储到BerkleyDB。还实现了message queue。
Tokyo Tyrant
    将数据存储到Tokyo Cabinet。不仅与memcached协议兼容,还能通过HTTP进行访问。

Tokyo Tyrant案例

mixi使用了上述兼容应用程序中的Tokyo Tyrant。Tokyo Tyrant是平林开发的 Tokyo Cabinet DBM的网络接口。它有自己的协议,但也拥有memcached兼容协议,也可以通过HTTP进行数据交换。Tokyo Cabinet虽然是一种将数据写到磁盘的实现,但速度相当快。

mixi并没有将Tokyo Tyrant作为缓存服务器,而是将它作为保存键值对组合的DBMS来使用。主要作为存储用户上次访问时间的数据库来使用。它与几乎所有的mixi服务都有关,每次用户访问页面时都要更新数据,因此负荷相当高。MySQL的处理十分笨重,单独使用memcached保存数据又有可能会丢失数据,所以引入了Tokyo Tyrant。但无需重新开发客户端,只需原封不动地使用Cache::Memcached::Fast即可,这也是优点之一。关于Tokyo Tyrant的详细信息,请参考本公司的开发blog。

    * mixi Engineers' Blog - Tokyo Tyrantによる耐高負荷DBの構築
    * mixi Engineers' Blog - Tokyo (Cabinet|Tyrant)の新機能

总结

到本次为止,“memcached全面剖析”系列就结束了。我们介绍了memcached的基础、内部结构、分散算法和应用等内容。读完后如果您能对memcached产生兴趣,就是我们的荣幸。关于mixi的系统、应用方面的信息,请参考本公司的开发blog。感谢您的阅读。
分享到:
评论

相关推荐

    CVE-2020-9484

    CVE-2020-9484(Tomcat) 仅用于...跑步$ git clone https://github.com/masahiro331/CVE-2020-9484.git$ cd CVE-2020-9484$ docker build -t tomcat:groovy .$ docker run -d -p 8080:8080 tomcat:groovy开发$ curl '...

    H2O-优化的HTTP / 1,HTTP / 2,HTTP / 3服务器-C/C++开发

    马克·霍斯肯(MarcHörsken),长野正宏(Masahiro Nagano),杰夫·马里森(Jeff Marrison),大木真希,Laurentiu Nicola,贾斯汀·朱,龙城刚朗,松本亮介,正木正佳,正隆昌之,Inc.,David Carlier,Frederik ...

    java-smtp-client:CustomersMailCloud-SMTP客户端-Java

    客户邮件云-Java / SMTP 一个Java库,用于将邮件发送到多个SMTP服务器,这些服务器的负载由DNS轮循机制分配。 可以代替JavaMail提供的Transport类使用它。要求JDK 1.6或更高版本JavaMail ...作者大久保弘(Masahiro O

    matlab求矩阵的行列式的代码-nmatrix:通过SciRuby的Ruby的稀疏线性代数库

    NMatrix的灵感来自田中正宏(Masahiro Tanaka)。 安装 要安装最新的稳定版本: gem install nmatrix - - pre 但是,您将需要首先使用CBLAS(到的C接口)进行安装。 可以找到详细的说明。 NMatrix的要求是: ATLAS,...

    vesselnessfilter:扫频光学相干断层扫描成像的脉络膜血管的可视化-matlab开发

    Sekiryu,Tetsuju,Yukinori Sugano,Okima Akira,Takafumi Mori,Minoru Furuta,Masahiro Okamoto和Satoshi Eifuku。2019年,“由扫频光学相干断层扫描成像的脉络膜血管的混合三维可视化。”翻译视觉科学与技术8 ...

    201510-masahiro.namatame

    【标题】"201510-masahiro.namatame"可能指的是一个开源项目或者个人在2015年10月期间由Masahiro Namatame维护的代码库。这个标题没有提供太多具体的信息,但从一般命名规范来看,它可能是作者的名字与日期的组合,...

    ODP:OrderDegree问题库

    @inproceedings {10.1145 / 3368474.3368478,作者= {Nakao,Masahiro和Murai,Hitoshi和Sato,Mitsuhisa},标题= {未加权图中所有对最短路径算法的并行化},年份= {2020},isbn = { 9781450372367},出版商= {...

    multiarray:用于多维和统一数组的 Ruby 扩展

    多阵列作者: Jan Wedekind版权所有: 2010许可证: GPL概要这个 Ruby 扩展定义了类 {Hornetseye::MultiArray} 和其他本地数据类型。 {Hornetseye::MultiArray} 提供具有相同类型元素的多维 Ruby 数组。 该扩展旨在与 ...

    日本旅游业的未来:2020年可持续增长路径.pdf

    我们对Urs Binggeli、Alex Dichter、Masahiro Komatsubara、Diaan-Yi Lin和Cheryl SH Lim等在旅游和旅游业方面的建议表示感谢。在零售和数字化领域,我们得益于Tomohiko Funaishi、Ken Kajii、Paul McInerney和...

    Measurement of MWCNT/Tungsten Contact Resistance by bridging CNT on Two Tungsten electrodes with Two Manipulators

    该研究论文于2015年12月11日至13日在日本名古屋的Meijo大学举办的2015 IEEE/SICE国际系统集成研讨会上发表。论文作者包括Ning Yu, Masahiro Nakajima, Qing Shi, Masaru Takeuchi, Zhan Yang, Qiang Huang, Toshio ...

    基于安卓的二维码扫描识别系统设计论文.doc

    二维码是由日本工程师Masahiro Hara于1994年发明的,主要用于快速识别和读取数据。 2. 安卓平台的应用:安卓平台是Google公司开发的一款开源操作系统,主要用于智能手机和平板电脑。安卓平台提供了许多开发工具和...

    【高考专题辅导】四川省2014版高考英语 阶段滚动卷(五)

    12. 日本机器人设计师Masahiro Mori的观点:Mori提出了"恐怖谷理论"(Uncanny Valley),指的是当机器人与人类相似度增加时,人们对其的反应可能会从正面转变为负面。 综上所述,这些内容涵盖了英语语法、句型结构...

    表面等离子体共振计算器:Matlab 程序,可生成表面等离子体共振曲线以将其与实验进行比较-matlab开发

    Matlab 程序,生成表面等离子共振曲线以将其与实验数据进行比较。... 关于 SPR 一般参见 en.wikipedia.org/wiki/Surface_plasmon_resonance 这个计算的灵感来自www.scl.kyoto-u.ac.jp/~masahiro/sprtheory.html

    lu分解法matlab代码-nmatrix:通过SciRuby的Ruby原型数字矩阵库

    lu分解法matlab代码 矩阵 用于Ruby的快速数值线性代数库 ...NMatrix的灵感来自田中正宏(Masahiro Tanaka)。 安装 要安装最新的稳定版本: gem install nmatrix NMatrix的要求是: GCC 4.3或更高版本

    标准模型下基于格的身份代理部分盲签名方案.docx

    MASAHIRO等人引入了代理签名的概念;ABE等人又进一步提出了部分盲签名的概念,即允许用户和签名者协商一个在整个签名过程中都可见的公共消息。 本文将关注的是2020年RAWAL等人针对2014年ZHANG等人提出的基于格的...

    Inter-brain sync during coordination of

    一项研究由Masahiro Kawasaki等人进行,他们专注于人类在社会互动中语音节奏协调时的“大脑间同步”(Inter-brain sync)现象。研究团队分别来自RIKEN BSI-TOYOTA合作中心、RIKEN脑科学研究所、茨城大学系统与信息...

    Primo:使用 Ruby 进行概率推理建模

    普里莫使用 Ruby 进行概率推理建模 2013 年,我参加了的在线课程“Probabilistic Graphical ... 真诚地感谢 Masahiro Tanaka 的精彩 ,例如,它允许我在将两个多维数组与它们的轴的简单旋转对齐后(实际上非​​常酷

    qrcodeproject:QR码生成

    QR的历史QR码系统是1994年由日本公司Denso Wave的Masahiro Hara发明的。 最初的设计受到Go板上的黑白棋子的影响。 其目的是在制造过程中跟踪车辆。 它旨在允许高速组件扫描。 现在,QR代码在更广泛

    THE-WEBSIDE-OF-ORIGAMI-4

    7. 折纸社区:在线社区如OrigamiUSA和International Origami Center,为折纸爱好者提供了一个交流心得、分享作品的平台,也组织线上线下活动促进折纸艺术的发展。 8. 折纸艺术的应用:除了传统的纸张,折纸还可以...

Global site tag (gtag.js) - Google Analytics