`
sillycat
  • 浏览: 2524555 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

VML勾画流程图(六)db4o后续问题

    博客分类:
  • UI
阅读更多
VML勾画流程图(六)db4o后续问题

问题一:
每次在关闭tomcat的时候,控制台都会有错误信息打印出来。
报错如下:
严重: A web application created a ThreadLocal with key of type [org.springframework.core.NamedThreadLocal] (value [Prototype beans currently in creation]) and a value of type [null] (value [null]) but failed to remove it when the web application was stopped. To prevent a memory leak, the ThreadLocal has been forcibly removed.
2010-4-22 22:09:52 org.apache.catalina.loader.WebappClassLoader clearThreadLocalMap
严重: A web application created a ThreadLocal with key of type [org.springframework.core.NamedThreadLocal] (value [Prototype beans currently in creation]) and a value of type [null] (value [null]) but failed to remove it when the web application was stopped. To prevent a memory leak, the ThreadLocal has been forcibly removed.
2010-4-22 22:09:52 org.apache.catalina.loader.WebappClassLoader clearThreadLocalMap
严重: A web application created a ThreadLocal with key of type [org.springframework.core.NamedThreadLocal] (value [Prototype beans currently in creation]) and a value of type [null] (value [null]) but failed to remove it when the web application was stopped. To prevent a memory leak, the ThreadLocal has been forcibly removed.
2010-4-22 22:09:52 org.apache.catalina.loader.WebappClassLoader clearThreadLocalMap
严重: A web application created a ThreadLocal with key of type [org.codehaus.groovy.runtime.GroovyCategorySupport.MyThreadLocal] (value [org.codehaus.groovy.runtime.GroovyCategorySupport$MyThreadLocal@1648e6f]) and a value of type [java.lang.ref.SoftReference] (value [java.lang.ref.SoftReference@c32254]) but failed to remove it when the web application was stopped. To prevent a memory leak, the ThreadLocal has been forcibly removed.
log4j:ERROR LogMananger.repositorySelector was null likely due to error in class reloading, using NOPLoggerRepository.

有人说是TOMCAT的BUG
tomcat6.0.24和ORACLE10g JDBC,MYSQL5 JDBC的兼容性都有问题!
http://hi.baidu.com/rtsbtx/blog/item/841c4f1f44ca02c3a786693b.html

我换成6.0.20之后就好了,不过这里到底有没有memory leak,以后还要多观察。

问题二:
以前我把db4o的db4oDAOImpl想得太简单了,而且local和remote那么弄不得行:),只能不考虑client或者本地yap文件的频繁打开和关闭问题,将对db4o的操作做调整。
web.xml中增加启动项,启动tomcat的时候就开启db4o的server,当然是根据配置来走。
<listener>
<listener-class>com.sillycat.easyworkflow.commons.listeners.Db4oContextLoaderListener</listener-class>
</listener>

Db4oContextLoaderListener.java的内容如下,做了哪些事情呢:
package com.sillycat.easyworkflow.commons.listeners;
import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.context.ApplicationContext;
import org.springframework.web.context.ContextLoaderListener;
import org.springframework.web.context.support.WebApplicationContextUtils;
import com.db4o.ObjectServer;
import com.db4o.cs.Db4oClientServer;
import com.sillycat.easyworkflow.commons.config.WebAppConfiguration;

public class Db4oContextLoaderListener extends ContextLoaderListener implements
ServletContextListener {
private final Log log = LogFactory.getLog(getClass());
private ObjectServer server;
public void contextInitialized(ServletContextEvent event) {
super.contextInitialized(event);
ServletContext context = event.getServletContext();
ApplicationContext ctx = WebApplicationContextUtils
.getRequiredWebApplicationContext(context);
WebAppConfiguration webAppConfiguration = (WebAppConfiguration) ctx
.getBean("webAppConfiguration");
if (!webAppConfiguration.isEnableLocal()) {
log.info("=============================  begin to init dbo4   =====================");
initdb4o(webAppConfiguration);
log.info("=============================  end   to init dbo4   =====================");
}
}
public void contextDestroyed(ServletContextEvent event) {
if(this.server != null){
log.info("shutdown the db4o server");
this.server.close();
}
}
public void initdb4o(WebAppConfiguration webAppConfiguration) {
log.info("serverfilename:" + webAppConfiguration.getServerFileName());
log.info("port:" + webAppConfiguration.getPort());
log.info("username:" + webAppConfiguration.getUsername());
this.server = Db4oClientServer.openServer(Db4oClientServer
.newServerConfiguration(), webAppConfiguration
.getServerFileName(), webAppConfiguration.getPort());
this.server.grantAccess(webAppConfiguration.getUsername(),
webAppConfiguration.getPassword());
}
}

配置类WebAppConfiguration.java如下:
public class WebAppConfiguration {
private String workflowPath;
// 是否是本地服务
private boolean enableLocal = true;
// 本地数据库文件名字
private String localFileName = "local.yap";
// 服务端数据库文件名字
private String serverFileName = "server.yap";
// 服务器端口
private int port = 1212;
// 用户名
private String username = "sillycat";
// 密码
private String password = "111111";
// 服务器地址
private String serverhost = "localhost";
...snip...
}

properties的数据如下:
db4o.enableLocal=true
db4o.local.filename=e:/work/easyworkflow/db/local.yap
db4o.server.filename=e:/work/easyworkflow/db/server.yap
db4o.server.port=1212
db4o.server.username=sillycat
db4o.server.password=111111
db4o.server.serverhost=localhost

原来的workflowManagerImpl要做如下修改:
package com.sillycat.easyworkflow.service.impl;

import java.util.ArrayList;
import java.util.List;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import com.db4o.Db4oEmbedded;
import com.db4o.ObjectContainer;
import com.db4o.ObjectSet;
import com.db4o.cs.Db4oClientServer;
import com.db4o.query.Predicate;
import com.sillycat.easyworkflow.commons.config.WebAppConfiguration;
import com.sillycat.easyworkflow.commons.utils.Db4oUtil;
import com.sillycat.easyworkflow.commons.utils.StringUtil;
import com.sillycat.easyworkflow.model.Workflow;
import com.sillycat.easyworkflow.model.WorkflowDefinition;
import com.sillycat.easyworkflow.model.WorkflowDefinitionQuery;
import com.sillycat.easyworkflow.service.WorkflowManager;

@Service("workflowManager")
public class WorkflowManagerImpl implements WorkflowManager {

public Logger logger = LoggerFactory.getLogger(this.getClass());

private WebAppConfiguration webAppConfiguration;

public ObjectContainer opendb() {
ObjectContainer db = null;
if (webAppConfiguration.isEnableLocal()) {
db = Db4oEmbedded.openFile(Db4oEmbedded.newConfiguration(),
webAppConfiguration.getLocalFileName());
logger.info("init local db4o file = "
+ webAppConfiguration.getLocalFileName());
} else {
db = Db4oClientServer.openClient(Db4oClientServer
.newClientConfiguration(), webAppConfiguration
.getServerhost(), webAppConfiguration.getPort(),
webAppConfiguration.getUsername(), webAppConfiguration
.getPassword());
logger.info("init remote db4o server "
+ webAppConfiguration.getServerhost() + ":"
+ webAppConfiguration.getPort());
}
return db;
}

@Autowired
public void setWebAppConfiguration(WebAppConfiguration webAppConfiguration) {
this.webAppConfiguration = webAppConfiguration;
}

/**
* use for show page,get flow instances information by flow id
*/
public Workflow getWorkflowById(String workflowInstanceId) {
if (StringUtil.isBlank(workflowInstanceId)) {
logger.info("workflowInstanceId can't be blank when get workflow!");
return null;
}
Workflow workflow = new Workflow(workflowInstanceId);
ObjectContainer db = null;
try {
db = opendb();
ObjectSet<Workflow> os = db.queryByExample(workflow);
Db4oUtil<Workflow> db4oUtil = new Db4oUtil<Workflow>();
workflow = db4oUtil.retrieveObject(os);
} catch (Exception e) {
logger.error("error:" + e);
} finally {
db.close();
}
return workflow;
}

/**
* save flow instances information
*/
public void saveWorkflow(Workflow workflow) {
if (workflow == null
|| StringUtil.isBlank(workflow.getWorkflowInstanceId())) {
logger
.info("object and workflowInstanceId can't be null,when save!");
return;
}
ObjectContainer db = null;
try {
db = opendb();
Workflow search = new Workflow(workflow.getWorkflowInstanceId());
ObjectSet<Workflow> os = db.queryByExample(search);
Db4oUtil<Workflow> db4oUtil = new Db4oUtil<Workflow>();
Workflow t = db4oUtil.retrieveObject(os);
if (t == null) {
// insert new object in the database
db.store(workflow);
logger
.debug("object workflow="
+ workflow.getWorkflowInstanceId()
+ " newly inserted!");
} else {
// update object in the database
t.setSteps(workflow.getSteps());
t.setWorkflowName(workflow.getWorkflowName());
db.store(t);
logger.debug("object workflow="
+ workflow.getWorkflowInstanceId() + " updated!");
}
db.commit();
} catch (Exception e) {
logger.error("error:" + e);
} finally {
db.close();
}
}

/**
* save flow definition information
*
* @param workflowDefinition
*/
public void saveWorkflowDefinition(WorkflowDefinition workflowDefinition) {
if (workflowDefinition == null
|| StringUtil.isBlank(workflowDefinition.getWorkflowName())) {
logger.info("object and workflowName can't be null,when save!");
return;
}
ObjectContainer db = null;
try {
db = opendb();
WorkflowDefinition search = new WorkflowDefinition(
workflowDefinition.getWorkflowName());
ObjectSet<WorkflowDefinition> os = db.queryByExample(search);
Db4oUtil<WorkflowDefinition> db4oUtil = new Db4oUtil<WorkflowDefinition>();
WorkflowDefinition t = db4oUtil.retrieveObject(os);
if (t == null) {
// insert new object in the database
db.store(workflowDefinition);
logger.debug("object workflowDefinition="
+ workflowDefinition.getWorkflowName()
+ " newly inserted!");
} else {
// update object in the database
t.setAliasName(workflowDefinition.getAliasName());
t.setContent(workflowDefinition.getContent());
db.store(t);
logger.debug("object workflowDefinition="
+ workflowDefinition.getWorkflowName() + " updated!");
}
db.commit();
} catch (Exception e) {
logger.error("error:" + e);
} finally {
db.close();
}
}

/**
* get the flow definition information by workflowName
*
* @param workflowName
* @return
*/
public WorkflowDefinition getWorkflowDefinitionByWorkflowName(
String workflowName) {
if (StringUtil.isBlank(workflowName)) {
logger
.info("workflowName can't be blank when get workflowDefinition!");
return null;
}
WorkflowDefinition wfDefinition = new WorkflowDefinition(workflowName);
ObjectContainer db = null;
try {
db = opendb();
ObjectSet<WorkflowDefinition> os = db.queryByExample(wfDefinition);
Db4oUtil<WorkflowDefinition> db4oUtil = new Db4oUtil<WorkflowDefinition>();
wfDefinition = db4oUtil.retrieveObject(os);
} catch (Exception e) {
logger.error("error:" + e);
} finally {
db.close();
}
return wfDefinition;
}

/**
* list all the flow definition information
*
* @return
*/
public List<WorkflowDefinition> allWorkflowDefinition() {
List<WorkflowDefinition> list = null;
WorkflowDefinition wfDefinition = new WorkflowDefinition();
ObjectContainer db = null;
try {
db = opendb();
ObjectSet<WorkflowDefinition> os = db.queryByExample(wfDefinition);
Db4oUtil<WorkflowDefinition> db4oUtil = new Db4oUtil<WorkflowDefinition>();
list = db4oUtil.retrieveList(os);
} catch (Exception e) {
logger.error("error:" + e);
} finally {
db.close();
}
return list;
}

/**
* query the flow definition information with page parameters
*
* @param query
* @return
*/
public List<WorkflowDefinition> queryWorkflowDefinition(
WorkflowDefinitionQuery query) {
List<WorkflowDefinition> os = null;
List<WorkflowDefinition> list = null;
final String workflowName = query.getWorkflowName();
final String aliasName = query.getAliasName();
ObjectContainer db = null;
try {
db = opendb();
os = db.query(new Predicate<WorkflowDefinition>() {
private static final long serialVersionUID = 8058916779101664916L;

public boolean match(WorkflowDefinition wd) {
boolean flag = true;
if (StringUtil.isNotBlank(workflowName)) {
flag = wd.getWorkflowName().equalsIgnoreCase(
workflowName);
}
if (StringUtil.isNotBlank(aliasName)) {
flag = flag
&& wd.getAliasName()
.equalsIgnoreCase(aliasName);
}
return flag;
}
});
if (os != null && !os.isEmpty()) {
query.setTotal(os.size());
}
list = new ArrayList<WorkflowDefinition>(query.getEnd()
- query.getStart() + 1);
for (int i = (query.getStart() - 1); i < query.getEnd(); i++) {
list.add(os.get(i));
}
} catch (Exception e) {
logger.error("error:" + e);
} finally {
db.close();
}
return list;
}

/**
*
* @param workflowName
*/
public void deleteWorkflowDefinitionByWorkflowName(String workflowName) {
if (StringUtil.isBlank(workflowName)) {
logger
.info("workflowName can't be blank when delete workflowdefinition!");
return;
}
ObjectContainer db = null;
try {
db = opendb();
WorkflowDefinition search = new WorkflowDefinition(workflowName);
ObjectSet<WorkflowDefinition> os = db.queryByExample(search);
Db4oUtil<WorkflowDefinition> db4oUtil = new Db4oUtil<WorkflowDefinition>();
WorkflowDefinition workflowDefinition = db4oUtil.retrieveObject(os);
if (workflowDefinition == null) {
logger.info("I can't find workflowDefinition=" + workflowName
+ " in database");
return;
}
db.delete(workflowDefinition);
db.commit();
} catch (Exception e) {
logger.error("error:" + e);
} finally {
db.close();
}
}
}
分享到:
评论

相关推荐

    js vml画流程图

    JavaScript,作为Web开发中的重要脚本语言,可以与VML结合,实现动态的、交互式的流程图绘制。 在JavaScript中,VML主要通过DOM(Document Object Model)操作来实现,可以创建VML元素,设置其属性,以及响应用户的...

    基于EXT | vml的流程图的实现

    EXT 和 VML 是在网页中实现图形界面的两种技术,特别是在创建流程图等可视化元素时。EXT 是一个基于 JavaScript 的富客户端应用框架,提供了一系列组件和工具,用于构建交互式的 Web 应用程序。而 VML(Vector ...

    asp.net+vml流程图代码

    在本案例中,"asp.net+vml流程图代码"指的是利用ASP.NET技术和VML(Vector Markup Language)来创建流程图的一种编程实践。VML是一种标记语言,允许在网页上绘制矢量图形,尤其适合在不支持SVG(Scalable Vector ...

    基于EXT vml的流程图的实现

    基于EXT vml的流程图的实现

    VML 实现流程图

    使用vml封装的流程图控件,颜色大写可自动控制。

    vml开发的流程图

    在这个"vml开发的流程图"项目中,我们可以看到开发者使用JavaScript与VML结合来创建动态和交互式的流程图。 JavaScript是Web开发中的脚本语言,它负责增加网页的动态功能和交互性。在描述中提到的“javascript+vml...

    vml-rose流程图

    "vml-rose流程图"是一个使用VML技术实现的流程图示例,用于在Web环境中展示流程或工作流的过程。在本项目中,我们可能找到了一个用于绘制类似Rose UML类图的流程图工具或代码库。 在描述中提到的"基于vml的web绘图...

    VML画流程图 图元js

    VML做流程图UI层的javascript

    VML+HTML实现流程图查看

    实现了vml+html中显示的,并解决了ie浏览器兼容的问题,代码直接运行便好用

    html+ VML工作流程

    通过查看这些文件,我们可以深入理解HTML和VML如何协同工作来呈现定制的工作流程图。 总之,HTML+VML工作流程结合了HTML的网页结构和VML的矢量图形能力,使得开发者能够创建出具有动态效果和交互性的复杂网页应用。...

    流程图编辑器--js oop vml

    本项目名为“流程图编辑器--js oop vml”,意味着它是一个基于JavaScript实现的对象导向编程(OOP)项目,使用了Vector Markup Language(VML)来绘制流程图。下面将详细介绍这个项目可能涉及的关键知识点。 **1. ...

    vml曲线走势图走势图走势图走势图

    vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml曲线走势图vml...

    vml实例,实现画流程

    在本实例中,我们将深入探讨如何使用VML来实现画流程图。 流程图是一种可视化表示流程或工作流的工具,它通过各种形状和连接线来展示步骤、决策和流程的流向。VML为绘制这些元素提供了丰富的功能,包括线条、矩形、...

    用vml画饼状图用vml画饼状图用vml画饼状图用vml画饼状图

    用vml画饼状图用vml画饼状图用vml画饼状图用vml画饼状图

    ASP VML走势图

    ASP VML走势图是一种基于ASP(Active Server Pages)技术,并结合VML(Vector Markup Language)来创建动态曲线图表的方法。这种技术常用于Web应用中,以便在网页上展示数据的实时变化或者历史趋势,如股票市场、...

    vml导出矢量图到excel

    将输出在页面上的vml图 导出到excel 中的矢量图 可在excel中编辑

    ASP与VML生成图表的示例

    在本示例中,ASP被用来处理和解析来自数据库或其他数据源的数据,然后使用VML(Vector Markup Language)来生成各种图表,如饼图、柱图和折线图。 VML是一种基于XML的矢量图形语言,允许在网页上创建和显示复杂的...

    VML.rar_DEMO_VML_vml API_vml包含哪些图_vml教程

    在"VML.rar_DEMO_VML_vml API_vml包含哪些图_vml教程"这个压缩包中,我们可以期待获取关于VML的基本知识、实例、API介绍以及可能的一些示例图形。以下是一些关于VML的关键知识点: 1. **VML结构**:VML基于XML,...

    一个精致的VML地图

    VML,全称Vector Markup Language,是一种基于XML的矢量图形语言,主要在早期的Web开发中用于在浏览器中创建和展示矢量图形。在“一个精致的VML地图”这个主题中,我们关注的是如何利用VML技术来制作和展示地图。 ...

Global site tag (gtag.js) - Google Analytics