为什么在 netstat/ifconfig 中看不到服务器运行?

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命令可以用来查看它?
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标志显示哪个程序正在监听,这通常是很有帮助的。


2

你可以使用

netstat -na

取而代之


1
除了Thomas所说的之外,我认为ifconfig没有机制来识别机器上的开放端口:它是一个用于接口配置而不是服务/端口暴露的实用程序。此外,打开套接字和/etc/services之间没有动态关系,因为后者是描述已知(常规)端口映射的静态文件,这意味着具有网络功能的运行代码不会对上述文件进行任何更改。
您可以使用: lsof -ni
或 lsof -ni:8888
直接查看所需端口的状态。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接