質問したいのですが、現在、SMSCクライアントの開発にSMPP Logica Libraryを使用しています。また、session.submitを使用してsmscサーバーにメッセージを送信し、ほぼ50メッセージ/秒でメッセージを送信しています。配信レポートを取得するにはサーバーからのすべての応答が必要なため、複数の送信にスレッドを使用します...質問は..session.submitはスレッドセーフですか?スレッドを使用してメッセージを送信する前に、最初にセッションを同期する必要がありますか?メッセージの送信に使用するコードは
{
response = session.submit(sm);
SUBMIT_SM_RESP(response,mt);
........
}
private void SUBMIT_SM_RESP(SubmitSMResp pdu,MTData mtd) {
log.info("CommandID From PDU "+pdu.getCommandId());
//SubmitSMResp submitSMResp = new SubmitSMResp();
if (pdu.getCommandId() == Data.SUBMIT_SM_RESP ){
// submitSMResp.setData(pdu.getData());
switch (pdu.getCommandStatus())
{
case 0:
log.info("Berhasil kirim MT; SeqNo=" + pdu.getSequenceNumber() + ";" + pdu.debugString());
break;
case 1031:
log.info("Error. Service not found; SeqNo=" + pdu.getSequenceNumber() + ";" +pdu.debugString());
break;
case 1032:
log.info("Error. Invalid TX Id; SeqNo=" + pdu.getSequenceNumber() + ";" +pdu.debugString());
break;
case 1033:
log.info("Error. Push limit exceeded; SeqNo=" + pdu.getSequenceNumber() + ";" + pdu.debugString());
break;
case 4107:
log.info("Error. Content Whitelisted (Testingmode); SeqNo=" + pdu.getSequenceNumber() + ";" +pdu.debugString());
break;
case 1280:
log.info("Insuficient Balance(Charging); SeqNo=" + pdu.getSequenceNumber() + ";" +pdu.debugString());
break;
}
log.debug("MT rec status: CommandID=SUBMIT_SM_RESP; SeqNo=" + pdu.getSequenceNumber() + "; CommandSts=" + pdu.getCommandStatus() + pdu.debugString());
//MTData mt = (MTData)DataInstance.getInstance().getHmSeqMT().get(Integer.valueOf(pdu.getSequenceNumber()));
MTData mt =mtd;
String tid = null;
if (mt == null) {
log.info("MT null");
// if (DataInstance.getInstance().getHmSeqTrxID().containsKey(Integer.valueOf(pdu.getSequenceNumber()))) {
// tid = (String)DataInstance.getInstance().getHmSeqTrxID().get(Integer.valueOf(pdu.getSequenceNumber()));
// mt = DataInstance.getInstance().getDbPrs().getMTTrxID(tid);
// log.info("MT rec status: CommandID=SUBMIT_SM_RESP; SeqNo=" + pdu.getSequenceNumber() + "; CommandSts=" + pdu.getCommandStatus() + "; trxid=" + tid + "; " + pdu.debugString());
// if (mt == null) {
log.info("MT rec status: CommandID=SUBMIT_SM_RESP; SeqNo=" + pdu.getSequenceNumber() + "; CommandSts=" + pdu.getCommandStatus() + "; trxid=" + tid + " n/a; " + pdu.debugString());
mt = DataInstance.getInstance().getDbPrs().getMTSeqNo(String.valueOf(pdu.getSequenceNumber()));
// }
// }
}
else {
tid = mt.getTransid();
}
// log.info(mt.getClass());
log.info("Transaction ID >>> "+mt.getTransid());
if (mt != null) {
DataInstance.getInstance().getDbPrs().deleteMT(mt,
String.valueOf(pdu.getCommandStatus()), DataInstance.getInstance().getTransX().operator);
DataInstance.getInstance().getHmSeqMT().remove(Integer.valueOf(pdu.getSequenceNumber()));
} else {
log.info("MT Null,,,Can't Send DR");
log.info("MT n/a: SeqNo=" + pdu.getSequenceNumber() + "; CommandSts=" + pdu.getCommandStatus() + pdu.debugString());
}
}
else
{
log.info("Nilai Enquiry Link "+Data.ENQUIRE_LINK_RESP);
}
}
よろしく
Danz