C++实现测试某个服务是否处于监听状态或某个端口是否可用

57 篇文章 0 订阅
3 篇文章 0 订阅

测试某个服务是否处于监听状态,还可以测试某个端口是否可用

#include <iostream>
#include <fstream>
#include <vector>
#include <iterator>
#include <algorithm>
#include <string>
#include <future>
#include <cstring>
#include <sys/socket.h>
#include <netdb.h>
#include <arpa/inet.h>
#include <unistd.h>

std::string isPortOpen(const std::string &domain, const std::string &port)
{
    addrinfo *result;
    addrinfo hints{}; 
    hints.ai_family = AF_UNSPEC;   // either IPv4 or IPv6
    hints.ai_socktype = SOCK_STREAM; 
    char addressString[INET6_ADDRSTRLEN];
    const char *retval = nullptr;
    if (0 != getaddrinfo(domain.c_str(), port.c_str(), &hints, &result)) {
        return "";
    }
    for (addrinfo *addr = result; addr != nullptr; addr = addr->ai_next) {
        int handle = socket(addr->ai_family, addr->ai_socktype, addr->ai_protocol);
        if (handle == -1) {
            continue;
        }
        if (connect(handle, addr->ai_addr, addr->ai_addrlen) != -1) {
            switch(addr->ai_family) {
                case AF_INET:
                    retval = inet_ntop(addr->ai_family, &(reinterpret_cast<sockaddr_in *>(addr->ai_addr)->sin_addr), addressString, INET6_ADDRSTRLEN);
                    break;
                case AF_INET6:
                    retval = inet_ntop(addr->ai_family, &(reinterpret_cast<sockaddr_in6 *>(addr->ai_addr)->sin6_addr), addressString, INET6_ADDRSTRLEN);
                    break;
                default:
                    // unknown family
                    retval = nullptr;
            }
            close(handle);
            break;
        }
    }
    freeaddrinfo(result);
    return retval==nullptr ? "" : domain + ":" + retval + "\n";
}

//如果返回true,则说明,某个服务处于监听状态,同时说明这个端口号已经被这个服务所占用,
//不能再被其他服务所用
bool isListening(const std::string &ip, const std::string &port){
  std::string addr = isPortOpen(ip, port);
  if(addr.empty()){
    return false;
  }
  return true;
}

int main(){
  std::string ip = "10.136.127.23";
  std::string port = "6056";
  if(isListening(ip, port)){
    std::cout << "server is listening" << std::endl;
  }else{
    std::cout << "server closing" << std::endl;
  }
}

参考资料

https://codereview.stackexchange.com/questions/155755/simple-and-effective-port-checker-in-c

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 下面是一个使用 C 语言监听 RPC 服务程序状态是否崩溃或掉线的简单示例代码: ``` #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <errno.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #define PORT 50000 #define BUFSIZE 1024 int main(int argc, char* argv[]) { int sockfd; struct sockaddr_in server_addr; /* 创建套接字 */ sockfd = socket(AF_INET, SOCK_STREAM, 0); if (sockfd < 0) { printf("Error creating socket: %s\n", strerror(errno)); exit(1); } /* 设置服务器地址 */ memset(&server_addr, 0, sizeof(server_addr)); server_addr.sin_family = AF_INET; server_addr.sin_port = htons(PORT); server_addr.sin_addr.s_addr = inet_addr("127.0.0.1"); /* 连接服务器 */ if (connect(sockfd, (struct sockaddr*) &server_addr, sizeof(server_addr)) < 0) { printf("Error connecting to server: %s\n", strerror(errno)); exit(1); } char buffer[BUFSIZE]; int num_bytes_received; /* 不断接收服务器的数据 */ while (1) { num_bytes_received = recv(sockfd, buffer, BUFSIZE, 0); if (num_bytes_received < 0) { printf("Error receiving data: %s\n", strerror(errno)); close(sockfd); exit(1); } else if (num_bytes_received == 0) { printf("Server disconnected.\n"); close(sockfd); break; } else { buffer[num_bytes_received] = '\0'; printf("Received: %s\n", buffer); } } return 0; } ``` 这段代码创建了一个客户端,并连接到服务器 `127.0.0.1` 的 `50000` 端口。然后,它不断地从服务器接收数据。 ### 回答2: 要编写一个C程序来监听RPC服务程序的状态是否崩溃或掉线,我们可以使用Socket编程以及心跳机制来实现。 首先,创建一个C程序,其中包含一个主函数和一个子函数。在主函数中,我们需要创建一个Socket对象,并设置Socket的地址和端口号,以便与RPC服务程序建立连接。 在子函数中,我们可以使用心跳机制来监听RPC服务程序的状态。心跳机制是指定时发送一个特定的请求,用于检测远程主机是否正常工作。我们可以定时向RPC服务程序发送一个心跳请求,如果在规定的时间内未收到回复,则可以认为RPC服务程序已崩溃或掉线。 具体实现中,我们可以使用Socket的发送和接收函数来发送心跳请求并等待回复。如果在规定的时间内没有收到回复,则可以认为服务程序已经崩溃或掉线。此时,我们可以触发相应的操作,如发送警报通知管理员或进行自动恢复等。 在实际编写过程中,还需注意处理异常情况,如网络连接失败、Socket函数调用出错等。可以使用try-catch来捕获异常并进行适当的处理,如输出错误信息或进行重连等。 总之,以上是一个关于监听RPC服务程序状态的C程序的基本框架。具体实现中,还需要根据具体的需求和环境进行调整和完善。 ### 回答3: 要编写一个C程序来监听RPC服务程序的状态是否崩溃或者掉线,可以采用以下步骤: 1. 引入必要的头文件和库文件,如<stdio.h>和<rpc/rpc.h>。 2. 定义RPC服务的结构体和函数原型。根据实际的RPC服务程序定义相应的结构体和函数原型,并确保程序能够连接到RPC服务。 3. 创建一个死循环来实时监测RPC服务程序的状态。可以使用while循环,使程序不停地进行状态检测。 4. 在循环中使用RPC函数来检测服务状态。可以通过调用适当的RPC函数来检查服务程序是否崩溃或掉线。例如,可以使用rpc_call()函数来向RPC服务程序发送一个心跳信号,并等待响应。如果没有收到响应或者收到了错误响应,就说明服务崩溃或掉线。 5. 根据检测结果采取相应的操作。当程序发现RPC服务程序崩溃或掉线时,可以记录错误日志、发送警报或者采取其他适当的措施。 6. 添加适当的延时。为了避免程序过于频繁地检测,可以在循环中添加适当的延时,以降低资源消耗。 7. 编译并运行程序。将代码编译为可执行文件,并在服务器上运行该程序,即可开始监听RPC服务程序的状态。 总结:编写一个C程序来监听RPC服务程序状态是否崩溃或掉线,关键是通过循环实时检测服务状态,并根据检测结果采取相应的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值