Teknik Telekomunikasi    
   
Daftar Isi
(Sebelumnya) Interaction overview diagramInterface (computing) (Berikutnya)

Inter-Asterisk eXchange

IAX is the Inter-Asterisk eXchange protocol native to Asterisk PBX and supported by a number of other softswitches and PBXs. It is used for enabling VoIP connections between servers beside client–server communication.

IAX now most commonly refers to IAX2, the second version of the IAX protocol. The original IAX protocol has been deprecated in favor of IAX2.

The IAX2 protocol was published as an informational (non-standards-track) RFC 5456 by discretion of the RFC Editor in February 2010.[1]

Contents

Basic properties

IAX2 is a VoIP protocol that carries both signaling and media on the same port. The commands and parameters are sent in binary format and any extension has to have a new numeric code allocated. Historically this was modeled after the internal data passing of Asterisk modules[citation needed].

IAX2 uses a single UDP data stream (usually on port 4569) to communicate between endpoints, multiplexing signaling and media flow. IAX2 easily traverses firewalls and network address translators. This is in contrast to SIP, H.323 and MGCP which use an out-of-band RTP stream to deliver information.

IAX2 supports trunking, multiplexing channels over a single link. When trunking, data from multiple calls are merged into a single stream of packets between two endpoints, reducing the IP overhead without creating additional latency. This is advantageous in VoIP transmissions, in which IP headers use a large percentage of bandwidth.

Origin of IAX

The IAX and IAX2 protocols were created by Mark Spencer for Asterisk for VoIP signaling. The protocol sets up internal sessions and these sessions can use whichever codec they want for voice transmission. The Inter-Asterisk Exchange protocol essentially provides control and transmission of streaming media over IP (Internet Protocol) networks. IAX is flexible and can be used with any type of streaming media including video, however it is mainly designed for control of IP voice calls.

The goals of IAX

The primary goals for IAX were to minimize bandwidth used in media transmissions, with particular attention drawn to control and individual voice calls, and to provide native support for NAT (network address translation) transparency. Another goal is to be easy to use behind firewalls.

The basic structure of IAX is that it multiplexes signaling and multiple media streams over a single UDP (User Datagram Protocol) stream between two computers. IAX is a binary protocol, designed to reduce overhead especially in regard to voice streams. Bandwidth efficiency in some places is sacrificed in exchange for bandwidth efficiency for individual voice calls. One UDP stream is easier to set up for users that are behind a firewall.

An additional benefit to having a single stream is the added security, which can be implemented very easily. Furthermore, in countries where ISPs are filtering VoIP, IAX can be easily hidden.

IAX drawbacks

  • Awkward extensibility: Due to the lack of a generic extension mechanism, every new feature has to be added in the protocol specification, which makes it less flexible than H.323, SIP or MGCP.
  • Vulnerability: Older implementations of IAX2 are vulnerable to resource exhaustion DoS attacks that are currently available to the public. There are currently no solutions to these issues. The current best practices include limiting UDP port access to specific trusted IP addresses. Internet facing IAX2 ports are considered vulnerable and should be monitored closely. The fuzzer used to detect these application vulnerabilities was posted on milw0rm and is included in the VoIPer svn tree. These issues were briefly mentioned in the IAX RFC 5456 on page 94. This flaw no longer exists in up-to-date installations of Asterisk or other PBXes.[2]

See also

  • SIP connection (aka SIP trunk)

References

  1. ^ RFC 5456 page 1: "Status of This Memo This memo provides information for the Internet community. It does not specify an Internet standard of any kind."
  2. ^ http://downloads.asterisk.org/pub/sec urity/AST-2009-006.html

External links

(Sebelumnya) Interaction overview diagramInterface (computing) (Berikutnya)