log4j файл журнала не катится при установке filepath во время выполнения - PullRequest
0 голосов
/ 27 июня 2018

Код 2 вводит экземпляр Logger в поле LOG в Код 1 . Журналы идут в правильный файл, но журналы не катятся. Однако при использовании Код 1 с Код 3 журналы катятся. Мне нужно, чтобы Код 1 работал с Код 2 . Основная логика добавления RollingFileAppender такая же, но у меня нет идей, почему журнал не будет свернут в первом случае. Не могли бы вы объяснить, что я делаю неправильно и что может быть возможным решением.

@Retention(RUNTIME)
@Target(FIELD)
@Documented
public @interface Log {
    Class<?> clazz();
}

Код 1: -

@RestController
@RequestMapping(value = "/util/")
public class UtilityController {
    @Log(clazz = COScheduler.class)
    private static Logger LOG;
}

Код 2: -

package text.worker.config.log;

import java.lang.reflect.Field;
import java.lang.reflect.Type;

import javax.annotation.PostConstruct;

import org.apache.log4j.Logger;
import org.apache.log4j.PatternLayout;
import org.apache.log4j.RollingFileAppender;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.config.BeanPostProcessor;
import org.springframework.stereotype.Component;
import org.springframework.util.ClassUtils;
import org.springframework.util.ReflectionUtils;    

@Component
public class LogInjector implements BeanPostProcessor {

    @Override
    public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
        return bean;
    }

    @Override
    public Object postProcessBeforeInitialization(final Object bean, String name) throws BeansException {
        ReflectionUtils.doWithFields(bean.getClass(), new ReflectionUtils.FieldCallback() {
            public void doWith(Field field) throws IllegalArgumentException, IllegalAccessException {
                // make the field accessible if defined private
                ReflectionUtils.makeAccessible(field);
                if (field.getAnnotation(Log.class) != null) {
                    Class<?> cl = ClassUtils.getUserClass(field.getAnnotation(Log.class).clazz());

                    Logger log = Logger.getLogger(cl);

                    if(log.getAppender("worker") == null) {
                        PatternLayout patternLayout = new PatternLayout();
                        patternLayout.setConversionPattern("%d{yyyy-MM-dd HH:mm:ss.SSS} %-5p %c{1}:%L - %m%n");
                        try {
                            RollingFileAppender appender = new RollingFileAppender(patternLayout, "D://aa.log",true);
                            appender.setMaxFileSize("500KB");
                            appender.setMaxBackupIndex(10);
                            appender.setName("worker");
                            appender.activateOptions();
                            log.addAppender(appender);
                        } catch (IOException e) {
                        }
                    }   
                    //log.warn("LogInjector postProcessBeforeInitialization Log getAppender "+field.getAnnotation(Log.class).clazz());                    

                    field.set(bean, log);
                }
            }
        });
        return bean;
    }
}

Код 3: -

if(LOG.getAppender("worker") == null) {
            PatternLayout patternLayout = new PatternLayout();
            patternLayout.setConversionPattern("%d{yyyy-MM-dd HH:mm:ss} %-5p %c{1}:%L - %m%n");
            try {
                RollingFileAppender appender = new RollingFileAppender(patternLayout, "D://aa.log",true);
                appender.setMaxFileSize("500KB");
                appender.setMaxBackupIndex(10);             
                appender.setName("worker");
                appender.activateOptions();
                LOG.addAppender(appender);              
            } catch (IOException e) {
            }
        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...