13

我测试了基于redis容器。 https://index.docker.io/u/dockerfile/redis/

使用相同的 redis-benchmark,redis-server 在容器内运行比在托管操作系统上运行要慢得多,实际统计数据如下所示。(第一个基准是针对 docker 容器)

那么,有没有办法优化 docker 容器的性能呢?

vagrant@precise64:/tmp$ redis-benchmark -p 49153 -q -n 100000
PING (inline): 5607.27 requests per second
PING: 6721.79 requests per second
MSET (10 keys): 6085.69 requests per second
SET: 6288.91 requests per second
GET: 6627.78 requests per second
INCR: 6454.11 requests per second
LPUSH: 6449.12 requests per second
LPOP: 5355.90 requests per second
SADD: 6237.91 requests per second
SPOP: 6794.40 requests per second
LPUSH (again, in order to bench LRANGE): 6089.76 requests per second
LRANGE (first 100 elements): 6000.24 requests per second
LRANGE (first 300 elements): 4660.70 requests per second
LRANGE (first 450 elements): 4276.79 requests per second
LRANGE (first 600 elements): 3710.85 requests per second

vagrant@precise64:/tmp$
vagrant@precise64:/tmp$ sudo /etc/init.d/redis-server start
Starting redis-server: redis-server.
vagrant@precise64:/tmp$ redis-benchmark -q -n 100000
PING (inline): 19357.34 requests per second
PING: 19175.46 requests per second
MSET (10 keys): 16697.28 requests per second
SET: 19146.08 requests per second
GET: 19175.46 requests per second
INCR: 19135.09 requests per second
LPUSH: 19168.10 requests per second
LPOP: 14976.79 requests per second
SADD: 16638.93 requests per second
SPOP: 18079.91 requests per second
LPUSH (again, in order to bench LRANGE): 18268.18 requests per second
LRANGE (first 100 elements): 16136.84 requests per second
LRANGE (first 300 elements): 11528.71 requests per second
LRANGE (first 450 elements): 9237.88 requests per second
LRANGE (first 600 elements): 8864.46 requests per second
4

2 回答 2

12

容器似乎更慢,因为您正在通过一个额外的网络层。

在这种情况下,不是直接连接到 Redis,而是连接到 Docker 用户空间代理,该代理本身连接回容器(而不是通过本地接口,此连接通过veth接口)。

这增加了一点延迟(与例如 10 毫秒网页生成相比无法测量;但如果您明白我的意思,50 微秒仍然比 150 微秒快)。

如果您想进行更多“苹果对苹果”的比较,您可以:

  • 在容器内运行 redis-benchmark(从容器内直接连接到 Redis);
  • 在另一台机器上运行 redis-benchmark(但请记住,您仍然会有一个额外的网络层用于端口转换机制);
  • 在另一台机器上运行 redis-benchmark使用类似管道的机制为容器提供一个 macvlan 接口,并且(几乎)零开销。
于 2014-02-11T16:44:57.740 回答
-1

容器的额外网络层是您场景中的性能瓶颈,从 docker 到 docker 的通信不会有太大帮助(一些优化适用,但也必须面对一些额外的开销)。

此外,在与 redis 服务器相同的容器中运行 redis-benchmark 将为您提供主机级别的性能,但这不是您正在寻找的用例,可能您想知道 dockerized redis 服务器可以提供的性能。

我们在 Torusware 进行了一些测试来评估 dockerized 应用程序的开销,我们已经意识到容器的网络层限制了性能。

实际上,在同一台主机上运行一个 dockerized redis-benchmark 和一个 dockerized redis server,每秒只能实现 38k GET 和 46k SET 请求。

我们有一个解决方案来加速这个场景,以一种非侵入性的方式(在 Docker 和应用程序中都没有改变)。它是我们的产品 Speedus Plug&Run,一个高性能的插座库。

通过使用 Redis+Speedus Lite docker(可在 Docker 注册表中免费获得),您将能够显着减少峰值时间(最坏的情况),从几乎 1 秒降至 1 毫秒以下。

此外,Redis+Speedus Lite 将 SET 的性能提高了 2.5 倍(从 46k TPS 到 113k TPS),将 GET 的性能提高了 3 倍(从 39k TPS 到 121k TPS)。

查看我们博客中的这篇文章以获取更多详细信息。

但是,如果您真的追求极致性能,我们的 Speedus Extreme Performance 版本将使您的 redis 服务器运行得非常快。由于我们的技术,一个 dockerized redis 服务器可以为其他 dockerized 应用程序提供每秒 717k SET 请求和 415k GET 请求!

检查此帖子中的详细信息

于 2015-04-02T08:31:05.810 回答