ホームページ  >  記事  >  運用・保守  >  Linux 聞いてください、それはどういう意味ですか

Linux 聞いてください、それはどういう意味ですか

藏色散人
藏色散人オリジナル
2023-04-21 10:58:082331ブラウズ

linux listen はリッスンすることを意味し、listen はクライアントの TCP ソケットからの接続要求を監視することを指します。listen 関数は通常、bind を呼び出した後、accept を呼び出す前に呼び出され、その関数プロトタイプは「int listen ( int sockfd)」です。 , int バックログ)」。

Linux 聞いてください、それはどういう意味ですか

#このチュートリアルの動作環境: linux5.9.8 システム、Dell G3 コンピューター。

linux 聞く それはどういう意味ですか?

linux での listen 関数

listen: クライアントの TCP ソケットからの接続要求をリッスンします

listen 関数は通常、後ですbinding の呼び出し - accept を呼び出す前の関数プロトタイプは次のとおりです。

#include<sys/socket.h>  
int listen  (  int sockfd,  int backlog  )
パラメータ sockfd は、listen 関数によって動作するソケットです。
パラメータ バックログは次のとおりです。リスニングキューの長さ。 プロセスが接続要求を処理している間、他の接続要求が発生する可能性があります。 TCP 接続はプロセスであるため、半接続状態が存在する場合があり、同時に接続しようとするユーザーが多すぎるために、サーバー プロセスが接続要求を迅速に完了できない場合があります。この状況が発生した場合、サーバー プロセスはカーネルにどのように処理してもらいたいでしょうか?カーネルは、これらの完了した接続を追跡するために独自のプロセス空間にキューを維持しますが、サーバー プロセスはまだその接続 (accept 関数をまだ呼び出していない接続) を引き継いでいません。カーネルはそのようなキューを任意に大きくすることはできません。サイズには上限があります。このバックログは、この値を上限として使用するようにカーネルに指示します。
##戻り値成功失敗エラー番号を設定するかどうか##0

−1

# エラー メッセージ:

EADDRINUSE : 別のソケットも同じポートでリッスンしています。 EBADF: パラメータ sockfd は不正なファイル記述子です。 ENOTSOCK: パラメーター sockfd はファイル記述子ではありません。

EOPNOTSUPP: ソケット タイプはリッスン操作をサポートしていません。



例:

#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>
int main()
{
int sockfd,new_fd;
struct sockaddr_in my_addr;
struct sockaddr_in their_addr;
int sin_size;
//建立TCP套接口
if((sockfd = socket(AF_INET,SOCK_STREAM,0))==-1)
{
printf("create socket error");
perror("socket");
exit(1);
}
//初始化结构体,并绑定2323端口
my_addr.sin_family = AF_INET;
my_addr.sin_port = htons(2323);
my_addr.sin_addr.s_addr = INADDR_ANY;
bzero(&(my_addr.sin_zero),8);
//绑定套接口
if(bind(sockfd,(struct sockaddr *)&my_addr,sizeof(struct sockaddr))==-1)
{
perror("bind socket error");
exit(1);
}
//创建监听套接口  监听队列长度为10
if(listen(sockfd,10)==-1)
{
perror("listen");
exit(1);
}

//等待连接
while(1)
{
sin_size = sizeof(struct sockaddr_in);

printf("server is run./n");
//如果建立连接,将产生一个全新的套接字
if((new_fd = accept(sockfd,(struct sockaddr *)&their_addr,&sin_size))==-1)
{
perror("accept");
exit(1);
}
printf("accept success./n");
//生成一个子进程来完成和客户端的会话,父进程继续监听
if(!fork())
{
printf("create new thred success./n");
//读取客户端发来的信息
int numbytes;
char buff[256];
memset(buff,0,256);
if((numbytes = recv(new_fd,buff,sizeof(buff),0))==-1)
{
perror("recv");
exit(1);
}
printf("%s",buff);
//将从客户端接收到的信息再发回客户端
if(send(new_fd,buff,strlen(buff),0)==-1)
perror("send");
close(new_fd);
exit(0);
}
close(new_fd);
}
close(sockfd);
}

#include <stdio.h>
#include <stdlib.h>

#include <string.h>
#include <netdb.h>
#include <sys/types.h>

#include <sys/socket.h>

int main(int argc,char *argv[])
{

int sockfd,numbytes;
char buf[100];

struct sockaddr_in their_addr;
//int i = 0;
//将基本名字和地址转换


//he = gethostbyname(argv[1]);

//建立一个TCP套接口
if((sockfd = socket(AF_INET,SOCK_STREAM,0))==-1)
{
perror("socket");
printf("create socket error.建立一个TCP套接口失败");
exit(1);
}
//初始化结构体,连接到服务器的2323端口
their_addr.sin_family = AF_INET;
their_addr.sin_port = htons(2323);
// their_addr.sin_addr = *((struct in_addr *)he->h_addr);
inet_aton( "127.0.0.1", &their_addr.sin_addr );


bzero(&(their_addr.sin_zero),8);
//和服务器建立连接
if(connect(sockfd,(struct sockaddr *)&their_addr,sizeof(struct sockaddr))==-1)
{
perror("connect");
exit(1);
}
//向服务器发送数据
if(send(sockfd,"hello!socket.",6,0)==-1)
{
perror("send");
exit(1);
}
//接受从服务器返回的信息
if((numbytes = recv(sockfd,buf,100,0))==-1)
{
perror("recv");
exit(1);
}
buf[numbytes] = &#39;/0&#39;;
printf("Recive from server:%s",buf);
//关闭socket
close(sockfd);

return 0;
}

推奨学習: 「linux ビデオ チュートリアル

以上がLinux 聞いてください、それはどういう意味ですかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。