karaf中利用Bundle引入外部log4j配置文件
环境准备:
1.在karaf_home下新建 config及logs目录
2.将mylog4j.properties拷贝到config文件夹下
查看log4j-1.2.17.jar/MANIFEST.MF
Manifest-Version: 1.0
Export-Package: org.apache.log4j.net;uses:="org.apache.log4j,org.apach
e.log4j.spi,javax.naming,org.apache.log4j.helpers,javax.jms,org.apach
e.log4j.xml,javax.mail,javax.mail.internet,org.w3c.dom,javax.jmdns";v
ersion="1.2.17",org.apache.log4j.jmx;uses:="org.apache.log4j,javax.ma
nagement,org.apache.log4j.helpers,org.apache.log4j.spi";version="1.2.
17",org.apache.log4j.jdbc;uses:="org.apache.log4j,org.apache.log4j.sp
i";version="1.2.17",org.apache.log4j.config;uses:="org.apache.log4j.h
elpers,org.apache.log4j,org.apache.log4j.spi";version="1.2.17",org.ap
ache.log4j.helpers;uses:="org.apache.log4j,org.apache.log4j.spi,org.a
pache.log4j.pattern";version="1.2.17",org.apache.log4j;uses:="org.apa
che.log4j.spi,org.apache.log4j.helpers,org.apache.log4j.pattern,org.a
pache.log4j.or,org.apache.log4j.config";version="1.2.17",org.apache.l
og4j.or.jms;uses:="org.apache.log4j.helpers,javax.jms,org.apache.log4
j.or";version="1.2.17",org.apache.log4j.nt;uses:="org.apache.log4j.he
lpers,org.apache.log4j,org.apache.log4j.spi";version="1.2.17",org.apa
che.log4j.or.sax;uses:="org.apache.log4j.or,org.xml.sax";version="1.2
.17",org.apache.log4j.pattern;uses:="org.apache.log4j.helpers,org.apa
che.log4j.spi,org.apache.log4j,org.apache.log4j.or";version="1.2.17",
org.apache.log4j.spi;uses:="org.apache.log4j,org.apache.log4j.helpers
,org.apache.log4j.or";version="1.2.17",org.apache.log4j.rewrite;uses:
="org.apache.log4j,org.apache.log4j.spi,org.apache.log4j.helpers,org.
apache.log4j.xml,org.w3c.dom";version="1.2.17",org.apache.log4j.or;us
es:="org.apache.log4j.helpers,org.apache.log4j.spi,org.apache.log4j";
version="1.2.17",org.apache.log4j.xml;uses:="javax.xml.parsers,org.w3
c.dom,org.xml.sax,org.apache.log4j.config,org.apache.log4j.helpers,or
g.apache.log4j,org.apache.log4j.spi,org.apache.log4j.or";version="1.2
.17",org.apache.log4j.varia;uses:="org.apache.log4j.spi,org.apache.lo
g4j,org.apache.log4j.helpers";version="1.2.17"
Ignore-Package: com.sun.jdmk.comm,javax.swing.text,javax.swing.border,
javax.swing.tree,javax.swing,com.ibm.uvm.tools,javax.swing.table,java
x.swing.event
Built-By: cy
Tool: Bnd-0.0.357
Bundle-Name: Apache Log4j
Created-By: Apache Maven Bundle Plugin
Bundle-Vendor: Apache Software Foundation
Build-Jdk: 1.6.0_23
Bundle-Version: 1.2.17
Bnd-LastModified: 1336302107501
Bundle-ManifestVersion: 2
Bundle-License: http://www.apache.org/licenses/LICENSE-2.0.txt
Bundle-Description: Apache Log4j 1.2
Bundle-DocURL: http://logging.apache.org/log4j/1.2
Bundle-SymbolicName: log4j
Import-Package: javax.jmdns;resolution:=optional,javax.jms;resolution:
=optional,javax.mail;resolution:=optional,javax.mail.internet;resolut
ion:=optional,javax.management,javax.naming,javax.xml.parsers,org.w3c
.dom,org.xml.sax,org.xml.sax.helpers Name: org.apache.log4j
DynamicImport-Package: *
Implementation-Vendor: "Apache Software Foundation"
Implementation-Title: log4j
Implementation-Version: 1.2.17我们能够看到 log4j-1.2.17.jar 就是一个Bundle
热部署 log4j
启动karaf,将 log4j-1.2.17.jar 拷贝到karaf_home/deploy文件夹下
输入 list 命令。能够查看Bundle已经成功安装
mylog4j.properties
### direct log messages to stdout ###
log4j.appender.consoleout=org.apache.log4j.ConsoleAppender
log4j.appender.consoleout.layout=org.apache.log4j.PatternLayout
log4j.appender.consoleout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c:%L - %m%n ### direct messages to file myfile.log ###
log4j.appender.myfile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.myfile.File=logs/myfile.log
log4j.appender.myfile.DatePattern='.'yyyy-MM-dd
log4j.appender.myfile.layout=org.apache.log4j.PatternLayout
log4j.appender.myfile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss,SSS} %5p %c:%L - %m%n log4j.rootLogger==info,consoleout,myfile
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion> <groupId>com.demo.hello.provider</groupId>
<artifactId>log-test</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>bundle</packaging> <name>log-test</name>
<url>http://maven.apache.org</url> <properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties> <dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>org.osgi</groupId>
<artifactId>org.osgi.core</artifactId>
<version>4.2.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.felix</groupId>
<artifactId>maven-bundle-plugin</artifactId>
<extensions>true</extensions>
<configuration>
<instructions>
<Import-Package>
org.apache.log4j,
org.osgi.framework.*
</Import-Package>
<Bundle-Activator>com.demo.hello.provider.Activator</Bundle-Activator>
</instructions>
</configuration>
</plugin>
</plugins>
</build>
</project>
Activitor
/**
*
* @author wumingkun
* @version 1.0.0
* @Description
*/ package com.demo.hello.provider; import org.apache.log4j.Logger;
import org.osgi.framework.BundleActivator;
import org.osgi.framework.BundleContext; import com.demo.hello.provider.log.LoggerFactory; /**
* @author wumingkun
*
*/
public class Activator implements BundleActivator { /* (non-Javadoc)
* @see org.osgi.framework.BundleActivator#start(org.osgi.framework.BundleContext)
*/
public void start(BundleContext context) throws Exception {
Logger logger =LoggerFactory.getLogger(Activator.class);
logger.info("bundle start...");
} /* (non-Javadoc)
* @see org.osgi.framework.BundleActivator#stop(org.osgi.framework.BundleContext)
*/
public void stop(BundleContext context) throws Exception { } }
LoggerFactory:
/**
*
* @author wumingkun
* @version 1.0.0
* @Description 日志工厂类
*/ package com.demo.hello.provider.log; import java.io.File; import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator; /**
* @author wumingkun
*
*/
public class LoggerFactory {
public static final String CONFIG_DIR = "config";
public static final String LOG4J_CONFIG = "myLog4j.properties";
private static String fileName = getFileName(); public static Logger getLogger(Class clazz) {
Logger logger = Logger.getLogger(clazz);
loadProperty();
return logger;
} private static String getFileName() {
return System.getProperty("user.dir") + File.separator + CONFIG_DIR
+ File.separator + LOG4J_CONFIG;
} public static void loadProperty() {
PropertyConfigurator.configure(fileName);
}
}
部署log-test
在karaf命令行能够看到,例如以下图所看到的:
在karaf_home/logs能够看到生成名为 myfile.log的日志文件
karaf中利用Bundle引入外部log4j配置文件的更多相关文章
- 在spring配置文件中引入外部properties配置文件 context:property-placeholder
在spring的配置文件中,有时我们需要注入很多属性值,这些属性全都写在spring的配置文件中的话,后期管理起来会非常麻烦.所以我们可以把某一类的属性抽取到一个外部配置文件中,使用时通用spring ...
- Spring Boot 引入外部yml配置文件
当需要在springboot中引用其他的yml文件时,需要在application.yml里配置 spring: profiles: include: email,xmyb ...
- ASP.NET MVC中在 @RenderBody() 或者 @Html.Partial()中需要使用引入外部js,css
今天想在后台封装一下bootstraptree这个插件,引入jquery.js bootstrap.js bootstrap.css bootstrap-tree.js后,我在页面查看脚本错误就连最简 ...
- JAVA MyBatis配置文件用properties引入外部配置文件
方式一:通过properties 元素的子元素来传递数据 例如: <properties> <property name="driver" value=" ...
- 如何在Android应用中引入外部网页
在某些情况下,我们需要在Android应用中引入外部网页,这里记录一下如何操作(其实很简单^.^). 先介绍一下开发环境: 开发工具:Android Studio 1.5 SDK API版本:17 操 ...
- SpringBoot常用配置,引入外部配置文件信息,热加载
SpringBoot的配置文件格式 yml规范 SpringBoot的配置文件支持properties和yml,甚至还支持json. 更推荐使用yml文件格式: yml文件,会根据换行和缩进帮助咱们管 ...
- spring 配置文件 引入外部的property文件的两种方法
spring 的配置文件 引入外部的property文件的两种方法 <!-- 引入jdbc配置文件 方法一 --> <bean id="propertyConfig ...
- vue文件中引入外部js
1.在项目的入口文件中(app.js)定义remoteScript标签 Vue.component('remote-script', { render: function (createElement ...
- jsp、css中引入外部资源相对路径的问题
在jsp页面中添加base,可用相对路径: <% String path = request.getContextPath(); String basePath = request.getSch ...
随机推荐
- loadrunner参数化数据分配方法
数据分配方法: 在“Select next row“列表中选择一个数据分配方法,以指示在Vuser脚本执行期间如何从参数文件中取得数据.选项包括”Sequential“.“Random”.“Uniqu ...
- CodeM美团点评编程大赛初赛A轮
因为语文太差弃赛,第一个追及问题看不懂我就弃赛了.打进复赛确实挺难的,补一下题,锻炼下就行了. 身体训练 时间限制:1秒 空间限制:32768K 美团外卖的配送员用变速跑的方式进行身体训练.他们训练的 ...
- springboot集成shiro——登陆记住我
在shiro配置类中增加两个方法: com.resthour.config.shrio.ShiroConfiguration /** * cookie管理对象 * @return */ @Bean p ...
- python相关——如何安装pip
今天在新的一台电脑上安装了pip.流程有点忘记了,在这里再次记录下来. 本教程基于python3.4,并且需要连接互联网,总共需要两步. 1.要安装pip,首先要安装setuptools,链接:htt ...
- iOS------手势操作(nib文件、纯代码)
总共有六种手势识别:轻击手势(TapGestureRecognizer),轻扫手势 (SwipeGestureRecognizer), 长按手势(LongPressGestureRecognizer) ...
- best coder #35-01<组合数学 || 概率数学>
问题描述 一个盒子里有n个黑球和m个白球.现在DZY每次随机从盒子里取走一个球,取了n+m次后,刚好取完.DZY用这种奇怪的方法生成了一个随机的01串S[1⋯(n+m)].如果DZY第i次取出的球是黑 ...
- HDU——1163Eddy's digital Roots(九余数定理+同余定理)
Eddy's digital Roots Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Oth ...
- 刷题总结——开车旅行(NOIP2012 set+倍增)
题目: 题目描述 小 A 和小 B 决定利用假期外出旅行,他们将想去的城市从 1 到 N 编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i 的海拔高度为Hi,城 ...
- 刷题总结——怪题(ssoj费用流)
题目: 题目描述 给出一个长度为 n 的整数序列 hi ,现在要通过一些操作将这个序列修改为单调不降序列,即 hi≤hi+1 . 可以用的操作有 m 种,第 i 种操作可以通过支付 ci 的代价将一 ...
- 你如果知道这些css常用命名,绝对事半功倍!--摘抄
对于布局,即用.g-作为前缀,通常有以下推荐的写法 对于模块,即.m-作为前缀.元件,.u-作为前缀,通常有下面推荐的写法. 对于功能,即以.f-为前缀,通常推荐如下: 对于颜色,即以.s-为前缀,通 ...