第八章 Transaction
整体设计
介绍
PJSIP中的transation表示为pjsip_transaction结构,在<pjsip/sip_transaction.h>中。Transaction的生命周期通常有以下几步:
- 通过pjsip_tsx_endpt_create_uac()/pjsip_tsx_create_uas()创建
- 在初始化UAS之后,应用将需要调用pjsip_tsx_recv_msg()传入初始的请求消息,这样这个transaction的状态就从NULL变为TRYING。后续的重传请求将被这个事务终止。
- 当应用想要使用这个Transaction发送请求或响应消息时,它将调用pjsip_tsx_send_msg()
- 当有消息传给Transaction时(Endpoint传给的到来消息或TU传给的外出消息),或定时器超时,事务状态会自动改变,并且TU通过on_tsx_state()回调函数将被通知。
- 如果Transaction的状态变为PJSIP_TSX_STATE_TERMINATED时,这个Transaction将被销毁。应用也可以调用pjsip_tsx_terminate()来强制终止这个Transaction。
定时器和重传
Transaction有两种类型的定时器:重传定时器和超时定时器。这两种定时器的值将被Transaction根据Transaction的类型(UAS或UAC),transport(可靠或不可靠),和请求方法(INVITE和non-INVITE)来设置。
应用只能在全局的基础上改变定时器的时间间隔(可能只有在编译的时候)。
一个Transaction处理包括到来和外出的重传。到来的重传会被Transaction安静地终止和忽略;Transaction不会发出任何通知。Transaction在需要时,会自动重传外出消息;同样也不发出任何通知。
INVITE最终响应和ACK请求
失败的INVITE请求
注意:Transaction严格遵循RFC3261来处理失败的INVITE请求。
客户端