Introduction To SMPP Version 5
Introduction To SMPP Version 5
Introduction To SMPP Version 5
Introduction
SMPP is an open, industry standard protocol designed to provide a flexible data communications interface for the transfer of short message data between External Short Message Entities (ESME), Routing Entities (RE) and Message Centers. The protocol is based on pairs of request/response PDUs (protocol data units, or packets) exchanged over OSI layer 4 (TCP session or X.25 SVC3) connections. PDUs are binary encoded for efficiency. Data exchange may be synchronous, where each peer must wait for a response for each PDU being sent, and asynchronous, where receiving and transmitting go in independent threads with the use of buffers and timers. Example: If an ESME wishes to submit a short message, it may send a submit_sm PDU to the MC. The MC will respond with a submit_sm_resp PDU, indicating the success or failure of the request. Likewise, if a MC wishes to deliver a message to an ESME, it may send a deliver_sm PDU to an ESME, which in turn will respond with a deliver_sm_resp PDU as a means of acknowledging the delivery.
Introduction
In order to make use of the SMPP Protocol, a SMPP session must be established between the ESME and Message Centre or SMPP Routing Entity where appropriate. The established session is based on an application layer TCP/IP or X.25 connection between the ESME and MC/RE and is usually initiated by the ESME.
SMPP Sessions
Establishing a Session first requires the ESME to connect to the MC. This is achieved using a TCP/IP or X.25 connection. The MC will typically be listening for connections on one or more TCP/IP ports or X.25 interfaces (X.25 programmatic interfaces, DTE addresses and X.25 protocol Ids). For TCP/IP, IANA has standardized port 2775 for SMPP. However ports may vary across MC vendors and operators. SMPP session and can have several states:
PDU Sequencing
PDU
Sequence Number
PDU Sequencing
Monotonically increasing sequence numbers are easy to implement and handle. They also have the additional characteristic of providing a running operation count for the session. Thus for any session employing monotonically increasing sequence numbers, a sequence number of 100, identifies the 100th PDU issued within the session. While the recommendation is that sequence numbers should be monotonically increased, this is not a mandatory requirement and some ESMEs or MCs may deliberately select random numbers or values based on some predetermined sequence. Another approach for an ESME or MC is to use a selected range of sequence numbers reusing values as soon as the associated response has been received.
Whatever the approach taken by the originating peer, the responding peer is expected to honour these values and use the same sequence number in the response PDU.
PDU Sequencing
Sequence numbers are designed for use within a single session. The recommended approach is to begin each session with a sequence number of 1 and increase monotonically from that point. The numbers used will not affect any other sessions that may already exist between the ESME and MC. Nor can PDUs from one session be acknowledged through another.
If the ESME-MC connection is closed or lost, then the expected recovery would be that the ESME or MC might re-establish the session. All unacknowledged PDUs from the lost session will not be acknowledged in the new recovery session, i.e. if the session was lost at a point where the MC had yet to send a submit_sm_resp to the ESME, then a new session established between the ESME and MC will not result in this response PDU being returned. Instead, the ESME is expected to begin numbering PDUs from 1. The same expectation applies for the Message Centre.
Error Handling
An ESME or MC may experience a failed connection attempt or may suddenly lose its connection to the other peer. This can be due to any of the following reasons.
The IP address and port or X.25 details are incorrect (for failed connection attempts) The remote MC or ESME is down or unable to accept the connection The network between the two hosts is down
The recommended approach is to continually try to connect or reconnect again at intervals. Many ESME systems provide crucial services to an SMS network. If a network or Message Centre becomes unavailable, causing ESMEs to lose their SMPP connections, then as long as an ESME enters a mode whereby it attempts to reconnect at intervals of say five seconds, then as soon as the network or Message Centre service is restored, the ESME will be quickly reconnected to resume service.
In terms of SMPP, if an ESME or MC submits/delivers messages at a rate that exceeds the capabilities of its peer, congestion may occur. Relying on windowing to solve the problem is not enough. The ESME will continue to top up its window of unacknowledged requests, keeping the MC under load to process these requests. To better assist a peer (ESME or MC) in avoiding congestion, the peer needs a mechanism to provide the receiving peer with an indication of its state of congestion. This is accomplished with the addition of an optional congestion_state TLV. This parameter may be optionally included in any response PDU sent between an ESME and MC. This TLV contains a simple integer from 0-100 to indicate the Congestion state ranging from idle to congested. The ESME or MC can use this value as a means of detecting increased load scenarios on its peer and take the appropriate action to reduce its input rates. In order to get the maximum throughput from the transfer of messages, the MC or ESME should try to maintain the Congestion state between 80-90 (Optimum Load).
When commencing a SMPP session, the ESME or MC would begin transmission of requests, with a maximum window of N. If the ESME or MC supports the Congestion_State TLV, then as the responses arrive, the ESME/MC can increase/decrease its transmission rate according to the indicated Congestion state of its peer. If the Congestion_State TLV is supported, then the Window of N can actually be discarded as the Congestion_State itself acts as a better indicator and preventative measure of congestion avoidance. If the TLV is not present in response PDUs, then simple linear windowing is the only means of applying flow control within the session. The advantage of using congestion_state over a fixed window is that the ESME can avail of the optimum performance available at a particular time instead of predetermining some window limit and using this consistently. This recognises that a MC or ESME may be under varying levels of stress and that predetermined performance is not always guaranteed.
SMPP Applications
Voicemail alerts originating from a VPS (Voice Processing System), indicating voice messages at a customers mailbox. This is arguably one of the first ESME-based applications of SMS and is still heavily used in the industry. Numeric and alphanumeric paging services. With an SMS-capable phone, the need to carry both pager and phone is drastically reduced. Information services. For example, an application that enables mobile subscribers to query currency rates or share-price information from a database or the WWW and have it displayed as a short message on the handsets. Calls directly dialled or diverted to a message-bureau operator, who forwards the message to the MC, for onward delivery to a subscribers handset. Directory services. For example a subscriber calls a directory service requesting information on restaurants in a given area. The operator lists out available restaurants and sends the appropriate information as an SMS to the caller.
Thank you !