linux下的socket是一直保持着链接的么?

发布于 2022-10-15 10:05:28 字数 19735 浏览 28 评论 0

我的代码如下,写的一个简单的访问telnet服务器的代码
使用socket在windows下的运行良好
我使用该框架,修改了一下,可在recv的时候
总是返回0或者-1
不知道怎么回事,是不是我对linux下的socket编程模式使用的不对

extern boost::thread g_tNionClient;
extern int g_socketNionClient;
extern bool g_bNionClientConnected;

extern string g_strNionServerIP;
extern long g_lNionPort;

extern string g_strNionClientUserName;
extern string g_strNionClientPassWord;

extern string g_strNionAirportName ;
extern long g_lNionReconnectTime;
extern long g_lNionSockTimeOut;

bool StartHYENionClient()
{
        WriteFileLogInfo_Nion("create RunHYENionClient_THREAD ....\t");
        g_tNionClient = boost::thread( &Thread_RunHYENionClient );  
               
        WriteFileLogInfo_Nion("OK");

        return true;
}

//这里是boost的一个线程,该线程持续从服务器recv数据
int Thread_RunHYENionClient()
{
        bool bFirst = true;
        while(1)
        {
                if (!bFirst)
                {
                        WriteFileLogInfo_Nion("NION Client: NION Server closed ,just reconnect after 2 sec..");
                        boost::this_thread::sleep(boost::posix_time::seconds(2));
                        bFirst = false;
                }
                if (!g_bNionClientConnected)
                {
                        shutdown(g_socketNionClient,SHUT_RDWR);
                        close(g_socketNionClient);
                        CreatesocketConnect();
                        bFirst = false;
                }

                string strBuffer;
                //string strDaqing = "statusIs running \"DaQingAirport\" ";
                string strDaqing = "statusIs running \"";
                strDaqing += g_strNionAirportName;
                strDaqing += "\" ";

                while(g_bNionClientConnected )
                {
                        char temp;
                        int ret;
                        ret = recv(g_socketNionClient,&temp,1,0);
                        if (ret == 0)        //服务器将socket关闭               
                        {
                                close(g_socketNionClient);
                                g_bNionClientConnected = false;

                                string strlog;
                                strlog = "NION Client:***** socket client closed gracefully ,remove this socket";
                                string str;
                                strlog += Inter2String(str,g_socketNionClient);
                                WriteFileLogInfo_Nion(strlog.c_str());
                                break;
                        }
                        else if (ret == -1)//出现错误,需要重连
                        {
                                g_bNionClientConnected = false;               
                                close(g_socketNionClient);
                                string strlog = "NION Client: recv error! remove this socket";
                                WriteFileLogInfo_Nion(strlog.c_str());                               
                                break;;
                        }
                        else//接收的正确数据
                        {
                                cout<<temp;
                                if (temp != '\n')
                                {
                                        strBuffer += temp;
                                }
                                else
                                {                                       
                                        if (strBuffer.find(strDaqing) >= 0)
                                        {
                                                ClearNionServerChannel();//;connect to nion and clear nion
                                        }
                                        strBuffer = "";                                       
                                }               
                        }
                        continue;
                }
        }

        return 1;
}

bool ClearNionServerChannel()
{
        /*
        //for debug
        string strDelete = "delete from npu_queue";
        Operate_NO_Log_DBBySQL(strDelete);

        string strSQL = "select * from "+g_strAREAINFO+" where QROW_ID is not null and TERM='"+g_strTerm+"'";
        try
        {
                _variant_t RecordsAffected;
                _RecordsetPtr pRecord = NULL;
                pRecord = g_Connection->Execute((LPCSTR)strSQL,&RecordsAffected,adCmdText);

                if (!pRecord->BOF)
                {
                        pRecord->MoveFirst();
                }
                else
                {               
                        if(pRecord != NULL)
                        {                               
                                if(pRecord->State)
                                {
                                        pRecord->Close();
                                }
                                pRecord = NULL;
                        }
                        return false;                               
                }
                int iComIndex = 0;
                while(!pRecord->adoEOF)
                {
                        string strAreaID = GetDBValueByFieldName("AREAID", pRecord);
                        string strTerm = GetDBValueByFieldName("TERM", pRecord);
                       
                        SendCommannd2NionServer(strAreaID, "0");
                        string strSQLUpdate;
                        strSQLUpdate= "update "+g_strAREAINFO+" set begin=null,pri=null,QROW_ID=null where areaid='"+strAreaID+"' and TERM='"+g_strTerm+"'";
                        Operate_NO_Log_DBBySQL(strSQLUpdate);

                        pRecord->MoveNext();
                }
                return true;
        }
        catch(_com_error *e)
        {
                char error[256];
                wsprintf(error,"%s",e->ErrorMessage());
                DebugMessageBox(error);

                return false;
        }
        catch (...)
        {
                //WriteSYSCatchLog(strSQL);
                return false;
        }

        */
        return false;

}

bool CreatesocketConnect()
{
connectagain:       
        if ((g_socketNionClient = socket(AF_INET,SOCK_STREAM,0)) == -1)
        {
                return false;
        }

        struct sockaddr_in Remote;
        bzero(&Remote, sizeof(Remote));
        Remote.sin_family = AF_INET;
        Remote.sin_port = htons((u_short)g_lNionPort);
        Remote.sin_addr.s_addr = inet_addr(g_strNionServerIP.c_str());
        //inet_pton(AF_INET, g_strNionServerIP.c_str(), &Remote.sin_addr);
       
        int ret = connect(g_socketNionClient,(struct sockaddr*)&Remote,sizeof(Remote));
        if(ret == -1)
        {
                WriteFileLogInfo_Nion("NION client: TRYING TO RECONNECT TO NION Server...");
                boost::this_thread::sleep(boost::posix_time::seconds(g_lNionReconnectTime));
                goto connectagain;
        }       

        if(!LoginServer(g_strNionClientUserName, g_strNionClientPassWord))
        {
                WriteFileLogInfo_Nion("NION client: login on the NION server failured!");
                close(g_socketNionClient);
                g_bNionClientConnected = false;
                goto connectagain;
        }

        struct timeval timeout = {g_lNionSockTimeOut+10,0};
        cout<<setsockopt(g_socketNionClient, SOL_SOCKET, SO_RCVTIMEO, (char*)&timeout, sizeof(timeout));
        cout<<setsockopt(g_socketNionClient, SOL_SOCKET, SO_SNDTIMEO, (char*)&timeout, sizeof(timeout));

        WriteFileLogInfo_Nion("NION Client: Connect to the NION server successfully!");
        g_bNionClientConnected = true;
        return true;
}

bool LoginServer(const string& user,const string& password)
{
        char connStr[256];

        strcpy(connStr, user.c_str());
        strcat(connStr, "\r");
        strcat(connStr, password.c_str());
        strcat(connStr, "\r\n");

        if (g_socketNionClient < 0)
        {
                return false;
        }

        int sendFlag = send(g_socketNionClient,connStr, strlen(connStr), MSG_DONTROUTE);
        if(sendFlag == -1)
        {
                WriteFileLogInfo_Nion("NION Client: Send user and pass error");
                return false;
        }

        return true;
}

bool SendCommannd(const string& strMess)
{
        if (strMess.size() <= 0 || g_socketNionClient ==-1)
        {
                WriteFileLogInfo_Nion("NION Client: strMess.size() <= 0 || g_socketNionClient == 0");
                return false;
        }

        int sendFlag = send(g_socketNionClient,strMess.c_str(), strMess.size(), MSG_DONTROUTE);
        if(sendFlag == -1)
        {
                string strLog = "NION Clinet:SendCommannd  error! [";
                strLog += strMess;
                strLog += "]";
                WriteFileLogInfo_Nion(strLog.c_str());
                return false;
        }
        return true;               
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

¢好甜 2022-10-22 10:05:28

看你是如何寫代碼的了。

乜一 2022-10-22 10:05:28

没看到断开的代码啊,那就是一直连着撒

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文