2

有没有办法在 C++ 代码中向远程系统日志发送消息?

相当于 linux 命令中的这一行:

nc -w0 -u 192.168.1.1 514 <<< "logging from remote"

这段代码应该用套接字做一些事情,但它不起作用。

int main(int argc, char *argv[])
{
int listenfd = 0, connfd = 0,n;
struct sockaddr_in serv_addr;
    struct hostent *server;


char sendBuff[1025];
sprintf(sendBuff,"bla bla");

time_t ticks; 

listenfd = socket(AF_INET, SOCK_DGRAM , 0);
memset(&serv_addr, '0', sizeof(serv_addr));
memset(sendBuff, '0', sizeof(sendBuff)); 

serv_addr.sin_family = AF_INET;
server = gethostbyname("192.168.1.108");
bcopy((char *)server->h_addr, (char *)&serv_addr.sin_addr.s_addr, server->h_length);

//serv_addr.sin_addr.s_addr = INADDR_ANY;
serv_addr.sin_port = htons(514); 

    if ((n=connect(connfd,(const sockaddr*)&serv_addr,sizeof(serv_addr))) < 0){
            printf(" Connection to has failed Server ");
    }


bind(listenfd, (struct sockaddr*)&serv_addr, sizeof(serv_addr)); 

listen(listenfd, 10); 

while(1)
{
    connfd = accept(listenfd, (struct sockaddr*)NULL, NULL); 

    write(connfd, sendBuff, strlen(sendBuff)); 

    close(connfd);
    sleep(60);
}

}

4

2 回答 2

4

在包括 Linux 在内的几个 Unix 上,您可以简单地使用客户端命令http://linux.die.net/man/3/syslog并安装当前的 syslog 服务器,例如 syslog-ng。该服务器不仅可以根据您的规则过滤消息,还可以将它们发送到任何远程系统日志。

如果您在 Windows 上,恐怕您必须实现自己的 syslog 协议。幸运的是,它并没有那么困难,而且或多或少是有定义的。

于 2013-06-12T13:38:47.633 回答
1

nc -u只是通过 UDP 套接字发送数据。它没有什么特别之处,没有要遵循的特定协议:它只是原始数据。您可以简单地通过 C++ 中的 UDP 套接字发送消息(参见参数socketAF_INET, SOCK_DGRAM其他相关函数)。

但这意味着您会错过许多 syslog 的功能,例如设施和优先级。

@Moose 是对的:syslogAPI 更符合您的需求,因为它更加灵活(如果您想更改行为,无需修改程序,您只需重新配置 syslog 守护程序)。

于 2013-06-12T13:45:06.603 回答