http://www.kamailio.org/w/features/
Features
Starting with version 3.0.0 Kamailio is a customized package of SIP Router Project, therefore you can have access to all features of Kamailio and SIP Express Router (SER) in the same SIP server instance.
Combining its SIP core capabilities and extensible APIs, building VoIP and Unified Communication Platforms using Kamailio (K) is straightforward.
Some of the features that Kamailio offers:
* Robust and Performant SIP (RFC3261) Server flavours
o Registrar server
o Location server
o Proxy server
o SIP Application server
o Redirect server
* Flexibility
o small footprint – suitable for embedded devices – the binary file is small size, functionality can be stripped/added via modules
o plug&play module interface – ability to add new extensions, without touching the core, therefore assuring a great stability of core components
o modular architecture – core, internal libraries and module interface to extend the server’s functionality
o impressive extension repository – overall 150 modules are included in the Kamailio source tree
* SIP Routing Capabilities
o stateless and transactional stateful SIP Proxy processing
o serial and parallel forking
o NAT traversal support for SIP and RTP traffic
o load balancing with many distribution algorithms and failover support
o flexible least cost routing
o routing failover
o replication for High Availability (HA)
* Transport Layers
o support for communication via UDP, TCP, TLS and SCTP
o IPv4 and IPv6
o transport layer gatewaying (IPv4 to IPv6, UDP to TLS, a.s.o.)
o SCTP multi-homing and multi-streaming
* Asynchronous Processing
o asynchronous TCP handling
o asynchronous SIP message processing
o asynchronous inter-process message queues communication system
* Secure Communication
o Digest SIP User authentication
o Authorization via ACL or group membership
o IP and Network authentication
o TLS support for SIP signaling
o transparent handling of SRTP for secure audio
o TLS domain name extension support
o authentication and authorization against database (MySQL, PostgreSQL, UnixODBC, BerkeleyDB, Oracle, text files), RADIUS and DIAMETER
* IP and DNS
o support for SRV and NAPTR DNS lookups
o SRV DNS failover
o ENUM support
o internal DNS caching system – avoid DNS blocking
o IP level Blacklists
o multi-homed and multi-domain support
o topology hiding – hide IP addresses in SIP headers to protect your network architecture
* Accounting
o event based accounting
o configurable accounting data details
o multi-leg call accounting
o storage to database, Radius or Diameter
* Configuration File
o scripting language for configurations file. With a syntax similar to scripting languages, the configuration offers a powerful and flexible way to deploy custom SIP services.
o pseudo-variables to access and manage parts of the SIP messages and attributes specific to users and server
o transformations to modify existing pseudo-variables, accessing only the wanted parts of the information
o over 1000 parameters, variables and functions exported to config file
o runtime update framework – to avoid restarting the SIP server when needing to change the config parameters
* External Interaction via
o text-based management interface via FIFO file, udp, xmlrpc and unix sockets
o RPC control interface – via XMLRPC, UDP or TCP
* Rich Communication Services
o SIP SIMPLE Presence Server (rich presence)
o Presence User Agent
o XCAP support
o Presence DialogInfo support – SLA/BLA
o Instant Messaging
* Monitoring and Troubleshooting
o SNMP – interface to Simple Network Management Protocol
o config file step-by-step debugger
o remote control via XMLRPC
o internal statistics exported via RPC and SNMP
o flexible debug and error message logging system – log custom messages including any header or pseudo-variable and parts of SIP message structure.
* Extensibility APIs
o Perl Programming Interface – embed your extensions written in Perl
o Java SIP Servlet Application Interface – write Java SIP Servlets to extent your VoIP services and integrate with web services
o Lua Programming Interface
o Python Programming Interface
* Multiple Database Backends
o (MySQL, PostgreSQL, UnixODBC, BerkeleyDB, Oracle, text files) and other database types which have unixodbc drivers
o connections pool
o different backends can be used at same time (e.g., accounting to Oracle and authorization against MySQL)
* Interconnectivity
o straightforward interconnection with PSTN gateways
o gateway to sms or xmpp and other IM services
o interoperability with SIP enabled devices and applications such as SIP phones (Snom, Cisco, etc.), Media Servers (Asterisk, FreeSwitch, etc.)
* Miscellaneous
o CPL – Call Processing Language (RFC3880)
o Internal generic caching system
o Memcached connector
o CLI – kamctl and sercmd
o Web Management Interface: Siremis
* Extensive documentation for both administrators and developers
Scalability:
* Kamailio can run on embedded systems, with limited resources – the performances can be up to hundreds of call setups per second
* used as load balancer in stateless mode, Kamailio can handle over 5000 call setups per second
* on systems with 4GB memory, Kamailio can serve a population over 300 000 online subscribers
* system can easily scale by adding more Kamailio servers
* Kamailio can be used in geographic distributed VoIP platforms
* Kamailio least-cost-routing scales up to millions of routing rules
* straightforward failover and redundancy |