介绍:在dubbo项目中,使用druid的监控功能
问题:因为,在网上找勒,很多的资料,显示的都是需要在web.xml中配置
<servlet> <servlet-name>DruidStatView</servlet-name> <servlet-class>com.alibaba.druid.support.http.StatViewServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>DruidStatView</servlet-name> <url-pattern>/druid/*</url-pattern> </servlet-mapping>
可是,我们一般搭建的dubbo项目,使用的shell脚本启动的,java命令启动,没有使用到Tomcat容器,虽然可以使用,
但是会显得,很浪费
解决:
其实,思路是借鉴,dubbo-monitor-simple 工程的思路,在dubbo的启动项目中,启动jetty容器,去监控,这个监控
这个容器也不是很大,所以不会有多少性能的损失。
下面贴出代码,以及遇到的问题,贴出的为主要代码,是在大家已有的dubbo项目上添加即可
pom.xml
<dependency> <groupId>org.mortbay.jetty</groupId> <artifactId>jetty</artifactId> <version>6.1.26</version> </dependency>
描述: dubbo启动jetty依赖的jar
/src/main/resources/META-INF/dubbo/com.alibaba.dubbo.container.Container
myjetty=com.xxxx.insurance.service.demo.common.container.JettyContainer
/src/main/java/com/xxxx/insurance/service/demo/common/container/JettyContainer.java
// 日志监控系统的 handler.addServletWithMapping(StatViewServlet.class, "/druid/*");
描述:直接copy,dubbo的JettyContainer.java过来,修改就可以啦
启动代码
public static void main(String[] args) { args = new String[]{"spring","myjetty"}; com.alibaba.dubbo.container.Main.main(args); }
脚本启动
conf/ dubbo.properties
dubbo.container=spring,myjetty dubbo.log4j.file=logs/dubbo-demo-provider.logdubbo.log4j.level=WARN
最后,启动,访问
http://localhost:8080/druid/index.html
时间: 2024-10-14 00:56:52