導航:首頁 > 編程系統 > linuxclienttcp斷開

linuxclienttcp斷開

發布時間:2021-12-09 06:50:14

linux系統下的c語言的網路socket的編程,作為client端去連接伺服器段,為什麼之間會突然斷開!求高手指點!

在出錯函數(socket)後抄面用printf("%m\n");列印出來襲可以知道出錯的原因
%m表示errno和strerror(errno)
或者不怕麻煩的話添加頭文件<error.h>
然後還是在出錯的函數socket()後面添加列印信息printf("%d|%s\n", error, strerror(errno));
error表示該函數的出錯碼,後面的表示英文解釋,具體的可以在linux下用慢查找

雖然這個辦法笨了點。但是我只會這種方法....

你有抓包看了嗎 linux下用tcpmp -w抓到本地來看 本地用wireshark抓 一抓包啥東西都清清楚楚

Ⅱ 如何判斷TcpClient已斷開連接

Socket在連接以後,如果客戶端非正常退出,比如網線掉了、超時退出等,伺服器端的socket仍然有緩存,此時可以從該socket描述符中讀出一些數據,短時間內甚至可以寫,因此判斷TCP socket是否斷開及其不易,網上有很多方法,都不能精確判斷。本人用select和recv寫了一個,在緩沖區被讀完以後判斷非常管用。這里,recv時使用MSG_PEEK參數,數據不會從緩沖區中清除掉,因此不會影響正常的讀寫。 /* check whether socket is connected. Actually, it is not accurate if the client * crashs and the server don't know about it because the socket buffer is ready. * So the return value '0' doesn't mean the socket is really valid. Of course, * '-1' shows the socket is invalid*/int checksock(int s){fd_set fds; char buf[2]; int nbread; FD_ZERO(&fds); FD_SET(s,&fds); if ( select(s+1, &fds, (fd_set *)0, (fd_set *)0, NULL) == -1 ) { //log(LOG_ERR,"select(): %s\n",strerror(errno)) ;return -1;}if (!FD_ISSET(s,&fds)) { //log(LOG_ERR,"select() returns OK but FD_ISSET not\n") ;return -1;}/* read one byte from socket */

Ⅲ TcpClient為什麼自動斷開

我曾經遇到了而且現在又遇到了呵呵

恩如果你的伺服器端使用線程來處理與客戶端的通信的話,很可能是一次發送數據結束而導致線程結束,於是「遠程主機強迫關閉。。。」,試試在伺服器端傳輸完使用代碼來(close)TcpClient或NetworkStream;
如果不讓斷開,就在關閉程序之前一直用一個while循環取數據(同步方式),或者使用BeginRead 、EndRead循環調用取數據(非同步方式)

Ⅳ 如何在TCP Server端解決出現斷網/斷電後,讓Client端斷開連接

recv 函數收到的數據長度為0,表示對方主動斷開了連接
recv 函數收到的數據長度為0,表示對方主動斷開了連接

Ⅳ linux tcp通信正常斷開和異常斷開分別該如何處理不用心跳機制

TCP 是面向連接的,自己有機制保證數據傳輸
TIMEOUT 不用自己去處理吧

Ⅵ linux中tcp連接斷開重蓮時伺服器應該怎麼處理

斷開重連,還是需要重新建立tcp三次握手,建立連接。

Ⅶ linux在子進程中,client與server進行socket通信,客戶端socket斷開後不能與server連接,求高手指點

在不間斷的建立連接過程中,每一次的連接斷開會經過TCP狀態的time_wait狀態,這個狀態的作用就是版延遲一段時間,然後保證下權一次連接的不會被當成上一次的連接。所以第二次的連接建立時如果沒有經過一段時間第二次的連接會失敗,報錯會顯示address in use這兒就是time_wait狀態。你如果是在不同主機上進行不間斷的連接肯定會出現上面的報錯。

Ⅷ linux socket怎麼檢測斷開

我想通過recv和send的返回值來判斷是否連接異常,但是不成功,下面是我的測試代碼,連接成功後如果我斷開客戶端,那麼服務端不會列印錯誤信息而是等待幾秒後直接終止;如果斷開服務端,客戶端的recv不再阻塞,而且返回值一直是0,請高手指點。

C/C++ code//服務端
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <sys/socket.h>
#include <sys/wait.h>
#define MYPORT 3490 /*定義用戶連接埠*/
#define BACKLOG 10 /*多少等待連接控制*/
int main(int argc, char *argv[])
{
int sockfd, new_fd;/* listen on sock_fd, new connection on new_fd*/
struct sockaddr_in my_addr; /* my address information */
struct sockaddr_in their_addr; /* connector's address information */
int sin_size;
if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
{
perror("socket");
exit(1);
}

int opt = 1;
int len = sizeof(opt);
setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &opt, len);

my_addr.sin_family = AF_INET; /* host byte order */
my_addr.sin_port = htons(MYPORT); /* short, network byte order */
my_addr.sin_addr.s_addr = INADDR_ANY; /* auto-fill with my IP */
bzero(&(my_addr.sin_zero),0); /* zero the rest of the struct */

if (bind(sockfd, (struct sockaddr *)&my_addr, sizeof(struct sockaddr))== -1)
{
perror("bind");
exit(1);
}
if (listen(sockfd, BACKLOG) == -1) {
perror("listen");
exit(1);
}

while(1) { /* main accept() loop */
sin_size = sizeof(struct sockaddr_in);
printf("while\n");
if ((new_fd = accept(sockfd, (struct sockaddr *)&their_addr, &sin_size)) == -1)
{
perror("accept");
continue;
}
printf("server: got connection from %s\n", inet_ntoa(their_addr.sin_addr));

while(1)
{
usleep(10000000);
if (send(new_fd, "Hello, world!\n", 14, 0) == -1)
perror("send");
}
close(new_fd);
exit(0);

}
return 0;
}

C/C++ code//客戶端
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <sys/socket.h>
#include <sys/wait.h>
#include <netdb.h>
#define PORT 3490 /* 客戶機連接遠程主機的埠 */
#define MAXDATASIZE 100 /* 每次可以接收的最大位元組 */
int main(int argc, char *argv[])
{
int sockfd, numbytes;
char buf[MAXDATASIZE];
struct hostent *he;
struct sockaddr_in their_addr; /* connector's address information */
if (argc != 2)
{
fprintf(stderr,"usage: client hostname\n");
exit(1);
}
if ((he=gethostbyname(argv[1])) == NULL)
{ /* get the host info */
herror("gethostbyname");
exit(1);
}

if ((sockfd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
{
perror("socket");
exit(1);
}

their_addr.sin_family = AF_INET; /* host byte order */
their_addr.sin_port = htons(PORT); /* short, network byte order */
their_addr.sin_addr = *((struct in_addr *)(he->h_addr));
bzero(&(their_addr.sin_zero),0); /* zero the rest of the struct */
if (connect(sockfd, (struct sockaddr *)&their_addr,sizeof(struct sockaddr)) == -1)
{
perror("connect");
exit(1);
}
while(1)
{
printf("receiving......\n");
if ((numbytes=recv(sockfd, buf, MAXDATASIZE, 0)) == -1)
{
perror("recv");
exit(1);
}
buf[numbytes] = '\0';
printf("Received: %s\n",buf);
}
close(sockfd);
return 0;
}

另外,在網上看到一種利用TCP協議棧中的KeepAlive探測的方法,下面是我從網上找的用的比較多的一段代碼,這里應該只是設置了一些屬性參數,但不知具體怎樣在通信中檢測斷開,請高手賜教。
C/C++ code#include
……
////KeepAlive實現
//下面代碼要求有ACE,如果沒有包含ACE,則請把用到的ACE函數改成linux相應的介面
int keepAlive = 1;//設定KeepAlive
int keepIdle = 5;//開始首次KeepAlive探測前的TCP空閉時間
int keepInterval = 5;//兩次KeepAlive探測間的時間間隔
int keepCount = 3;//判定斷開前的KeepAlive探測次數

if(setsockopt(s,SOL_SOCKET,SO_KEEPALIVE,(void*)&keepAlive,sizeof(keepAlive)) == -1)
{
ACE_DEBUG ((LM_INFO,
ACE_TEXT ("(%P|%t) setsockopt SO_KEEPALIVE error!\n")));

}

if(setsockopt(s,SOL_TCP,TCP_KEEPIDLE,(void *)&keepIdle,sizeof(keepIdle)) == -1)
{
ACE_DEBUG ((LM_INFO,
ACE_TEXT ("(%P|%t) setsockopt TCP_KEEPIDLE error!\n")));
}

if(setsockopt(s,SOL_TCP,TCP_KEEPINTVL,(void *)&keepInterval,sizeof(keepInterval)) == -1)
{
ACE_DEBUG ((LM_INFO,
ACE_TEXT ("(%P|%t) setsockopt TCP_KEEPINTVL error!\n")));
}

if(setsockopt(s,SOL_TCP,TCP_KEEPCNT,(void *)&keepCount,sizeof(keepCount)) == -1)
{
ACE_DEBUG ((LM_INFO,
ACE_TEXT ("(%P|%t)setsockopt TCP_KEEPCNT error!\n")));
}

Ⅸ 伺服器端與客戶端建立了TCP連接, 但是 Client 並沒有close, server端會主動斷掉TCP連接么

看伺服器端的設置

Ⅹ 檢查tcp 有沒有斷開 linux

client/server端recv:
①對端close(fd)檢測(超時檢測):recv 返回0,說明緩存區數據被讀完,實測兩種情況,對端沒有再發數據,對端fd被關閉了。
通過select超時來檢測,當超時如2s,我們認為對端連接斷開,應關閉本地的fd。
②網線斷開/斷電關機檢測(超時檢測):recv 返回-1,errno == EAGAIN,意為「沒有可讀寫數據,緩沖區無數據」。
所以此時需要select超時檢測,若超時,要麼對端沒有再發數據,要麼對端的網線斷了或者直接斷電了。
超過我們判定為對端不在線,關閉本地的fd。

閱讀全文

與linuxclienttcp斷開相關的資料

熱點內容
日版iphone6維修 瀏覽:369
郵票數據英語怎麼讀 瀏覽:924
linuxshort幾個位元組 瀏覽:410
怎麼查看文件位元組多少 瀏覽:500
男男大尺度電影在線視頻 瀏覽:850
蘋果6p玩王者榮耀卡嗎 瀏覽:395
和諧片網站 瀏覽:966
北京錦平寶網路技術有限公司 瀏覽:791
隔世怨靈片段 瀏覽:235
泰國血腥犯罪暴力電影 瀏覽:227
普陀單抽文件櫃多少錢 瀏覽:569
觀看香港網站 瀏覽:816
文件簽字有效 瀏覽:247
抖音直播電影不侵權的電影有哪些 瀏覽:439
geodatabase資料庫設計 瀏覽:306
如何清除word編號格式 瀏覽:404
鹽城哪裡有學數控編程 瀏覽:954
微信設置不用支付密碼 瀏覽:412

友情鏈接