From owner-freebsd-current@freebsd.org Sun Aug 12 16:50:25 2018 Return-Path: Delivered-To: freebsd-current@mailman.ysv.freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2610:1c1:1:606c::19:1]) by mailman.ysv.freebsd.org (Postfix) with ESMTP id 54EC31076112 for ; Sun, 12 Aug 2018 16:50:25 +0000 (UTC) (envelope-from micchie@sfc.wide.ad.jp) Received: from mail.sfc.wide.ad.jp (mail.sfc.wide.ad.jp [IPv6:2001:200:0:8803:203:178:142:146]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (Client did not present a certificate) by mx1.freebsd.org (Postfix) with ESMTPS id D6ED28F96E for ; Sun, 12 Aug 2018 16:50:24 +0000 (UTC) (envelope-from micchie@sfc.wide.ad.jp) Received: from mail-io0-f178.google.com (mail-io0-f178.google.com [209.85.223.178]) by mail.sfc.wide.ad.jp (Postfix) with ESMTPSA id 298262782D8 for ; Mon, 13 Aug 2018 01:50:20 +0900 (JST) Received: by mail-io0-f178.google.com with SMTP id l7-v6so8345535iok.6 for ; Sun, 12 Aug 2018 09:50:20 -0700 (PDT) X-Gm-Message-State: AOUpUlEnX4G1MF8SoWBp7cTlAhppQezJhkEbefhxt8QhJ9VX8AsCHkCd 2d/BjTfNWbiyVzHFJ/ljMUlmuuDfD9nIKnKlVN0= X-Google-Smtp-Source: AA+uWPweI7WvgrNeW4bcI2zRDnz4YzqslJIs1V+P4iI++cQ+62HlATXPRn7Eb9nRIezFam+lio+4fgJ0yo03/ie4Plo= X-Received: by 2002:a6b:3757:: with SMTP id e84-v6mr12547386ioa.151.1534092618480; Sun, 12 Aug 2018 09:50:18 -0700 (PDT) MIME-Version: 1.0 Received: by 2002:a4f:1007:0:0:0:0:0 with HTTP; Sun, 12 Aug 2018 09:50:17 -0700 (PDT) From: Honda Michio Date: Sun, 12 Aug 2018 18:50:17 +0200 X-Gmail-Original-Message-ID: Message-ID: Subject: TCP server app performance To: freebsd-current@freebsd.org Content-Type: text/plain; charset="UTF-8" X-Content-Filtered-By: Mailman/MimeDel 2.1.27 X-BeenThere: freebsd-current@freebsd.org X-Mailman-Version: 2.1.27 Precedence: list List-Id: Discussions about the use of FreeBSD-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 12 Aug 2018 16:50:25 -0000 Hi, I'm measuring TCP server app performance using my toy web server. It just accept TCP connections and responds back HTTP OK to the clients. It monitors sockets using kqueue, and processes each ready descriptor using a pair of read() and write(). (in more detail, it's https://github.com/micchie/netmap/tree/paste/apps/phttpd) Using 100 persistent TCP connections (the client sends 44 B HTTP GET and the server responds with 151 B of HTTP OK) and a single CPU core, I only get 152K requests per second, which is 2.5x slower than Linux that runs the same app (except that it uses epoll instead of kqueue). I cannot justify this by myself. Does anybody has some intuition about how much FreeBSD would get with such workloads? I tried disabling TCP delayed ack and changing interrupt rates, but no significant difference was observed. I use FreeBSD-CURRENT with GENERIC-NODEBUG (git commit hash: 3015145c3aa4b). For hardware, the server has Xeon Silver 4110 and Intel X540 NIC (activate only a single queue as I test with a single CPU core). All the offloadings are disabled. Cheers, - Michio