1. 程式人生 > >帶超時時間的telnet該怎麼玩?------檢測tcp是否可連線時經常用到(本文僅給出linux版本,之前部落格也有Windows版本的)

帶超時時間的telnet該怎麼玩?------檢測tcp是否可連線時經常用到(本文僅給出linux版本,之前部落格也有Windows版本的)

        前面說過, 利用ping命令探測網路是否可通, 但很多時候, 服務端或者防火牆禁止了ping命令, 也就是說, ping不通, 不表示網路不通, 所以仍有可能能建立tcp連線。怎麼檢測tcp連線是否可通呢? 用telnet命令就可以搞起, 但問題是, 很多時候(尤其是批量探測的時候), 我們需要給telnet命令設定一個超時時間, 很遺憾, 這是telnet命令所不支援的。 那要怎麼搞? 還是自己寫程式吧, 如下:

#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <errno.h>
#include <malloc.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/ioctl.h>
#include <stdarg.h>
#include <fcntl.h>
#include <time.h>


int telnetCheckTcp(const char *ip, int port, int tSecond)
{
	int sockClient = socket(AF_INET, SOCK_STREAM, 0);
	int iFinal = 0;

	struct sockaddr_in addrSrv;
	addrSrv.sin_addr.s_addr = inet_addr(ip);
	addrSrv.sin_family = AF_INET;
	addrSrv.sin_port = htons(port);

	fcntl(sockClient, F_SETFL, fcntl(sockClient, F_GETFL, 0)|O_NONBLOCK);  
	
	int iRet = connect(sockClient, ( const struct sockaddr *)&addrSrv, sizeof(struct sockaddr_in));  // 返回-1不一定是異常
	if (iRet != 0)	
	{  
		if(errno != EINPROGRESS)
		{
			iFinal = -1;	
		}
		else  
		{
			struct timeval tm = {tSecond, 0}; 
			fd_set wset, rset;	
			FD_ZERO(&wset); 
			FD_ZERO(&rset); 
			FD_SET(sockClient, &wset);	
			FD_SET(sockClient, &rset); 
			int time1 = time(NULL);
			int n = select(sockClient + 1, &rset, &wset, NULL, &tm);  
			int time2 = time(NULL);

			if(n < 0)	
			{  
			    iFinal = -2;	  
			}  
			else if(n == 0)  
			{  
			    iFinal = -3;	  
			}  
			else if (n == 1)  
			{
			   if(FD_ISSET(sockClient, &wset))	
			   {  
				   iFinal = 0;	 
				   fcntl(sockClient, F_SETFL, fcntl(sockClient, F_GETFL, 0) & ~O_NONBLOCK);  
			   }  
			   else  
			   {  
				   iFinal = -4;	
			   }  
			}
			else
			{
				iFinal = -5;	
			}
		}  
	}  

	close(sockClient);
	return iFinal;
}


int main(int argc, char *argv[])
{
	if(argc != 4)
	{
		printf("error\n");
		return -1;
	}

	int iFinal = telnetCheckTcp(argv[1], atoi(argv[2]), atoi(argv[3]));
	printf("iFinal is %d\n", iFinal);

	return 0;
}
        來試下:
[email protected]:~$ ./a.out 220.181.112.244 80 2
iFinal is 0
[email protected]:~$ ./a.out 220.181.112.244 81 2
iFinal is -3
[email protected]:~$ ./a.out 220.181.112.244 443 2
iFinal is 0
[email protected]:~$ ./a.out 220.181.112.244 445 2
iFinal is -3
[email protected]:~$ ./a.out 1.1.1.1 80 2
iFinal is -3
[email protected]
:~$
        

        批量探測怎麼搞呢? 來看看:

#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <errno.h>
#include <malloc.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <sys/ioctl.h>
#include <stdarg.h>
#include <fcntl.h>
#include <time.h>

#include <iostream>
#include <fstream>
using namespace std;


int telnetCheckTcp(const char *ip, int port, int tSecond)
{
	int sockClient = socket(AF_INET, SOCK_STREAM, 0);
	int iFinal = 0;

	struct sockaddr_in addrSrv;
	addrSrv.sin_addr.s_addr = inet_addr(ip);
	addrSrv.sin_family = AF_INET;
	addrSrv.sin_port = htons(port);

	fcntl(sockClient, F_SETFL, fcntl(sockClient, F_GETFL, 0)|O_NONBLOCK);  
	
	int iRet = connect(sockClient, ( const struct sockaddr *)&addrSrv, sizeof(struct sockaddr_in));  // 返回-1不一定是異常
	if (iRet != 0)	
	{  
		if(errno != EINPROGRESS)
		{
			iFinal = -1;	
		}
		else  
		{
			struct timeval tm = {tSecond, 0}; 
			fd_set wset, rset;	
			FD_ZERO(&wset); 
			FD_ZERO(&rset); 
			FD_SET(sockClient, &wset);	
			FD_SET(sockClient, &rset); 
			int time1 = time(NULL);
			int n = select(sockClient + 1, &rset, &wset, NULL, &tm);  
			int time2 = time(NULL);

			if(n < 0)	
			{  
			    iFinal = -2;	  
			}  
			else if(n == 0)  
			{  
			    iFinal = -3;	  
			}  
			else if (n == 1)  
			{
			   if(FD_ISSET(sockClient, &wset))	
			   {  
				   iFinal = 0;	 
				   fcntl(sockClient, F_SETFL, fcntl(sockClient, F_GETFL, 0) & ~O_NONBLOCK);  
			   }  
			   else  
			   {  
				   iFinal = -4;	
			   }  
			}
			else
			{
				iFinal = -5;	
			}
		}  
	}  

	close(sockClient);
	return iFinal;
}


int main(int argc, char *argv[])  // ./a.out ipfilename port timeout
{
	if(argc != 4)
	{
		cout << "error" << endl;
		return -1;
	}

	ifstream in(argv[1]);
	string filename;
	string line;

	unsigned int i = 0;
	if(in) // 有該檔案
	{
		while (getline (in, line)) // line中不包括每行的換行符
		{
			// 這裡最好做ip格式判斷
			i++;
			int iFinal = telnetCheckTcp(line.c_str(), atoi(argv[2]), atoi(argv[3]));
			if(iFinal == 0)
			{
				printf("iFinal is %d, ip is %s,  index is %d\n", iFinal, line.c_str(), i);
			}
			else
			{
				printf("iFinal is %d, cannot connect to %s, index is %d\n", iFinal, line.c_str(), i);
			}
		}
	}
	else // 沒有該檔案
	{
		cout <<"no such file" << endl;
	}

	return 0;
}
       結果:
[email protected]:~$ ./a.out a.txt 443 2
iFinal is 0, ip is 220.181.112.244,  index is 1
iFinal is -3, cannot connect to 1.1.1.1, index is 2
[email protected]:~$ 
[email protected]:~$ 
[email protected]:~$ ./a.out a.txt 80 2
iFinal is 0, ip is 220.181.112.244,  index is 1
iFinal is -3, cannot connect to 1.1.1.1, index is 2
[email protected]:~$ 
[email protected]:~$ 
[email protected]:~$ ./a.out a.txt 100 2
iFinal is -3, cannot connect to 220.181.112.244, index is 1
iFinal is -3, cannot connect to 1.1.1.1, index is 2
[email protected]:~$ 
        搞定。

相關推薦

超時時間telnet怎麼?------檢測tcp是否連線經常本文linux版本之前部落Windows版本

        前面說過, 利用ping命令探測網路是否可通, 但很多時候, 服務端或者防火牆禁止了ping命令, 也就是說, ping不通, 不表示網路不通, 所以仍有可能能建立tcp連線。怎麼檢測tcp連線是否可通呢? 用telnet命令就可以搞起, 但問題是, 很多時

windows超時telnet探測IP和埠

              玩樹莓派由於沒有螢幕,IP可能會跳,這時就不知道自己的樹莓派是哪個IP了,下面可以用這個程式去探測自己樹莓派的IP。其主要思想是:非阻塞的帶超時的connect函式。 #include <stdio.h> #include &l

Java傳送郵件必超時時間配置

前言 只有光頭才能變強。 文字已收錄至我的GitHub倉庫,歡迎Star:https://github.com/ZhongFuCheng3y/3y 在線上遇到了一個傳送郵件的問題,記錄一下。 一、先說背景 某一天,小王跟我反饋:“麻煩檢查一下線上郵件的傳送情況,我這查出來發送失敗啦” 我去DB查了一下

6.你10 分鐘時間根據上排十個數在其下排填對應的十個數

要求下排每個數都是先前上排那十個數在下排出現的次數。上排的十個數如下: 【0,1,2,3,4,5,6,7,8,9】 舉一個例子, 數值: 0,1,2,3,4,5,6,7,8,9 分配: 6,2,1,0,0,0,1,0,0,0 0 在下排出現了6 次,1 在下排出現了2 次,

頁面檢測網路外網連線- 網頁基礎模組JavaScript

方法一  html 新增圖片標籤 載入外站圖片 <img id="connect-test" style="display:none;" onload="conectSuccess()" onerror="conectError()" />

素數距離問題 時間限制:3000 ms | 記憶體限制:65535 KB 難度:2 描述 現在你一些數要求你寫一個程式輸出這些整數相鄰最近的素數並輸出其相距長度。如果左右等距離長度素數

個人理解:判斷輸入的數是不是輸入只要判斷一個數i從2開始到到i*i小於等於輸入的這個數,對於0,1要直接輸出來0,然後找到左右的兩個素數進行比較大小後打印出即可 #include<stdio.h> #include<string.h>#inclu

Linux伺服器和本地主機檢視伺服器埠資訊檢測埠是否連線

(1)本地主機上檢測伺服器埠是否可以連線cmd視窗下輸入以下命令(可以檢視埠能否正常連線,第一個引數是ip地址,第二個引數是埠號):如果出現以下問題:更詳細在本地主機檢測伺服器埠是否可連線的方法可參考:怎樣測試某個埠是否開啟(2)在Linux伺服器檢視本伺服器上的所有埠:伺服

TCP建立/關閉連線握手過程中的狀態情況

一句話總結:深入理解握手中的狀態情況 建立連線的3次握手和關閉連線的4次握手: 狀態轉換: 注:下面狀態轉換說明以客戶端主動關閉為例。 close:表示初始狀態 listen:伺服器端某個socket處於監聽狀態,可以接受客戶端連線 SYN_SENT:客戶端執行c

遞推: 你10分鐘時間根據上排十個數在其下排填對應的十個數 要求下排每個數都是先前上排那十個數在下排出現的次數

騰訊面試題:給你10分鐘時間,根據上排給出十個數,在其下排填出對應的十個數   要求下排每個數都是先前上排那十個數在下排出現的次數。   上排的十個數如下:   【0,1,2,3,4,5,6,7,8,

曹工說面試:當應用依賴jar包的A版本中介軟體jar包依賴B版本兩個版本不相容這還怎麼

# 背景 大一點的公司,可能有一些組,專門做中介軟體的;假設,某中介軟體小組,給你提供了一個jar包,你需要整合到你的應用裡。假設,它依賴了一個日期類,版本是v1;我們應用也依賴了同名的一個日期類,版本是v2. 兩個版本的日期類,方法邏輯的實現,有一些差異。 舉個例子,中介軟體提供的jar包中,依賴如下

Linux 建立 TCP 連線超時時間分析(解惑)

Linux 系統預設的建立 TCP 連線的超時時間為 127 秒,對於許多客戶端來說,這個時間都太長了, 特別是當這個客戶端實際上是一個服務的時候,更希望能夠儘早失敗,以便能夠選擇其它的可用服務重新嘗試。 socket 是 Linux 下實現的傳輸控制層協議,包括 TCP 和 UDP,一個 socket 端

Windows服務系列——Windows服務啟動超時時間

最近有客戶反映,機房出現斷電情況,伺服器的系統重新啟動後,資料庫服務自啟動失敗。第一次遇到這種情況,為了檢視是不是斷電情況導致資料庫檔案損壞,從客戶的伺服器拿到資料庫的日誌,進行分析。 資料庫工作機制 要分析資料庫啟動失敗的原因,首先說明一下資料庫服務的工作機制。 資料庫分為六大服務: 資料庫的六

設定TCP connect超時時間的2種方法

1.常用方法設定socket非阻塞,之後使用select等設定超時時間2.使用alarm訊號量需要注意:執行緒訊號量掩碼是執行緒私有的,當指定程序遞交訊號量時,作業系統會將訊號量遞交至該程序中未遮蔽該訊號量的所有執行緒中的隨機之一。見 man 7 signal:Asignal

Windows上如何非阻塞的connect?---讓程式設計師自定義connect函式的超時時間

        我們知道, 對於阻塞的socket而言, connect函式也是阻塞的, 我在Windows上測試過, 對於阻塞的socket而言, connect的阻塞時間約為25s(linux上是75s吧, 各個平臺都不一樣).  也就是說, 很多時候, 客戶端需要等2

TCP服務端要設定超時時間

socket的setSoTimeOut() 因為呼叫ServerSocket類的accept()方法和Socket輸入流的read()方法時會引起執行緒阻塞,所以應該用 setSoTimeout()方法設定超時,預設的設定是0,即超時永遠不會發生。超時的判斷是累計式

設定linuxtcp預設的20秒connect超時時間

無論你用任何語言或者是網路庫,你都可以設定網路操作的超時時間,特別是connect、read、write的超時時間。 你可以在程式碼中把超時時間設定任意大小值,但是connect方法會有一點特殊。 connect的超時時間在任意的核心實現上都有一個可以設定的最大值,你的

js 處理Json 時間T 時間格式

oca 轉換 上下 格式 logs http asc cond ear 對於後臺傳過來的json數據是帶T時間格式的坑處理的一些做法總結 new Date(data[j].addtime).toISOString().replace(/T/g, ‘ ‘).replace(/

TCP/IP具體解釋》讀書筆記21章TCP超時與重傳

打開 定時器 是否 檢查 例如 技術 blog 信息 全部 TCP提供可靠的運輸層。它使用的方法之中的一個就是確認從還有一端收到的數據。但數據和確認都有可能會丟失。TCP通過在發送時設置一個定時器來解決這樣的問題。假設當定時器溢出時還沒有收到確認,它就重傳該數據。對於實現

CURL超時時間設置

url 地址 輸出 獲得 ket time 完整 nal 進行 一次完整的http請求,一般包含三個步驟: 通過DNS把域名解析成IP 通過IP地址連接到目標主機 獲取目標主機數據(1、給目標主機輸出http請求頭,以\r\n\r\n結尾;2、獲取目標主機傳過來的數據)

設置超時時間項目案例供參考

n) htm click ont mls play .get 放大 .html #設置超時時間爬取網頁速度相對要快些#encoding:utf8from lxml import etree#xpathimport re#正則import time#時間import requ