SLF4J - Göçmen

Jakarta Commons Logging (JCL) veya, log4j veya java.util.logging'de (JUL) bir projeniz varsa ve bu projeleri SLF4J'ye dönüştürmek istiyorsanız, bunu SLF4J dağıtımında sağlanan geçiş aracını kullanarak yapabilirsiniz.

SLF4J Migrator'u Çalıştırma

SLF4J basit bir tek jar dosyasıdır (slf4j-migrator.jar) ve bunu java –jar komutunu kullanarak çalıştırabilirsiniz.

Çalıştırmak için, komut isteminde, bu jar dosyasına sahip olduğunuz dizine göz atın ve aşağıdaki komutu çalıştırın.

java -jar slf4j-migrator-1.8.0-beta2.jar
Starting SLF4J Migrator

Bu, taşımacıyı başlatır ve bağımsız bir java uygulamasını şu şekilde görebilirsiniz:

Pencerede belirtildiği gibi, yapmak istediğiniz taşıma türünü kontrol etmeniz ve proje dizinini seçmeniz ve Projeyi SLF4J'ye Taşı düğmesine tıklamanız gerekir.

Bu araç, sağladığınız kaynak dosyalara gider ve içe aktarma satırlarını ve günlükçü bildirimlerini geçerli günlük çerçevesinden SLF4j'ye değiştirmek gibi basit değişiklikler yapar.

Misal

Örneğin, bir örneğimiz olduğunu varsayalım log4j(2) aşağıdaki gibi tek bir dosya ile tutulma projesi -

import org.apache.log4j.Logger;
import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class Sample {
   /* Get actual class name to be printed on */
   static Logger log = Logger.getLogger(Sample.class.getName());

   public static void main(String[] args)throws IOException,SQLException {
      log.debug("Hello this is a debug message");
      log.info("Hello this is an info message");
   }
}

Örneği taşımak için log4j(2) slf4j projesine, radyo düğmesini kontrol etmemiz gerekiyor from log4j to slf4j ve projenin dizinini seçin ve tıklayın Exit göç etmek.

Taşıyıcı yukarıdaki kodu aşağıdaki gibi değiştirdi. Burada, içe aktarım ve günlükçü ifadelerinin değiştirildiğini gözlemlerseniz.

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.io.*;
import java.sql.SQLException;
import java.util.*;

public class Sample {
   static Logger log = LoggerFactory.getLogger(Sample.class.getName());
   public static void main(String[] args)throws IOException,SQLException {
      log.debug("Hello this is a debug message");
      log.info("Hello this is an info message");
   }
}

Zaten sahip olduğun için log4j.jar projenize eklemeniz gerekiyor slf4j-api.jar ve slf4jlog12.jar Projeyi yürütmek için dosyalar.

SLF4JMigrator'ın Sınırlamaları

Aşağıda, SLF4J taşıyıcısının sınırlamaları bulunmaktadır.

  • Göçmen, karınca, maven ve sarmaşık gibi derleme komut dosyalarını değiştirmez, bunu kendiniz yapmanız gerekir.

  • Taşıyıcı, Dize türü dışındaki mesajları desteklemez.

  • Taşıyıcı FATAL seviyesini desteklemiyor.

  • Log4j ile çalışırken, göçmen çağrıları PropertyConfigurator veya DomConfigurator'a taşımaz.