From owner-freebsd-hackers@FreeBSD.ORG Tue Sep 11 14:58:06 2007 Return-Path: Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.freebsd.org (mx1.freebsd.org [IPv6:2001:4f8:fff6::34]) by hub.freebsd.org (Postfix) with ESMTP id 3255F16A417 for ; Tue, 11 Sep 2007 14:58:06 +0000 (UTC) (envelope-from kazakov@gmail.com) Received: from an-out-0708.google.com (an-out-0708.google.com [209.85.132.250]) by mx1.freebsd.org (Postfix) with ESMTP id 069AD13C46A for ; Tue, 11 Sep 2007 14:58:05 +0000 (UTC) (envelope-from kazakov@gmail.com) Received: by an-out-0708.google.com with SMTP id c14so279454anc for ; Tue, 11 Sep 2007 07:58:05 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=beta; h=domainkey-signature:received:received:message-id:date:from:to:subject:mime-version:content-type:content-transfer-encoding:content-disposition; bh=HEkaNEb2WmYfWb05kLZkshuOesX/dfVjLAqF5uu2+n8=; b=K0gl16bn6lHXpdrbe6o03fJum7wzL1cXwiPgmL75ZGP6ZNyijdFOl0D3ay8KVRhHphP55R3rUpKHxK4ZaiXC2+aPGN6bt91ZJT3Alj5jw378m2ju5r2l7wIDMaYMGKYmFMw0ZSohdZRQ+fyut+8mDrpr7+ElPy4JBjzwW1RrC+4= DomainKey-Signature: a=rsa-sha1; c=nofws; d=gmail.com; s=beta; h=received:message-id:date:from:to:subject:mime-version:content-type:content-transfer-encoding:content-disposition; b=hdDFUHcAqEbrnnWuifAAqSIBnexeI2t0SrEelDZCDQClN8uCXTLQnZ9XDsAl3YxOFB7NFfx7YdA0cVIQX1irEVNF6GhMrhvntSNA9eLpNLfRqmoEbTWzLScb90tjpxEO5sToRdG2c7C6DVZGTZiN98B7scNAw0VS2Dag5rrM3do= Received: by 10.100.127.1 with SMTP id z1mr6523623anc.1189521199958; Tue, 11 Sep 2007 07:33:19 -0700 (PDT) Received: by 10.100.134.2 with HTTP; Tue, 11 Sep 2007 07:33:19 -0700 (PDT) Message-ID: Date: Tue, 11 Sep 2007 23:33:19 +0900 From: "Artem Kazakov" To: "FreeBSD Hackers" MIME-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1 Content-Transfer-Encoding: 7bit Content-Disposition: inline Subject: TCP/IP redundant connections X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Tue, 11 Sep 2007 14:58:06 -0000 Hello Everyone! For my research project I'm working on making some network services redundant. And I have one idea, but I'm not so good and operating system internals, so could you please tell what do you think. If it is possible at all. So, I have two hosts, which are all the same and they have some network service which I need to make available all the time. This service has some internal state, which is synchronized over private connection. And at one time only one of the servers actually works with clients, the other on is just sitting there and kept synchronized. The clients have persistent TCP connections to the server, and in case of failure they make UDP broadcasts searching for server and then reconnect. So basically there is no need to use IP-sharing between two of them. But if the server fails, the client usually notices that after some time-out (tcp keep alive time out I suppose) which is not very good in some cases. So I want to utilize IP-sharing and TCP-connection synchronization (which is not yet implemented by anyone as far as I know). I want it in case of failure seamlessly to switch to the other machine. As far as the internal state is synchronized, if it is possible to synchronize open connections as well(and all the low level stuff as packet sequence numbers and so on) it would allow to make switch-over to the back-up server in a matter of seconds, and the clients would stay connected. Is is possible to do so ? And if yes, how difficult would it be for a person who has solid background in general-tasks programming, but no experience with low level system programming ? And what are the possible cave-eats of this approach? Thank you. Artem Kazakov.