[短彩信]C#短彩信模块开发设计(4)——其他

准备从以下几个方面简单的谈谈短彩信模块的实现:

[短彩信]C#短彩信模块开发设计(1)——架构(http://www.cnblogs.com/CopyPaster/archive/2012/12/07/2806776.html
[短彩信]C#短彩信模块开发设计(2)——配置(http://www.cnblogs.com/CopyPaster/archive/2012/12/10/2811626.html
[短彩信]C#短彩信模块开发设计(3)——协议(http://www.cnblogs.com/CopyPaster/archive/2012/12/12/2814918.html
[短彩信]C#短彩信模块开发设计(4)——其他(http://www.cnblogs.com/CopyPaster/archive/2012/12/17/2821715.html

1)流控

    流控实现的方法很多种,大家去搜一个下,应该能找到很多的方式,下面简单说一下,我们的方式,下面是一个主要实现方法的概要:

public class MtConnection
    {
        private int _maxSendCount;
        private readonly object _sendCountLock = new object();
        private int _sendCount = 0;  
        private DateTime _sendTime = DateTime.Now;      //该条链路累计发送MT的时间间隔 500毫秒为一时间段

        public MtConnection(int maxSendCount)
        {
            _maxSendCount = maxSendCount;
        }

        public int MaxSendCount
        {
            get
            {
                if (DateTime.Now.Millisecond >= 500)
                {
                    return _maxSendCount / 2;
                }

                return _maxSendCount - (_maxSendCount / 2);
            }
        }

        public bool IsOverSendCount(int sendNum)
        {
            lock (_sendCountLock)
            {
                DateTime now = DateTime.Now;
                if ((now - _sendTime).TotalMilliseconds >= 500)
                {
                    _sendTime = now;
                    _sendCount = sendNum;
                }
                else
                {
                    if (this._sendCount + sendNum > this.MaxSendCount)
                    {
                        return true;
                    }

                    _sendCount += sendNum;
                }

                return false;
            }
        }
    }
class Program
    {
        static void Main(string[] args)
        {
            var mtConnection = new MtConnection(10);
            for (int i = 0; i <= 1000000; i++)
            {
                if (mtConnection.IsOverSendCount(1))
                {
                    Console.WriteLine("发送" + i + "超流控");
                    Thread.Sleep(1000);
                }
                else
                {
                    Console.WriteLine(i);
                }
            }
        }
    }

怎么样很简单吧,当然了,在我们实际的处理之中,如果判断某次的发送超过了流控阀值,不是简单的sleep,而是利用
ThreadPool.RegisterWaitForSingleObject(
 WaitHandle waitObject,
      WaitOrTimerCallback callBack,
      Object state,
     int millisecondsTimeOutInterval,
     bool executeOnlyOnce

)
向线程池添加一个可以定时执行的方法;(在我们的实现中对于延迟消息实际上会发送至一个System.Collections.Queue;原则是只要超流控,就入延迟队列;至于如何处理延迟,大家各自根据口味实现,不过要注意:一定不能丢消息,不能说第一次延迟了,第二次就一定不延迟)

2)实时监控

     关于实时监控,我们借助Window性能计数器(Performance Counter),去实时统计发送速度、发送消息数量、滑动窗口消息数量、消息积压数、网关延迟等等信息;由于为了使用方便,我们对于性能计数器进行了一定的封装,这里就不贴具体的代码了。关于性能计数器的使用,大家可以去查一下相关的资料;总之,借助Window性能计数器(Performance Counter)进行实时监控,对于程序本省的资源损耗很低,大家可以认为可以忽略;大家可以在run中输入perfmon.exe打开性能监视器;

 

3)联调和工具

3.1)抓包工具: 

短信基于CMPP协议,在联调和排查问题的时候,往往需要先抓包,那可以使用:wireshark(wireshark支持以cmpp协议解码):

 

3.2)常用Dos命令:

telnet:在检查网络是否通畅时用此命令。

tracert:如果telnet不通,可以用此命令检查哪一步出问题了。

netstat:检查连接情况。

 

3.3)其他:

一般在本地开发过程之中需要简单写一个模拟构造消息的工具(下图的TestTool)和网关挡板(下图的DumyGateway),下图是彩信solution的结构,短信的类似;

 

posted @ 2012-12-17 15:50  CopyPaster  阅读(2486)  评论(7编辑  收藏  举报