Re: [sipcore] Bypassing out-of-service intermediate Proxy

<> Tue, 16 November 2010 17:02 UTC

Return-Path: <>
Received: from localhost (localhost []) by (Postfix) with ESMTP id 514103A6DBD for <>; Tue, 16 Nov 2010 09:02:37 -0800 (PST)
X-Virus-Scanned: amavisd-new at
X-Spam-Flag: NO
X-Spam-Score: -2.049
X-Spam-Status: No, score=-2.049 tagged_above=-999 required=5 tests=[BAYES_00=-2.599, HELO_EQ_FR=0.35, J_CHICKENPOX_29=0.6, J_CHICKENPOX_39=0.6, RCVD_IN_DNSWL_LOW=-1]
Received: from ([]) by localhost ( []) (amavisd-new, port 10024) with ESMTP id cox1ew3pGn4C for <>; Tue, 16 Nov 2010 09:02:36 -0800 (PST)
Received: from ( []) by (Postfix) with ESMTP id EA0093A68F2 for <>; Tue, 16 Nov 2010 09:02:35 -0800 (PST)
Received: from (localhost.localdomain []) by localhost (Postfix) with SMTP id 7A76E77800D; Tue, 16 Nov 2010 18:06:37 +0100 (CET)
Received: from (unknown []) by (Postfix) with ESMTP id 77C27858011; Tue, 16 Nov 2010 18:06:23 +0100 (CET)
Received: from ([]) by with Microsoft SMTPSVC(6.0.3790.4675); Tue, 16 Nov 2010 18:01:37 +0100
X-MimeOLE: Produced By Microsoft Exchange V6.5
Content-class: urn:content-classes:message
MIME-Version: 1.0
Content-Type: text/plain; charset="iso-8859-1"
Content-Transfer-Encoding: quoted-printable
Date: Tue, 16 Nov 2010 18:01:18 +0100
Message-ID: <>
In-Reply-To: <>
Thread-Topic: [sipcore] Bypassing out-of-service intermediate Proxy
Thread-Index: Act9pwQEV7/PjqRaRkKhk2AoTys28QIB/LJA
References: <><>, <> <><> <> <> <>
From: <>
To: <>
X-OriginalArrivalTime: 16 Nov 2010 17:01:37.0693 (UTC) FILETIME=[EE79ECD0:01CB85AF]
Subject: Re: [sipcore] Bypassing out-of-service intermediate Proxy
X-Mailman-Version: 2.1.9
Precedence: list
List-Id: SIP Core Working Group <>
List-Unsubscribe: <>, <>
List-Archive: <>
List-Post: <>
List-Help: <>
List-Subscribe: <>, <>
X-List-Received-Date: Tue, 16 Nov 2010 17:02:37 -0000

> How can the element doing the skipping know? In general it has no idea of the importance of an element in the route.
> Its at the time of insertion into the route that the importance is known, so that is when such decisions should be made.

I see two ways: at the moment of insertion into the Route, as you mentionned, via a URI parameters ( the element which inserts itself into the Route knows whether it's could be sikpped) or via a static configuration ( which is of course less flexible solution)

Best Regards, 


-----Message d'origine-----
De : Paul Kyzivat [] 
Envoyé : samedi 6 novembre 2010 12:38
Cc :
Objet : Re: [sipcore] Bypassing out-of-service intermediate Proxy

On 11/5/2010 2:44 PM, wrote:
> I don't think this analogy is correct.
> If you take the example of a SIP Server which is inserted in the SIP path only to provide a supplementary service in case this latter is requested by the user ( e.g. call transfer), I think that the user will not be satisfied if it's call does not succeed just because the network is not able to provide this service...

Sure, the analogy *might* not always be correct, though it surely will be correct in some / many cases.

How can the element doing the skipping know? In general it has no idea of the importance of an element in the route.
Its at the time of insertion into the route that the importance is known, so that is when such decisions should be made.

> Youssef
> -----Message d'origine-----
> De : [] De la 
> part de Paul Kyzivat Envoyé : mercredi 3 novembre 2010 14:58 À : 
> Objet : Re: [sipcore] Bypassing out-of-service 
> intermediate Proxy
> This idea seems analogous to the auto assembly line deciding to bypass 
> the broken station where the engine is inserted into the car, and just 
> send the car on to the next station without its engine. The consumer 
> who receives this car may be less than satisfied. :-(
> 	Thanks,
> 	Paul
> On 11/3/2010 5:55 AM, wrote:
>> I understand that the usage of DNS to provide alternate server is a way to ensure redundancy. In such solution, to be able to handle SIP requests inside a SIP dialog and for which the proxy need to be "dialog statefull", there is a need to implement a mechanism that would allow the "alternate" server to share the same SIP dialog contexts.
>> My idea is in case of unavailability of the next hop and in case no 
>> alternate server is returned by DNS (or alternate servers are 
>> unreachable too), instead of rejecting the request (which would make 
>> the call/session fails), the SIP Proxy may send it to the hop after 
>> the unreachable one in the Route. This alternative would be 
>> authorized only if the Proxy knows that it's better to bypass the 
>> unreachable node instead of rejecting the request. The SIP proxy may 
>> get this information via a URI parameter in the Route entry of the 
>> "unreachable" node for example
>> Best regards,
>> Youssef
>> -----Message d'origine-----
>> De : Worley, Dale R (Dale) [] Envoyé :
>> vendredi 29 octobre 2010 20:22 À : CHADLI Youssef RD-CORE-ISS; 
>> Cc : Objet : RE: [sipcore] 
>> Bypassing out-of-service intermediate Proxy
>> ________________________________________
>> From: [] On Behalf 
>> Of 
>> []
>> I understand that the intention of this text in RFC 3261 is to fail over to an alternate server that serves the same function. Though, it's not explicitly stated.
>> However, I did not find any text in RFC 3261 that would make forbidden failing over to a proxy further down the path.  Moreover, I did not see any problem to such behaviour.
>> ________________________________
>> If a particular URI is included in a Route header, then there is some important function the server with that URI is to perform.  If one element ignores this URI and sends the request to the next URI in the Route header, presumably the function of the skipped server will not be performed.
>> In all cases that I have heard about, the correct way to provide alternate servers for a failed server is to construct a DNS SRV name which maps to the primary and alternate server as is desired.
>> For instance, if functionA is to be serviced by serverA but in an emergency the request can be routed to serverB, and if functionB is serviced by serverB, then we construct two SRV names:
>> functionA    SRV   serverA  priority=1
>> functionA    SRV   serverB  priority=2
>> functionB    SRV   serverB priority=1
>> and use this Route header:
>> Route:  sip:functionA, sip:functionB
>> If an element has a request with this Route header, it will send the request to sp:functionA using the RFC 3263 rules, viz., attempt to send to serverA, and if that fails, attempt to send to serverB.
>> Dale
>> _______________________________________________
>> sipcore mailing list
> _______________________________________________
> sipcore mailing list