机器之心编译机器之心编辑部撸代码、写博客、动手做点好玩的东西是一个码农常见的进阶方式。很多大牛都有写博客的习惯,动手能力更是不在话下。今天介绍的这位机器学习爱好者WILLHO也喜欢写博客,他不仅自己注册了一个博客网站,还搭了一个28核的树莓派集群来实现自托管。在此过程中,他学到了Linux、Docker、DockerSwarm、Kubernetes、DNS、TLS和网络拓扑等很多方面的技能。在最新的一篇博客中,WILLHO介绍了自己搭建的28核树莓派集群。这个集群名叫Kraken,用到了7个树莓派3B。前面已经说过,WILLHO搭建树莓派集群是为了实现自托管,也就是托管自己用Wordpress搭建起来的博客网站。WordPress是使用PHP语言开发的博客平台,用户可以在支持PHP和MySQL数据库的服务器上架设属于自己的网站,也可以把WordPress当作一个内容管理系统来使用。在此之前,他也曾搭建过一个名为Octopi的树莓派集群(一个树莓派1B+和4个树莓派1B),但很快他就发现,在这个集群上运行Wordpress有很大的性能瓶颈,打开一个新的Wordpress博客的单页加载大约需要10秒!为了解决这一瓶颈,WILLHO下决心对Octopi进行升级,于是就有了我们今天文章的主角——Kraken。在以下的篇幅中,WILLHO介绍了自己搭建Kraken的过程。如果你也有建树莓派集群的需求或者想学学Docker等工具,可以参考作者的方式搭一个自己的集群。Kraken概况Kraken由7个树莓派3B组成,由一个USB充电器供电。WILLHO本打算构建一个由8个节点组成的树莓派集群,但消费级的网络交换机上的最大端口数为8个,能容纳7个节点和一条到路由器的电缆。另一种选择是使用具有16个端口的商业级网络交换机,但这显然是不可能的,看看价格,劝退。用树莓派3B搭建的Kraken集群规格如下表:所需的零件清单如下表:值得注意的是,作者选择了32GBMicroSD卡作为第一个节点的存储,并希望它成为Dockerswarm设置的主节点。作者预计,还需要额外的存储空间来构建和部署Docker映像。Kraken(上)和Octopi(下)Kraken千兆升级作者发现自己经常在RaspberryPi3B的内置以太网端口上达到Mbps的带宽限制。在大型文件的传输过程中,传输速度甚至徘徊在令人沮丧的8MB/秒。受到JeffGeerling的博客的启发,作者发现,使用USB千兆以太网适配器可以将带宽提高到Mbps以上。于是,他买了一堆便宜的USB千兆以太网适配器和一个千兆交换机,开始升级。便宜的USB千兆以太网适配器。附加零件清单:升级后,Kraken看起来是这样的:GigabitKraken,Octopiandmycablemanagementnightmare如果所有成本都算下来,打造这个Kraken集群总共花了.84美元。基准判别在升级之前运行iperf,可以看到最大带宽是93.1Mbps。~iperf-c..3.11------------------------------------------------------------Clientconnectingto..3.11,TCPportTCPwindowsize:KByte(default)------------------------------------------------------------[4]local..3.71portconnectedwith..3.11port[ID]IntervalTransferBandwidth[4]0.0-10.0secMBytes93.1Mbits/sec在安装千兆适配器之后运行iperf,可以看到最大带宽为Mbps!~iperf-c..3.11------------------------------------------------------------Clientconnectingto..3.11,TCPportTCPwindowsize:KByte(default)------------------------------------------------------------[4]local..3.71portconnectedwith..3.11port[ID]IntervalTransferBandwidth[4]0.0-10.0secMBytesMbits/sec有了这个简单的模块,每个节点就获得了Mbps的带宽。然而,这些仍然只是理论上的速度,因为典型的使用场景包括将从网络接收到的数据写入磁盘,但是iperf只从网络接收数据,而不将数据写入磁盘。一些注意事项即使在Web服务中,也不大可能持续地充分利用此新带宽。它主要有助于在首次加载时更快地传输大型资源(如图像数据),之后,用户的浏览器会缓存图像。此外,RaspberryPi1至3型号中臭名昭著的共享USB2.0总线也限制了实际带宽。对于未初始化的用户,单个USB2.0总线的Mbps理论单向宽带在以太网端口、SD卡插槽和所有USB端口之间共享。带宽分布如下所示:尽管表格中的数字给人的印象是:这次升级没有带来性能上的提升。但它们代表的是最坏的情况。通常情况下,人们期望在web服务器上进行的主要是读操作,而很少进行写操作。在现实世界中,带宽分配通常应如下所示:以上是作者对第二个树莓派集群的升级操作,但是如果你已经熟悉Docker系统,或者正在寻找高性能的家庭设置,在此不建议使用此教程。为何选择此集群?如果你对Docker和Kubernetes感兴趣,作者强烈建议你上手搭个这样的集群。对此,他给出了两个理由:首先,该集群与官方支持的最新版本Docker映像兼容。此外,RaspberryPi3B在armv7CPU架构上运行。最新的Arm处理器(arm64)向后兼容在armv7上编写和编译的所有代码。相反,arm64处理器不向后兼容armv6处理器(RaspberryPi1和2),因此它们正在被社区淘汰。其次,对于大多数对带宽要求较高的应用程序,该集群将是理想的选择,例如托管你自己的博客,文件同步服务,媒体库管理器,记笔记应用程序等。考虑到RaspberryPi3中的USB2.0总线瓶颈,如果你的应用程序需要大量持续的写入(例如对视频进行编码),这个集群的性能可能无法达到要求。总而言之,构建RaspberryPi3集群是学习Docker和集群的最经济有效的方式,并且在可预见的将来仍将如此。因此,如果你只是想接触Docker,强烈建议你尝试一下。原文链接:
转载请注明:http://www.aierlanlan.com/tzrz/8274.html