Chciałbym mieć plik logback.xml do produkcji i inny z innymi parametrami w moim środowisku pomostowym. Mój kod jest w stanie automatycznie rozpoznać w czasie wykonywania, jeśli jest on w fazie produkcyjnej lub wykonawczej. Czy istnieje sposób na ustawienie pliku konfiguracyjnego logback w środowisku wykonawczym?Jak ustawić plik konfiguracyjny logowania w środowisku wykonawczym?
Odpowiedz
Metoda 1: Ładowanie z różnych plików
można trzymać dwa różne pliki konfiguracji i załadować plik dla konkretnego środowisku z JoranConfiguratior#doConfigure
przy starcie aplikacji.
Zobacz http://logback.qos.ch/manual/configuration.html#joranDirectly. Przykład kodu również wziąć stamtąd ze zmianami w Twoim przypadku:
public class MyApp3 {
final static String STAGING_CONFIGURATION = "/path/to/statging.xml";
final static String PRODUCTION_CONFIGURATION = "/path/to/production.xml";
final static Logger logger = LoggerFactory.getLogger(MyApp3.class);
public static void main(String[] args) {
// assume SLF4J is bound to logback in the current environment
LoggerContext context = (LoggerContext) LoggerFactory.getILoggerFactory();
// determine environmental specific configuration path
final String path = isProdcution() ? PRODUCTION_CONFIGURATION : STAGING_CONFIGURATION;
try {
JoranConfigurator configurator = new JoranConfigurator();
configurator.setContext(context);
// Call context.reset() to clear any previous configuration, e.g. default
// configuration. For multi-step configuration, omit calling context.reset().
context.reset();
configurator.doConfigure(path);
} catch (JoranException je) {
// StatusPrinter will handle this
}
StatusPrinter.printInCaseOfErrorsOrWarnings(context);
logger.info("Entering application.");
Foo foo = new Foo();
foo.doIt();
logger.info("Exiting application.");
}
}
Oczywiście, kod dla uzyskania prawidłowego pliku może być regulowane dopasowanie potrzeb. Co więcej, istnieją pewne przeciążone metody doConfigure
(http://logback.qos.ch/apidocs/ch/qos/logback/core/joran/GenericConfigurator.html#doConfigure%28java.io.File%29), które dobrze odbierają również pliki InputStreams, pliki i adresy URL.
Metoda 2: Korzystanie warunkowe w jednym pliku
Jeśli można określić otoczenie przy użyciu build logbag w lub właściwości systemowych, można użyć konfiguracje warunkowe:
http://logback.qos.ch/manual/configuration.html#conditional
<!-- if-then form -->
<if condition="condition for your production">
<then>
...
</then>
<else>
...
</else>
</if>
używasz Springa? – John
nie! Zwykły stary java. – poiuytrez