• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            socket長連接的keeplive

            Posted on 2008-12-11 16:04 Prayer 閱讀(3234) 評論(0)  編輯 收藏 引用 所屬分類: SOCKET

            //設置KeepAlive
            BOOL bKeepAlive = TRUE;
            nRet = ::setsockopt(m_sockDesc, SOL_SOCKET, SO_KEEPALIVE, (char*)&bKeepAlive, sizeof(bKeepAlive));
            if (nRet !=0)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Socket SetOpt failed ", WSAGetLastError());
            return FALSE;
            }

            //設置KeepAlive檢測時間和次數
            TCP_KEEPALIVE inKeepAlive = {0}; //輸入參數
            unsigned long ulInLen = sizeof(TCP_KEEPALIVE);

            TCP_KEEPALIVE outKeepAlive = {0}; //輸出參數
            unsigned long ulOutLen = sizeof(TCP_KEEPALIVE);

            unsigned long ulBytesReturn = 0;

            //設置socket的keep alive為10秒,并且發送次數為3次
            inKeepAlive.onoff = 1;
            inKeepAlive.keepaliveinterval = 10000; //兩次KeepAlive探測間的時間間隔
            inKeepAlive.keepalivetime = 3; //開始首次KeepAlive探測前的TCP空閉時間

            nRet = WSAIoctl(m_sockDesc,
            SIO_KEEPALIVE_VALS,
            (LPVOID)&inKeepAlive,
            ulInLen,
            (LPVOID)&outKeepAlive,
            ulOutLen,
            &ulBytesReturn,
            NULL,
            NULL);
            if(SOCKET_ERROR == nRet)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Nonblocking socket call error ", WSAGetLastError());
            return FALSE;
            }

            -------------------------------------------------------------------------------------------------------------------------------

            //設置KeepAlive
            BOOL bKeepAlive = TRUE;
            nRet = ::setsockopt(m_sockDesc, SOL_SOCKET, SO_KEEPALIVE, (char*)&bKeepAlive, sizeof(bKeepAlive));
            if (nRet !=0)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Socket SetOpt failed ", WSAGetLastError());
            return FALSE;
            }

            //設置KeepAlive檢測時間和次數
            TCP_KEEPALIVE inKeepAlive = {0}; //輸入參數
            unsigned long ulInLen = sizeof(TCP_KEEPALIVE);

            TCP_KEEPALIVE outKeepAlive = {0}; //輸出參數
            unsigned long ulOutLen = sizeof(TCP_KEEPALIVE);

            unsigned long ulBytesReturn = 0;

            //設置socket的keep alive為10秒,并且發送次數為3次
            inKeepAlive.onoff = 1;
            inKeepAlive.keepaliveinterval = 10000; //兩次KeepAlive探測間的時間間隔
            inKeepAlive.keepalivetime = 3; //開始首次KeepAlive探測前的TCP空閉時間

            nRet = WSAIoctl(m_sockDesc,
            SIO_KEEPALIVE_VALS,
            (LPVOID)&inKeepAlive,
            ulInLen,
            (LPVOID)&outKeepAlive,
            ulOutLen,
            &ulBytesReturn,
            NULL,
            NULL);
            if(SOCKET_ERROR == nRet)
            {
            sprintf(m_pszError, "Winsock error : %s (Error Code %d)\n ", "Nonblocking socket call error ", WSAGetLastError());
            return FALSE;
            }

            久久99精品久久久大学生| 久久婷婷五月综合色99啪ak| 久久亚洲国产成人影院网站| 久久影院综合精品| 中文字幕乱码人妻无码久久| 亚洲а∨天堂久久精品9966| 久久久久国产一区二区三区| 国産精品久久久久久久| 国内精品久久久久久麻豆| 99久久国产热无码精品免费久久久久| 久久AV高清无码| 精品午夜久久福利大片| 亚洲午夜精品久久久久久人妖| 日韩精品国产自在久久现线拍| 99精品伊人久久久大香线蕉| 久久久精品久久久久特色影视| 久久AAAA片一区二区| 久久综合色老色| 欧美黑人又粗又大久久久| 国产成年无码久久久久毛片| www亚洲欲色成人久久精品| 久久久久国产成人精品亚洲午夜| 亚洲精品NV久久久久久久久久| 久久久久亚洲精品日久生情| 99久久婷婷免费国产综合精品| 青青草国产精品久久久久| 人人狠狠综合久久亚洲| 人妻久久久一区二区三区| 99热热久久这里只有精品68| 久久99热这里只有精品66| 精品久久久久久中文字幕人妻最新| 久久综合九色综合精品| 亚洲国产日韩欧美久久| 国产精品无码久久久久久| 精品久久人人爽天天玩人人妻| 99久久精品免费看国产一区二区三区 | 久久久久亚洲AV无码永不| 国产精品一区二区久久国产| 亚洲成av人片不卡无码久久| 久久久久无码精品国产不卡| 四虎久久影院|