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; 
}

我从这里拿了这段代码。

我在端口上运行代码8888 我的问题是为什么我在 bash 中运行这些命令时看不到它:

netstat -a | grep 8888

或者

ifconfig -a | grep 8888

但如果我这样做:

sudo cat /etc/services | grep 8888

我能看到它。

我可以使用其他任何相关的 shell 命令来查看它吗?

4

3 回答 3

5

/etc/services如果您的文件中列出了端口 8888 ,则将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 -ni

或者

lsof -ni:8888

用于所需端口的直接状态识别。

于 2012-06-16T08:30:05.670 回答
1

您可以使用

netstat -na

反而

于 2012-06-16T21:25:25.400 回答