日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Linux網(wǎng)絡編程:端口號監(jiān)聽方法大揭秘(linux如何監(jiān)聽的端口號)

隨著互聯(lián)網(wǎng)的發(fā)展,網(wǎng)絡編程已經(jīng)成為一種非常重要的編程形式。在網(wǎng)絡編程中,端口號的監(jiān)聽是非常關鍵的一個環(huán)節(jié)。本文將從基礎開始,詳細介紹Linux網(wǎng)絡編程中的端口號監(jiān)聽方法,包括常見的TCP和UDP協(xié)議。

在云州等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站設計、網(wǎng)站建設 網(wǎng)站設計制作按需設計網(wǎng)站,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,品牌網(wǎng)站制作,營銷型網(wǎng)站建設,外貿(mào)網(wǎng)站制作,云州網(wǎng)站建設費用合理。

一、什么是端口號

在計算機網(wǎng)絡中,端口號是指一個16位的無符號整數(shù),用于標識一臺計算機的特定進程。每個進程都可以打開(也就是綁定)一個或多個端口號并監(jiān)聽該端口號,以便能夠接收來自其他計算機上的請求消息。

例如,HTTP服務器通常會使用端口號80,F(xiàn)TP服務器通常會使用端口號21,TP郵件服務器通常會使用端口號25等等。當客戶端發(fā)送請求消息時,它需要指定目標端口號,并將請求發(fā)送到目標計算機的該端口號。

二、TCP協(xié)議的端口號監(jiān)聽

TCP協(xié)議是一種基于連接的面向流的一對一傳輸協(xié)議。在TCP協(xié)議中,端口號的監(jiān)聽是非常重要的,因為它決定了客戶端和服務器之間的通信。

在Linux中,使用socket()函數(shù)創(chuàng)建一個我們所期望的監(jiān)聽的socket。然后,使用bind()綁定端口號和IP地址(如果想要監(jiān)聽所有IP地址,則可以使用通配符IP地址)。使用listen()函數(shù)監(jiān)聽指定端口,以便可以接收新的連接請求。

下面是TCP協(xié)議的端口號監(jiān)聽的代碼示例:

“`C++

#include

#include

#include

#include

#include

#include

#define PORT 8080

#define BUF_SIZE 1024

int mn(int argc, char const *argv[])

{

int server_fd, new_socket;

struct sockaddr_in address;

int addrlen = sizeof(address);

char buffer[BUF_SIZE] = {0};

char *hello = “Hello from server”;

// 創(chuàng)建TCP socket

if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0)

{

perror(“socket fled”);

exit(EXIT_FLURE);

}

address.sin_family = AF_INET;

address.sin_addr.s_addr = INADDR_ANY;

address.sin_port = htons( PORT );

// 綁定socket

if (bind(server_fd, (struct sockaddr *)&address, sizeof(address))

{

perror(“bind fled”);

exit(EXIT_FLURE);

}

// 監(jiān)聽端口號

if (listen(server_fd, 3)

{

perror(“l(fā)isten fled”);

exit(EXIT_FLURE);

}

if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen))

{

perror(“accept fled”);

exit(EXIT_FLURE);

}

// 接收消息

read( new_socket , buffer, BUF_SIZE);

printf(“%s\n”,buffer );

// 發(fā)送消息

send(new_socket , hello , strlen(hello) , 0 );

printf(“Hello message sent\n”);

return 0;

}

“`

在上面的代碼中,我們使用了socket()函數(shù)創(chuàng)建了一個TCP協(xié)議的socket。然后使用bind()函數(shù)將socket和端口號綁定起來,并使用listen()函數(shù)將端口號設置為監(jiān)聽狀態(tài),以便接受來自客戶端的連接請求。

使用accept()函數(shù)接受連接請求,并使用send()函數(shù)發(fā)送數(shù)據(jù)。最后使用close()函數(shù)關閉socket。

三、UDP協(xié)議的端口號監(jiān)聽

UDP協(xié)議是一種基于無連接的面向消息的協(xié)議。與TCP協(xié)議不同,UDP協(xié)議不需要在傳輸前建立連接,因此也不需要進行端口號的監(jiān)聽。但是,如果我們希望接收來自客戶端的UDP數(shù)據(jù)包,則必須要綁定一個固定的端口號或使用通配符IP地址。

在Linux中,使用socket()函數(shù)創(chuàng)建UDP socket。然后使用bind()函數(shù)指定綁定的端口號,這樣就可以接收來自客戶端的數(shù)據(jù)包了。

下面是UDP協(xié)議的端口號監(jiān)聽的代碼示例:

“`C++

#include

#include

#include

#include

#include

#include

#define PORT 8080

#define BUF_SIZE 1024

int mn(int argc, char const *argv[])

{

int server_fd, new_socket;

struct sockaddr_in address;

int addrlen = sizeof(address);

char buffer[BUF_SIZE] = {0};

char *hello = “Hello from server”;

// 創(chuàng)建UDP socket

if ((server_fd = socket(AF_INET, SOCK_DGRAM, 0)) == 0)

{

perror(“socket fled”);

exit(EXIT_FLURE);

}

address.sin_family = AF_INET;

address.sin_addr.s_addr = INADDR_ANY;

address.sin_port = htons( PORT );

// 綁定固定端口號

if (bind(server_fd, (struct sockaddr *)&address, sizeof(address))

{

perror(“bind fled”);

exit(EXIT_FLURE);

}

// 接收消息

recvfrom(server_fd, buffer, BUF_SIZE, 0, (struct sockaddr *)&address, (socklen_t*)&addrlen);

printf(“%s\n”,buffer );

// 發(fā)送消息

sendto(server_fd, hello, strlen(hello), 0, (struct sockaddr *)&address, addrlen);

printf(“Hello message sent\n”);

return 0;

}

“`

在上述代碼中,我們使用了socket()函數(shù)創(chuàng)建了一個UDP協(xié)議的socket。然后使用bind()函數(shù)將socket和固定端口號綁定起來,以便接收來自客戶端的數(shù)據(jù)包。

使用recvfrom()函數(shù)接收來自客戶端的數(shù)據(jù)包,并使用sendto()函數(shù)發(fā)送數(shù)據(jù)包。最后使用close()函數(shù)關閉socket。

四、結論

在Linux網(wǎng)絡編程中,端口號的監(jiān)聽是非常重要的一個環(huán)節(jié)。在TCP協(xié)議中,端口號的監(jiān)聽通常是用于socket服務器接受來自客戶端的連接請求。而在UDP協(xié)議中,端口號的監(jiān)聽則是用于接收來自客戶端的數(shù)據(jù)包。

相關問題拓展閱讀:

  • linux怎么查看進程占用端口

linux怎么查看進程占用端口

1. ss命令簡介

ss 是 Socket Statistics 的縮寫。ss 命令可以用來獲取 socket 統(tǒng)計信息,它顯示的內容和 netstat 類似。但 ss 的優(yōu)勢在于它能夠顯示更多更詳細的有關 TCP 和連接狀態(tài)的信息,而且比 netstat 更快。當服務器的 socket 連接數(shù)量變得非常大時,無論是使用 netstat 命令還是直接 cat /proc/net/tcp,執(zhí)行速度都會很慢。ss 命令利用到了 TCP 協(xié)議棧中 tcp_diag。tcp_diag 是一個用于分析統(tǒng)計的模塊,可以獲得 Linux 內核中之一手的信息,因此 ss 命令的性能會好很多。

ss命令簡介

2. 常用選項

-h, –help 幫助

-V, –version 顯示版本號

-t, –tcp 顯辯唯示 TCP 協(xié)議的 sockets

-u, –udp 顯示攜和培 UDP 協(xié)議的 sockets

-x, –unix 顯示 unix domain sockets,與 -f 選項相同

-n, –numeric 不解析服務的名稱,如 “22” 端口不會顯示成 “ssh”

-l, –listening 只顯示處于監(jiān)聽狀態(tài)的端口

-p, –processes 顯示監(jiān)聽端口的進程(Ubuntu 上需要 sudo)

-a, –all 對 TCP 協(xié)議來說,棚旦既包含監(jiān)聽的端口,也包含建立的連接

-r, –resolve 把 IP 解釋為域名,把端口號解釋為協(xié)議名稱

3. 常見用法

如果不添加選項 ss 命令默認輸出所有建立的連接(不包含監(jiān)聽的端口),包括 tcp, udp, and unix socket 三種類型的連接:

3.1 查看前5名的連接:

Netid State Recv-Q Send-Q Local Address:Port Peer Address:Port

u_str ESTAB 0 0 **

u_str ESTAB 0 0 **

u_str ESTAB 0 0 **

u_str ESTAB 0 0 /run/dbus/system_bus_socket* 18591

3.2 查看主機的監(jiān)聽端口

State Recv-Q Send-Q Local Address:Port Peer Address:Port

LISTEN.0.0.1:9016 :

LISTEN.0.0.1:9017 :

LISTEN.0.0.1:25 :

LISTEN.0.0.1:9018 :

LISTEN.0.0.1:1723 :

LISTEN.0.0.1:9019 :

3.3 linux查看tcp連接

ESTAB 0 0 ::1:ssh ::1:53238

ESTAB 0 0 ::1:53278 ::1:ssh

ESTAB 0 0 ::1:ssh ::1:53280

ESTAB 0 0 ::1:53288 ::1:ssh

ESTAB 0 0 ::1:ssh ::1:53296

ESTAB 0 0 ::1:53294 ::1:ssh

ESTAB 0 0 ::1:48456 ::1:ssh

ESTAB 0 0 ::1:53286 ::1:ssh

ESTAB 0 0 ::1:53292 ::1:ssh

ESTAB 0 0 ::1:ssh ::1:53272

linux查看tcp連接

3.4 解析IP和端口號

使用-r選項

State Recv-Q Send-Q Local Address:Port Peer Address:Port

LISTENmy_public_ip:9016 :

LISTENmy_public_ip:9017 :

LISTENlocalhost:tp :

LISTENmy_public_ip:9018 :

LISTENmy_public_ip:pptp :

LISTENmy_public_ip:9019 :

linux查看監(jiān)聽端口

3.5 輸出時帶進程名稱

使用-p選項

Total: 2340 (kernel 2365)

TCP: 2126 (estab 72, closed 23, orphaned 1, synrecv 0, timewait 2/0), ports 0

Transport Total IP IPv6

3.6 根據(jù)條件過濾輸出結果

可以通過語法過濾輸出結果,根據(jù)源IP、源端口、目標IP、目標端口

src源

dst目標

ss dst 172.16.26.33

ss dst 172.16.26.43:http

ss dst 172.16.26.43:443

3.7 根據(jù)源端口號范圍輸出:

根據(jù)目標端口號范圍輸出:

ss dport OP PORT

OP 可以代表以下任意一個:

=ge大于或等于某個端口號==eq等于某個端口號!=ne不等于某個端口號>gt大于某個端口號

比如:

輸出源端口號小于8080的連接狀態(tài)

或者

3.8 根據(jù)TCP 的狀態(tài)進行過濾

ss命令還可以根據(jù)TCP連接的狀態(tài)進行過濾,支持的 TCP 協(xié)議中的狀態(tài)有:

established

syn-sent

syn-recv

fin-wait-1

fin-wait-2

time-wait

closed

close-wait

last-ack

listening

closing

除了上面的 TCP 狀態(tài),還可以使用下面這些狀態(tài):

狀態(tài)輸出結果

all輸出所有TCP狀態(tài)。connected輸出已經(jīng)建立連接的TCP狀態(tài)。synchronized輸出同步狀態(tài)的連接。bucket輸出maintained的狀態(tài),如:time-wait 和 syn-recv。big輸出與bucket相反的狀態(tài)。

只輸出ipv4狀態(tài):

只輸出ipv6狀態(tài):

輸出ipv4監(jiān)聽狀態(tài):

3.9 根據(jù)TCP狀態(tài)和端口號進行過濾

輸入出ipv4協(xié)議下的ssh監(jiān)聽狀態(tài):

或者

要么使用轉義小括號,要么使用單引號

查看所有已經(jīng)建立TCP三次握手的HTTP連接:

查看所有正在進程的ssh連接:

4. 總結

ss 命令功能豐富并且性能出色,完全可以替代 netsate 命令。已經(jīng)成為我們日常查看 socket 相關信息的利器。未來netstat已經(jīng)慢慢被ss取代。

關于linux如何監(jiān)聽的端口號的介紹到此就結束了,不知道你從中找到你需要的信息了嗎 ?如果你還想了解更多這方面的信息,記得收藏關注本站。

香港服務器選創(chuàng)新互聯(lián),2H2G首月10元開通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務提供商,擁有超過10年的服務器租用、服務器托管、云服務器、虛擬主機、網(wǎng)站系統(tǒng)開發(fā)經(jīng)驗。專業(yè)提供云主機、虛擬主機、域名注冊、VPS主機、云服務器、香港云服務器、免備案服務器等。


當前文章:Linux網(wǎng)絡編程:端口號監(jiān)聽方法大揭秘(linux如何監(jiān)聽的端口號)
當前網(wǎng)址:http://www.5511xx.com/article/cdcjpeh.html