Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

TomcatAccessLog.java 3.0KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2019 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. package org.sonar.server.app;
  21. import ch.qos.logback.access.PatternLayoutEncoder;
  22. import ch.qos.logback.core.FileAppender;
  23. import org.apache.catalina.LifecycleEvent;
  24. import org.apache.catalina.LifecycleListener;
  25. import org.apache.catalina.startup.Tomcat;
  26. import org.sonar.api.utils.log.Logger;
  27. import org.sonar.api.utils.log.Loggers;
  28. import org.sonar.process.logging.LogbackHelper;
  29. import org.sonar.process.Props;
  30. class TomcatAccessLog {
  31. private static final String PROPERTY_ENABLE = "sonar.web.accessLogs.enable";
  32. private static final String PROPERTY_PATTERN = "sonar.web.accessLogs.pattern";
  33. private static final String DEFAULT_SQ_ACCESS_LOG_PATTERN = "%h %l %u [%t] \"%r\" %s %b \"%i{Referer}\" \"%i{User-Agent}\" \"%reqAttribute{ID}\"";
  34. void configure(Tomcat tomcat, Props props) {
  35. tomcat.setSilent(true);
  36. tomcat.getService().addLifecycleListener(new LifecycleLogger(Loggers.get(TomcatAccessLog.class)));
  37. configureLogbackAccess(tomcat, props);
  38. }
  39. private static void configureLogbackAccess(Tomcat tomcat, Props props) {
  40. if (props.valueAsBoolean(PROPERTY_ENABLE, true)) {
  41. ProgrammaticLogbackValve valve = new ProgrammaticLogbackValve();
  42. LogbackHelper helper = new LogbackHelper();
  43. LogbackHelper.RollingPolicy policy = helper.createRollingPolicy(valve, props, "access");
  44. FileAppender appender = policy.createAppender("ACCESS_LOG");
  45. PatternLayoutEncoder fileEncoder = new PatternLayoutEncoder();
  46. fileEncoder.setContext(valve);
  47. fileEncoder.setPattern(props.value(PROPERTY_PATTERN, DEFAULT_SQ_ACCESS_LOG_PATTERN));
  48. fileEncoder.start();
  49. appender.setEncoder(fileEncoder);
  50. appender.start();
  51. valve.addAppender(appender);
  52. tomcat.getHost().getPipeline().addValve(valve);
  53. }
  54. }
  55. static class LifecycleLogger implements LifecycleListener {
  56. private Logger logger;
  57. LifecycleLogger(Logger logger) {
  58. this.logger = logger;
  59. }
  60. @Override
  61. public void lifecycleEvent(LifecycleEvent event) {
  62. if ("after_start".equals(event.getType())) {
  63. logger.debug("Tomcat is started");
  64. } else if ("after_destroy".equals(event.getType())) {
  65. logger.debug("Tomcat is stopped");
  66. }
  67. }
  68. }
  69. }