<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<body link="#355491" alink="#4262a1" vlink="#355491" style="background: #e2e2e2; margin: 0; padding: 20px;">

<div>
        <table cellpadding="0" bgcolor="#FFFFFF" border="0" cellspacing="0" style="border: 1px solid #dadada; margin-bottom: 30px; width: 100%; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
                <tbody>
                        <tr>

                                <td>

                                        <table border="0" cellpadding="0" cellspacing="0" bgcolor="#FFFFFF" style="border: solid 2px #ccc; background: #dadada; width: 100%; -moz-border-radius: 6px; -webkit-border-radius: 6px;">
                                                <tbody>
                                                        <tr>
                                                                <td bgcolor="#000000" valign="middle" height="58px" style="border-bottom: 1px solid #ccc; padding: 20px; -moz-border-radius-topleft: 3px; -moz-border-radius-topright: 3px; -webkit-border-top-right-radius: 5px; -webkit-border-top-left-radius: 5px;">
                                                                        <h1 style="color: #333333; font: bold 22px Arial, Helvetica, sans-serif; margin: 0; display: block !important;">
                                                                        <!-- To have a header image/logo replace the name below with your img tag -->
                                                                        <!-- Email clients will render the images when the message is read so any image -->
                                                                        <!-- must be made available on a public server, so that all recipients can load the image. -->
                                                                        <a href="https://community.jboss.org/index.jspa" style="text-decoration: none; color: #E1E1E1">JBoss Community</a></h1>
                                                                </td>

                                                        </tr>
                                                        <tr>
                                                                <td bgcolor="#FFFFFF" style="font: normal 12px Arial, Helvetica, sans-serif; color:#333333; padding: 20px;  -moz-border-radius-bottomleft: 4px; -moz-border-radius-bottomright: 4px; -webkit-border-bottom-right-radius: 5px; -webkit-border-bottom-left-radius: 5px;"><h3 style="margin: 10px 0 5px; font-size: 17px; font-weight: normal;">
    how to handle this?
</h3>
<span style="margin-bottom: 10px;">
    created by <a href="https://community.jboss.org/people/zydzjy">yu zhou</a> in <i>jBPM</i> - <a href="https://community.jboss.org/message/827890#827890">View the full discussion</a>
</span>
<hr style="margin: 20px 0; border: none; background-color: #dadada; height: 1px;">

<div class="jive-rendered-content"><p> This is my task server:</p><pre class="jive-pre"><code class="jive-code jive-java"> 
<font color="navy"><b>import</b></font> java.util.HashMap;
<font color="navy"><b>import</b></font> java.util.Map;
<font color="navy"><b>import</b></font> javax.persistence.EntityManagerFactory;
<font color="navy"><b>import</b></font> javax.persistence.Persistence;
<font color="navy"><b>import</b></font> org.drools.KnowledgeBaseFactory;
<font color="navy"><b>import</b></font> org.drools.SystemEventListenerFactory;
<font color="navy"><b>import</b></font> org.drools.runtime.Environment;
<font color="navy"><b>import</b></font> org.drools.runtime.EnvironmentName;
<font color="navy"><b>import</b></font> org.jbpm.task.User;
<font color="navy"><b>import</b></font> org.jbpm.task.service.TaskService;
<font color="navy"><b>import</b></font> org.jbpm.task.service.TaskServiceSession;
<font color="navy"><b>import</b></font> org.jbpm.task.service.mina.MinaTaskServer;
 
<font color="navy"><b>import</b></font> bitronix.tm.resource.jdbc.PoolingDataSource;
&#160;
<font color="navy"><b>public</b></font> <font color="navy"><b>class</b></font> JBPMTaskServer<font color="navy">{</font>
 <font color="navy"><b>public</b></font> JBPMTaskServer() <font color="navy">{</font>
&#160; <font color="darkgreen">// TODO Auto-generated constructor stub</font>
 <font color="navy">}</font>
 <font color="darkgreen">/**
&#160; * @param args
&#160; */</font>
 <font color="navy"><b>public</b></font> <font color="navy"><b>static</b></font> <font color="navy"><b>void</b></font> main(String[] args) <font color="navy">{</font>
&#160; <font color="darkgreen">// TODO Auto-generated method stub</font>
&#160; setupDataSource();
&#160; <font color="darkgreen">//String dialect = properties.getProperty("persistence.persistenceunit.dialect", "org.hibernate.dialect.H2Dialect");</font>
&#160; Map&lt;String, String&gt; map = <font color="navy"><b>new</b></font> HashMap&lt;String, String&gt;();
&#160; map.put(<font color="red">"hibernate.dialect"</font>, <font color="red">"org.hibernate.dialect.MySQL5Dialect"</font>);
&#160;&#160;&#160;&#160;&#160;&#160;&#160; EntityManagerFactory emf = Persistence
&#160;&#160;&#160; .createEntityManagerFactory(<font color="red">"org.jbpm.persistence.jpa"</font>,map); 
&#160;&#160; 
<font color="darkgreen">/*&#160; Environment env = KnowledgeBaseFactory.newEnvironment();
&#160; env.set(EnvironmentName.ENTITY_MANAGER_FACTORY, emf);*/</font>
&#160; TaskService taskService = <font color="navy"><b>new</b></font> TaskService(emf, SystemEventListenerFactory.getSystemEventListener());
&#160; TaskServiceSession taskSession = taskService.createSession();
&#160;&#160;&#160;&#160;&#160;&#160;&#160; <font color="darkgreen">// now register new users and groups</font>
&#160;&#160;&#160;&#160;&#160;&#160;&#160; <font color="darkgreen">//taskSession.addUser(new User("mary"));</font>
&#160;&#160;&#160;&#160;&#160;&#160;&#160; <font color="darkgreen">//taskSession.addUser(new User("john"));</font>
&#160; 
&#160; MinaTaskServer server = <font color="navy"><b>new</b></font> MinaTaskServer( taskService );
&#160; Thread thread = <font color="navy"><b>new</b></font> Thread( server );
&#160; thread.start();
 <font color="navy">}</font>
 
 <font color="navy"><b>private</b></font> <font color="navy"><b>static</b></font> <font color="navy"><b>void</b></font> setupDataSource()<font color="navy">{</font>
&#160; PoolingDataSource ds = <font color="navy"><b>new</b></font> PoolingDataSource();
&#160; ds.setUniqueName(<font color="red">"jdbc/jbpm-ds"</font>);
&#160; ds.setClassName(com.mysql.jdbc.jdbc2.optional.MysqlXADataSource.class
&#160;&#160;&#160; .getName());
&#160; ds.setMaxPoolSize(3);
&#160; ds.setAllowLocalTransactions(<font color="navy"><b>true</b></font>);
&#160; ds.getDriverProperties().put(<font color="red">"user"</font>, <font color="red">"jbossjbpm"</font>);
&#160; ds.getDriverProperties().put(<font color="red">"password"</font>, <font color="red">"jbossjbpm"</font>);
&#160; ds.getDriverProperties().put(<font color="red">"URL"</font>, <font color="red">"jdbc:mysql://localhost:3306/jbpm"</font>);
&#160; <font color="darkgreen">// ds.getDriverProperties().put("driverClassName",</font>
&#160; <font color="darkgreen">// "com.mysql.jdbc.Driver");</font>
&#160; ds.init();
 <font color="navy">}</font>
<font color="navy">}</font>
</code></pre><p> And this is my task client,</p><p>and i seprate this class into two projects:</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><pre class="jive-pre"><code class="jive-code jive-java"> 
<font color="navy"><b>import</b></font> java.util.HashMap;
<font color="navy"><b>import</b></font> java.util.Map;
<font color="navy"><b>import</b></font> javax.persistence.EntityManagerFactory;
<font color="navy"><b>import</b></font> javax.persistence.Persistence;
<font color="navy"><b>import</b></font> org.drools.KnowledgeBaseFactory;
<font color="navy"><b>import</b></font> org.drools.SystemEventListenerFactory;
<font color="navy"><b>import</b></font> org.drools.runtime.Environment;
<font color="navy"><b>import</b></font> org.drools.runtime.EnvironmentName;
<font color="navy"><b>import</b></font> org.jbpm.task.User;
<font color="navy"><b>import</b></font> org.jbpm.task.service.TaskService;
<font color="navy"><b>import</b></font> org.jbpm.task.service.TaskServiceSession;
<font color="navy"><b>import</b></font> org.jbpm.task.service.mina.MinaTaskServer;
 
<font color="navy"><b>import</b></font> bitronix.tm.resource.jdbc.PoolingDataSource;
&#160;
<font color="navy"><b>public</b></font> <font color="navy"><b>class</b></font> JBPMTaskServer<font color="navy">{</font>
 <font color="navy"><b>public</b></font> JBPMTaskServer() <font color="navy">{</font>
&#160; <font color="darkgreen">// TODO Auto-generated constructor stub</font>
 <font color="navy">}</font>
 <font color="darkgreen">/**
&#160; * @param args
&#160; */</font>
 <font color="navy"><b>public</b></font> <font color="navy"><b>static</b></font> <font color="navy"><b>void</b></font> main(String[] args) <font color="navy">{</font>
&#160; <font color="darkgreen">// TODO Auto-generated method stub</font>
&#160; setupDataSource();
&#160; <font color="darkgreen">//String dialect = properties.getProperty("persistence.persistenceunit.dialect", "org.hibernate.dialect.H2Dialect");</font>
&#160; Map&lt;String, String&gt; map = <font color="navy"><b>new</b></font> HashMap&lt;String, String&gt;();
&#160; map.put(<font color="red">"hibernate.dialect"</font>, <font color="red">"org.hibernate.dialect.MySQL5Dialect"</font>);
&#160;&#160;&#160;&#160;&#160;&#160;&#160; EntityManagerFactory emf = Persistence
&#160;&#160;&#160; .createEntityManagerFactory(<font color="red">"org.jbpm.persistence.jpa"</font>,map); 
&#160;&#160; 
<font color="darkgreen">/*&#160; Environment env = KnowledgeBaseFactory.newEnvironment();
&#160; env.set(EnvironmentName.ENTITY_MANAGER_FACTORY, emf);*/</font>
&#160; TaskService taskService = <font color="navy"><b>new</b></font> TaskService(emf, SystemEventListenerFactory.getSystemEventListener());
&#160; TaskServiceSession taskSession = taskService.createSession();
&#160;&#160;&#160;&#160;&#160;&#160;&#160; <font color="darkgreen">// now register new users and groups</font>
&#160;&#160;&#160;&#160;&#160;&#160;&#160; <font color="darkgreen">//taskSession.addUser(new User("mary"));</font>
&#160;&#160;&#160;&#160;&#160;&#160;&#160; <font color="darkgreen">//taskSession.addUser(new User("john"));</font>
&#160; 
&#160; MinaTaskServer server = <font color="navy"><b>new</b></font> MinaTaskServer( taskService );
&#160; Thread thread = <font color="navy"><b>new</b></font> Thread( server );
&#160; thread.start();
 <font color="navy">}</font>
 
 <font color="navy"><b>private</b></font> <font color="navy"><b>static</b></font> <font color="navy"><b>void</b></font> setupDataSource()<font color="navy">{</font>
&#160; PoolingDataSource ds = <font color="navy"><b>new</b></font> PoolingDataSource();
&#160; ds.setUniqueName(<font color="red">"jdbc/jbpm-ds"</font>);
&#160; ds.setClassName(com.mysql.jdbc.jdbc2.optional.MysqlXADataSource.class
&#160;&#160;&#160; .getName());
&#160; ds.setMaxPoolSize(3);
&#160; ds.setAllowLocalTransactions(<font color="navy"><b>true</b></font>);
&#160; ds.getDriverProperties().put(<font color="red">"user"</font>, <font color="red">"jbossjbpm"</font>);
&#160; ds.getDriverProperties().put(<font color="red">"password"</font>, <font color="red">"jbossjbpm"</font>);
&#160; ds.getDriverProperties().put(<font color="red">"URL"</font>, <font color="red">"jdbc:mysql://localhost:3306/jbpm"</font>);
&#160; <font color="darkgreen">// ds.getDriverProperties().put("driverClassName",</font>
&#160; <font color="darkgreen">// "com.mysql.jdbc.Driver");</font>
&#160; ds.init();
 <font color="navy">}</font>
<font color="navy">}</font>
&#160;
</code></pre><p>When i run these two classes,and threw the exception:</p><p style="min-height: 8pt; height: 8pt; padding: 0px;">&#160;</p><pre class="jive-pre"><code class="jive-code jive-java">1&#160;&#160;&#160; 15/07 09:30:33,936[main] ERROR workitem.wsht.GenericHTWorkItemHandler.executeWorkItem&#160; - Mon Jul 15 09:30:33 CST 2013: Error when creating task on task server <font color="navy"><b>for</b></font> work item id 7. Error reported by task server: Command AddTaskRequest faild due to Could not commit transaction. Please contact task server administrator.
java.lang.RuntimeException: Command AddTaskRequest faild due to Could not commit transaction. Please contact task server administrator.
 at org.jbpm.task.service.TaskServerHandler.messageReceived(TaskServerHandler.java:729)
 at org.jbpm.task.service.mina.MinaTaskServerHandler.messageReceived(MinaTaskServerHandler.java:41)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain$TailFilter.messageReceived(DefaultIoFilterChain.java:716)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:46)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:796)
 at org.apache.mina.filter.codec.ProtocolCodecFilter$ProtocolDecoderOutputImpl.flush(ProtocolCodecFilter.java:427)
 at org.apache.mina.filter.codec.ProtocolCodecFilter.messageReceived(ProtocolCodecFilter.java:245)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:46)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:796)
 at org.apache.mina.filter.logging.LoggingFilter.messageReceived(LoggingFilter.java:177)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.access$1200(DefaultIoFilterChain.java:46)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain$EntryImpl$1.messageReceived(DefaultIoFilterChain.java:796)
 at org.apache.mina.core.filterchain.IoFilterAdapter.messageReceived(IoFilterAdapter.java:119)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.callNextMessageReceived(DefaultIoFilterChain.java:434)
 at org.apache.mina.core.filterchain.DefaultIoFilterChain.fireMessageReceived(DefaultIoFilterChain.java:426)
 at org.apache.mina.core.polling.AbstractPollingIoProcessor.read(AbstractPollingIoProcessor.java:692)
 at org.apache.mina.core.polling.AbstractPollingIoProcessor.process(AbstractPollingIoProcessor.java:645)
 at org.apache.mina.core.polling.AbstractPollingIoProcessor.process(AbstractPollingIoProcessor.java:634)
 at org.apache.mina.core.polling.AbstractPollingIoProcessor.access$400(AbstractPollingIoProcessor.java:66)
 at org.apache.mina.core.polling.AbstractPollingIoProcessor$Processor.run(AbstractPollingIoProcessor.java:1078)
 at org.apache.mina.util.NamePreservingRunnable.run(NamePreservingRunnable.java:64)
 at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
 at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
 at java.lang.Thread.run(Thread.java:662)
Process started ...7
&#160;
</code></pre></div>

<div style="background-color: #f4f4f4; padding: 10px; margin-top: 20px;">
    <p style="margin: 0;">Reply to this message by <a href="https://community.jboss.org/message/827890#827890">going to Community</a></p>
        <p style="margin: 0;">Start a new discussion in jBPM at <a href="https://community.jboss.org/choose-container!input.jspa?contentType=1&containerType=14&container=2034">Community</a></p>
</div></td>
                        </tr>
                    </tbody>
                </table>


                </td>
            </tr>
        </tbody>
    </table>

</div>

</body>
</html>