1

そこで、Socketappender と本質的に同じことを行う Log4J 用のカスタム アペンダーを作成しましたが、TCP ではなく UDP を使用します。ただし、ログに日付を表​​示することはできません。.properties ファイルに問題があるのではないかと思いますが、何が原因かわかりません。特に、テストプログラムがどのアペンダーを使用するかを知る方法であるため、.properties ファイルがある程度機能していることを知っているためです。ただし、.properties ファイルで指定されたレイアウトを使用していません。どんな助け/提案も大歓迎です!

アペンダーコード:

import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.net.UnknownHostException;

import org.apache.log4j.AppenderSkeleton;

import org.apache.log4j.spi.LoggingEvent;


public /*static*/ class UDPAppender extends AppenderSkeleton {

    @Override
protected void append(LoggingEvent event) {
        String message = null;
            event.getProperties();
            StringBuilder formatedMessage = new StringBuilder();
            formatedMessage.append("Level:");
            formatedMessage.append(event.getLevel());
            formatedMessage.append(", FILE:");
            formatedMessage.append(event.getLocationInformation().getFileName());
            formatedMessage.append(", Thread Id:");
            formatedMessage.append(event.getLocationInformation().getLineNumber());
            formatedMessage.append(", ERROR: ");
            formatedMessage.append(event.getMessage().toString());
            message = formatedMessage.toString();
            DatagramSocket clientSocket = null;
            //creating DatagramSocket to send logger info to socket; if not created, will print Stack Trace
            try {
                clientSocket = new DatagramSocket();
            } catch (SocketException e) {
                e.printStackTrace();
            }
            InetAddress IPAddress = null;
            //get InetAddress for sending packet
            try {
                IPAddress = InetAddress.getByName("localhost");
            } catch (UnknownHostException e) {
                e.printStackTrace();
            }
            byte[] sendData = new byte[1024];

            sendData = message.getBytes(); //convert from String to bytes so that message can be sent through datagrampacket
            DatagramPacket sendPacket = new DatagramPacket(sendData, sendData.length, IPAddress, 27770); //address packet
            try {
                clientSocket.send(sendPacket); //send packet to the socket addressed above
            } catch (IOException e) {
                e.printStackTrace();
            }
            clientSocket.close(); //need to close 
}

public void close()     {
}

public boolean requiresLayout()    {
    return true;
}



}

テストコード:

import org.apache.log4j.*;
public class Tester {   
private static final Logger log2 = Logger.getLogger("REMOTE");

public static void main(String[] args) { 
    //configures using the .properties file user creates
    PropertyConfigurator.configure("log4j.properties");
    log2.info("This is info message");   
    System.out.println("Logging complete"); 
    //prints to console to let user know logging completed successfully
    LogManager.shutdown();
    //closes logs once logging is complete
    }
}

.properties ファイル:

log4j.logger.REMOTE=DEBUG, REMOTE
log4j.appender.REMOTE=custom.UDPAppender
log4j.appender.REMOTE.layout=org.apache.log4j.PatternLayout 
log4j.appender.REMOTE.layout.ConversionPattern=%d{MMMM dd HH:mm:ss}, %d{yyyy} %F %L %m %t
4

1 に答える 1

0

実際には、次のコードを使用してタイムスタンプを日付/時刻に変換できました。

long date = event.getTimeStamp();
Date dateObj = new Date(date);
DateFormat df = new SimpleDateFormat("MM-dd-yyyy HH:mm:ss");
StringBuilder formatedMessage = new StringBuilder();
            formatedMessage.append("Time:");
            formatedMessage.append(df.format(dateObj));
于 2013-07-12T20:00:20.983 に答える