Linux中用C语言写系统日志

Linux中用C语言写系统日志

__________________________________________________________________________________________________

Author:冀博

Time :2011/11/24

Emaile:jibo.tiger@gmail.com

声明:本人不反对别人和团体转载本人文章,但请注明出处,3Q。对本文有任何疑问,可直接在

博客中留言或发Emaile和我联系(不保证及时回复,时间有限,敬请原谅)

_________________________________________________________________________________________________

我门在做一些大型项目时候,在编写程序中时会考虑到,如果出现一些异常的时候是直接抛出异常呢,还是将异常写入到日志文件中,提供给系统管理员来查看。以下就针对这两种情况分别介绍在Linux中如何将异常写入日志或者是直接抛出异常。

一.抛出异常

在C语言中抛出异常,是用的最多,也是最简单的。因为我们先来talk下它的使用方法。

1.使用exit()函数来实现抛出异常

1>头文件:#include<stdlib.h>

2>当在程序中碰到异常情况时,可以使用exit(),函数直接退出程序,即抛出异常。

3>exit()函数的参数为EXIT_FAILURE,用来表明程序运行失败。

4>实例:当我们在Linux中当开一个文件失败时,使用exit()函数抛出异常。

#include<stdio.h>

#include<stdlib.h>
#include<sys/types.h>

#include<sys/stat.h>

#include<fcntl.h>

 

int main()

{

     int fd;

     fd  = open(“tiger.c”,O_RDWR);

if( fd < 0){

        perror(“OpenFailed\n”);

        exit(EXIT_FAILURE);

}

}

执行可执行程序后,如下图所示:


二.将异常写入日志文件

有些时候,我们要将调试信息写入到日志文件中去以便系统管理员去查看;而不是直接退出程序。

1.使用syslog(),openlog(),closelog()函数将调试信息写入日志文件中

1>这三个函数openlog, syslog, closelog是一套系统日志写入接口,另外那个vsyslog和syslog功能一样,只是参数格式不同。

2> 通常,syslog守护进程读取三种格式的记录消息。此守护进程在启动时读一个配置文件。一般来说,其文件名为/etc/syslog.conf,该文件决定了不同种类的消息应送向何处。例如,紧急消息可被送向系统管理员(若已登录),并在控制台上显示,而警告消息则可记录到一个文件中。该机制提供了syslog函数,其调用格式如下 
#include <syslog.h> 
void openlog (char*ident,int option ,int facility); 
void syslog(int priority,char*format,……) 
void closelog();

3>调用openlog是可选择的。如果不调用openlog,则在第一次调用syslog时,自动调用openlog。调用closelog也是可选择的,它只是关闭被用于与syslog守护进程通信的描述符。调用openlog 使我们可以指定一个ident,以后, 此ident 将被加至每则记录消息中。ident 一般是程序的名称 。4>openlog及closelog函数说明
此函数原型如下:
void openlog(const char *ident, int option, int facility);
此函数用来打开一个到系统日志记录程序的连接,打开之后就可以用syslog或vsyslog函数向系统日志里添加信息了。而closelog函数就是用来关闭此连接的。

第一个参数ident将是一个标记,ident所表示的字符串将固定地加在每行日志的前面以标识这个日志,通常就写成当前程序的名称以作标记。

第二个参数option是下列值取与运算的结果:LOG_CONS, LOG_NDELAY, LOG_NOWAIT, LOG_ODELAY, LOG_PERROR, LOG_PID,各值意义请参考man openlog手册:

l LOG_CONS:Write directly to system console if there is an error while sendingto system logger.

l LOG_NDELAY:Open the connection immediately (normally, the connection is openedwhen the first message is logged).

l LOG_NOWAIT:Don’t  wait  for  child processes that may have beencreated while logging the message.  (The GNU C library does not create a childprocess, so this option has no effect on Linux.)

l LOG_ODELAY: The converse of LOG_NDELAY; opening of the connection is delayeduntil syslog() is called.  (This is the  default,  and  neednot be specified.)

l LOG_PERROR:(Not in SUSv3.)Print to stderr as well.

l LOG_PID:Include PID with eachmessage.

第三个参数指明记录日志的程序的类型。

5>syslog函数及参数
syslog函数用于把日志消息发给系统程序syslogd去记录,此函数原型是:void syslog(int priority, const char *format, ...);
第一个参数是消息的紧急级别,第二个参数是消息的格式,之后是格式对应的参数。就是printf函数一样使用。

如果我们的程序要使用系统日志功能,只需要在程序启动时使用openlog函数来连接syslogd程序,后面随时用syslog函数写日志就行了。

2.程序实例:


执行程序后,终端运行没有什么反应,但是要用:

tail /var/log/syslog可以查看系统日志信息


转自:http://blog.csdn.net/tigerjibo/article/details/7008581
### 回答1: 以下是 Linux 中使用 C 语言编的简单 socket 编程示例: 服务端代码: ``` #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; } ``` 客户端代码: ``` #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <string.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <netdb.h> void error(const char *msg) { perror(msg); exit(0); } int main(int argc, char *argv[]) { int sockfd, portno, n; struct sockaddr_in serv_addr; struct hostent * ### 回答2: 以下是一个用C语言的简单的Linux socket编程示例: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> // close函数 #include <arpa/inet.h> // htons, inet_pton函数 #include <sys/socket.h> // socket, bind, listen, accept, recv, send函数 #define PORT 8080 #define BUFFER_SIZE 1024 int main() { int server_fd, new_socket, valread; struct sockaddr_in address; int opt = 1; int addrlen = sizeof(address); char buffer[BUFFER_SIZE] = {0}; char *hello = "Hello from server"; // 创建套接字 if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) { perror("Socket creation failed"); exit(EXIT_FAILURE); } // 设置套接字选项,允许地址重复使用 if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR | SO_REUSEPORT, &opt, sizeof(opt))) { perror("Setsockopt failed"); exit(EXIT_FAILURE); } address.sin_family = AF_INET; address.sin_addr.s_addr = INADDR_ANY; address.sin_port = htons(PORT); // 绑定套接字到指定端口 if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0) { perror("Bind failed"); exit(EXIT_FAILURE); } // 监听连接请求 if (listen(server_fd, 3) < 0) { perror("Listen failed"); exit(EXIT_FAILURE); } // 接受连接请求 if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen)) < 0) { perror("Accept failed"); exit(EXIT_FAILURE); } // 接收客户端数据 valread = recv(new_socket, buffer, BUFFER_SIZE, 0); printf("Received: %s\n", buffer); // 向客户端发送消息 send(new_socket, hello, strlen(hello), 0); printf("Hello message sent\n"); // 关闭套接字 close(new_socket); close(server_fd); return 0; } ``` 该示例中创建了一个TCP服务器,会监听在8080端口上。当有客户端连接后,会接收客户端发送的消息,并向客户端发送"Hello from server"消息。最后关闭套接字。 ### 回答3: 在Linux系统中,我们可以使用C语言一个基本的Socket编程示例。以下是一个简单的Server-Client示例,包括了服务器端和客户端的代码。 服务器端代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #define PORT 8080 #define BUFFER_SIZE 1024 int main() { int server_fd, new_socket; struct sockaddr_in address; int addrlen = sizeof(address); char buffer[BUFFER_SIZE] = {0}; char *server_response = "Server is connected!\n"; // 创建Socket if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) { perror("Socket creation failed"); exit(EXIT_FAILURE); } address.sin_family = AF_INET; address.sin_addr.s_addr = INADDR_ANY; address.sin_port = htons(PORT); // 绑定Socket到指定端口 if (bind(server_fd, (struct sockaddr *)&address, sizeof(address))<0) { perror("Binding failed"); exit(EXIT_FAILURE); } // 监听连接 if (listen(server_fd, 3) < 0) { perror("Listening failed"); exit(EXIT_FAILURE); } // 建立连接 if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen)) < 0) { perror("Acceptance failed"); exit(EXIT_FAILURE); } // 发送欢迎消息 send(new_socket, server_response, strlen(server_response), 0); printf("Welcome message sent\n"); // 接收客户端消息并发送回复 while (1) { memset(buffer, 0, sizeof(buffer)); read(new_socket, buffer, BUFFER_SIZE); printf("Client message: %s\n", buffer); send(new_socket, buffer, BUFFER_SIZE, 0); } return 0; } ``` 客户端代码: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #define PORT 8080 #define BUFFER_SIZE 1024 int main() { int sock = 0, valread; struct sockaddr_in serv_addr; char *client_message = "Hello from client"; char buffer[BUFFER_SIZE] = {0}; // 创建Socket if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0) { perror("Socket creation failed"); exit(EXIT_FAILURE); } serv_addr.sin_family = AF_INET; serv_addr.sin_port = htons(PORT); // 将IPv4地址从点分十进制转换为网络字节序 if(inet_pton(AF_INET, "127.0.0.1", &(serv_addr.sin_addr))<=0) { perror("Invalid address or address not supported"); exit(EXIT_FAILURE); } // 连接到服务器 if (connect(sock, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) { perror("Connection failed"); exit(EXIT_FAILURE); } // 发送消息 send(sock, client_message, strlen(client_message), 0); printf("Message sent to server\n"); // 接收回复消息 valread = read(sock, buffer, BUFFER_SIZE); printf("Server message: %s\n", buffer); return 0; } ``` 以上代码示例展示了Linux中使用C语言Socket通信的基本原理。服务器端使用`socket()`函数创建socket,`bind()`函数将socket绑定到指定的端口,`listen()`函数监听连接请求,并使用`accept()`函数接收来自客户端的连接。客户端使用`socket()`函数创建socket,`connect()`函数连接到服务器,并使用`send()`函数发送消息,`read()`函数接收并打印服务器端回复的消息。 以上示例是一个简单的基于TCP协议的Socket通信示例,可以通过编译并在Linux系统上运行进行测试。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值