3

UNIXの下で、cのサーバーコード用に次のコードがあります。

/* A simple server in the internet domain using TCP
   The port number is passed as an argument */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h> 
#include <sys/socket.h>
#include <netinet/in.h>

void error(const char *msg)
{
    perror(msg);
    exit(1);
}

int main(int argc, char *argv[])
{
     int sockfd, newsockfd, portno;
     socklen_t clilen;
     char buffer[256];
     struct sockaddr_in serv_addr, cli_addr;
     int n;
     if (argc < 2) {
         fprintf(stderr,"ERROR, no port provided\n");
         exit(1);
     }
     sockfd = socket(AF_INET, SOCK_STREAM, 0);
     if (sockfd < 0) 
        error("ERROR opening socket");
     bzero((char *) &serv_addr, sizeof(serv_addr));
     portno = atoi(argv[1]);
     serv_addr.sin_family = AF_INET;
     serv_addr.sin_addr.s_addr = INADDR_ANY;
     serv_addr.sin_port = htons(portno);
     if (bind(sockfd, (struct sockaddr *) &serv_addr,
              sizeof(serv_addr)) < 0) 
              error("ERROR on binding");
     listen(sockfd,5);
     clilen = sizeof(cli_addr);
     newsockfd = accept(sockfd, 
                 (struct sockaddr *) &cli_addr, 
                 &clilen);
     if (newsockfd < 0) 
          error("ERROR on accept");
     bzero(buffer,256);
     n = read(newsockfd,buffer,255);
     if (n < 0) error("ERROR reading from socket");
     printf("Here is the message: %s\n",buffer);
     n = write(newsockfd,"I got your message",18);
     if (n < 0) error("ERROR writing to socket");
     close(newsockfd);
     close(sockfd);
     return 0; 
}

このコードはhereから取得しました。

私はポートでコードを実行します8888 私の質問は、bashでこれらのコマンドを実行したときになぜそれが表示されないのかということです:

netstat -a | grep 8888

また

ifconfig -a | grep 8888

しかし、もしそうなら:

sudo cat /etc/services | grep 8888

私はそれを見ることができます。

それを見るために使用できる他の関連シェルコマンドはありますか?

4

3 に答える 3

5

ポート8888が/etc/servicesファイルにリストされている場合netstatは、ポート番号をそこに指定されている名前に置き換えます。grepこれが見つからない理由です。-nフラグを使用してこれをオフにすることができます。

$ netstat -a
...
tcp        0      0 *:ssh                   *:*                     LISTEN     
...
$ netstat -an
...
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
...

私は通常、netstat -lpn -t tcpリッスンしているTCPソケットのみを表示するために使用します。その場合、リストは通常​​、私の目を使ってgrepするのに十分短いです。フラグは、-pどのプログラムがリッスンしているかを示します。これは多くの場合役立ちます。

于 2012-06-16T08:24:15.373 に答える
1

Thomasの発言に加えて、 ifconfigには、マシン上で開いているポートを識別するメカニズムがあったとは思いません。これは、インターフェイス構成用のユーティリティであり、サービス/ポートの公開用ではありません。また、ソケットを開くことと/etc/servicesの間に動的な関係はありません。後者は既知の (通常の) ポート マッピングを記述する静的ファイルであるためです。つまり、ネットワーク機能を使用してコードを実行しても、前述のファイルは変更されません。 .

以下を使用できます。

lsof-に

また

lsof-ni:8888

目的のポートのステータスを直接識別するため。

于 2012-06-16T08:30:05.670 に答える
1

あなたが使用することができます

netstat -na

代わりは

于 2012-06-16T21:25:25.400 に答える