您的位置:首页 > 编程语言 > Java开发

Java socket编程中的日志处理

2012-11-26 22:06 176 查看
Logger
对象用来记录特定系统或应用程序组件的日志消息。一般使用圆点分隔的层次命名空间来命名 Logger。Logger
名称可以是任意的字符串,但是它们一般应该基于被记录组件的包名或类名,如 java.net
或 javax.swing。此外,可以创建“匿名”的 Logger,其名称未存储在 Logger
命名空间中。
下面演示在Socket通信中使用Logging来进行日志消息.
一、修改系统日志配置文件
在<Java_HOME>\jre1.5.0_09\lib\logging.properties文件,有一个ConsoleHandler:

handlers= java.util.logging.ConsoleHandler
当然也有一个默认的FileHandler:

java.util.logging.FileHandler.pattern = %h/java%u.log
java.util.logging.FileHandler.limit = 50000
java.util.logging.FileHandler.count = 1
java.util.logging.FileHandler.formatter = java.util.logging.XMLFormatter
将handlers= java.util.logging.ConsoleHandler变成如下内容
handlers= java.util.logging.FileHandler, java.util.logging.ConsoleHandler
二、客户端程序
LogTest.java:


package sterning.tcpsocket;

import java.io.*;
import java.util.logging.*;

public class LogTest {
private static Logger logger =
Logger.getAnonymousLogger();
public static void main(String argv[]) throws IOException {
Handler handler = new SocketHandler("localhost", 8099);
logger.addHandler(handler);
logger.log(Level.SEVERE, "Hello, World");
logger.log(Level.INFO, "欢迎您的到来");
}
}


三、服务端程序
LogServer.java:
package sterning.tcpsocket;
import javax.net.ssl.*;
import javax.net.*;
import java.io.*;
import java.net.*;

public class LogServer {
private static final int PORT_NUM = 8099;
public static void main(String args[]) {
ServerSocketFactory serverSocketFactory =
ServerSocketFactory.getDefault();
ServerSocket serverSocket = null;
try {
serverSocket =
serverSocketFactory.createServerSocket(PORT_NUM);
} catch (IOException ignored) {
System.err.println("无法创建服务");
System.exit(-1);
}
System.out.printf("LogServer 运行端口: %s%n", PORT_NUM);
while (true) {
Socket socket = null;
try {
socket = serverSocket.accept();
InputStream is = socket.getInputStream();
BufferedReader br = new BufferedReader(
new InputStreamReader(is, "GBK"));
String line = null;
while ((line = br.readLine()) != null) {
System.out.println(line);
}
} catch (IOException exception) {
// 处理下在个请求.
} finally {
if (socket != null) {
try {
socket.close();
} catch (IOException ignored) {
}
}
}
}
}
}


四、运行结果



内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: