- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我对J2EE
不是很熟悉,所以在解释错误时可能会犯一些错误。请耐心等待。
我正在尝试对我的 Java 企业应用程序运行查询,但 glassfish
抛出以下异常:
[#|2014-12-05T15:31:00.412+0200|WARNING|glassfishv3.0|javax.enterprise.system.core.transaction.com.sun.jts.CosTransactions|_ThreadID=86;_ThreadName=Thread-1;|JTS5031: Exception [java.lang.RuntimeException: org.postgresql.xa.PGXAException: Error preparing transaction] on Resource [prepare] operation.|#]
[#|2014-12-05T15:31:00.413+0200|SEVERE|glassfishv3.0|javax.enterprise.system.core.transaction.com.sun.jts.CosTransactions|_ThreadID=86;_ThreadName=Thread-1;|JTS5031: Exception [org.omg.CORBA.INTERNAL: vmcid: 0x0 minor code: 0 completed: Maybe] on Resource [rollback] operation.|#]
[#|2014-12-05T15:31:00.439+0200|WARNING|glassfishv3.0|javax.enterprise.system.container.ejb.com.sun.ejb.containers|_ThreadID=86;_ThreadName=Thread-1;|A system exception occurred during an invocation on EJB OFReportTimeoutService method public void com.companyname.appname.service.OFReportTimeoutService.ofTimeout()
javax.ejb.EJBException: Unable to complete container-managed transaction.
at com.sun.ejb.containers.BaseContainer.completeNewTx(BaseContainer.java:4962)
at com.sun.ejb.containers.BaseContainer.postInvokeTx(BaseContainer.java:4716)
at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:1941)
at com.sun.ejb.containers.BaseContainer.postInvoke(BaseContainer.java:1892)
at com.sun.ejb.containers.EJBLocalObjectInvocationHandler.invoke(EJBLocalObjectInvocationHandler.java:198)
at com.sun.ejb.containers.EJBLocalObjectInvocationHandlerDelegate.invoke(EJBLocalObjectInvocationHandlerDelegate.java:84)
at com.sun.proxy.$Proxy307.ofTimeout(Unknown Source)
at com.companyname.appname.service.__EJB31_Generated__OFReportTimeoutService__Intf____Bean__.ofTimeout(Unknown Source)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at com.companyname.appname.servlet.GFv3EJBInvokerJob.execute(GFv3EJBInvokerJob.java:88)
at org.quartz.core.JobRunShell.run(JobRunShell.java:213)
at org.quartz.simpl.SimpleThreadPool$WorkerThread.run(SimpleThreadPool.java:557)
Caused by: javax.transaction.SystemException: org.omg.CORBA.INTERNAL: JTS5031: Exception [org.omg.CORBA.INTERNAL: vmcid: 0x0 minor code: 0 completed: Maybe] on Resource [rollback] operation. vmcid: 0x0 minor code: 0 completed: No
at com.sun.jts.jta.TransactionManagerImpl.commit(TransactionManagerImpl.java:330)
at com.sun.enterprise.transaction.jts.JavaEETransactionManagerJTSDelegate.commitDistributedTransaction(JavaEETransactionManagerJTSDelegate.java:169)
at com.sun.enterprise.transaction.JavaEETransactionManagerSimplified.commit(JavaEETransactionManagerSimplified.java:843)
at com.sun.ejb.containers.BaseContainer.completeNewTx(BaseContainer.java:4951)
... 14 more
|#]
另一个具有相同版本的glassfish
、postgresql
和web 应用程序的系统没有抛出任何异常。它们都有相同的 domain.xml
和 postgresql.conf
文件。
我已将 max_prepared_transactions
从 100
更改为 10000
并将 shared_buffers
从 32MB
到 320MB
但它不起作用。
有什么想法吗?
编辑 ofTimeout
添加代码。
@Startup
@Singleton(mappedName="OFReportTimeoutService")
public class OFReportTimeoutService {
@EJB
protected QueueManagerService queueManagerService;
@EJB
protected AnalyzerService analyzerService;
@EJB
protected ErrorReportJpaController errorReportJpaController;
@EJB
protected ReportJpaController reportJpaController;
protected Boolean isProcessing = Boolean.FALSE;
private Boolean exceptionPresent = Boolean.FALSE;
private String errorText = "error";
private Integer reportId = 0;
//@Schedule(second="*/10", minute="*", hour="*", persistent=false)
public void ofTimeout() {
//System.out.println("STATE : " + "OfReportTimeOutService is running...") ;
if(exceptionPresent) {
ErrorReport errorReport = errorReportJpaController.create();
errorReport.setErrorDate(new Date());
errorReport.setErrorText(errorText);
errorReport.setReport(reportJpaController.find(reportId));
errorReportJpaController.persist(errorReport);
exceptionPresent = Boolean.FALSE;
if (queueManagerService.getLastReport() != null)
queueManagerService.resetLastReport();
isProcessing = Boolean.FALSE;
}
if (isProcessing)
return;
if (queueManagerService.reportQueueSize() > 0)
isProcessing = Boolean.TRUE;
else {
//System.out.println("STATE : " + "queueManagerService.reportQueueSize == 0 !!!") ;
return;
}
while (queueManagerService.reportQueueSize() > 0)
try {
Report report = queueManagerService.pullReport();
reportId = report.getId();
if ( reportId != null )
System.out.println("STATE : " + "reportId var") ;
analyzerService.process(report);
} catch (ReportJPAException rex) {
Logger.getLogger(OFReportTimeoutService.class.getName()).log(Level.SEVERE, null, rex);
exceptionPresent = Boolean.TRUE;
errorText = rex.toString();
break;
} catch (RuntimeException rex) {
Logger.getLogger(OFReportTimeoutService.class.getName()).log(Level.SEVERE, null, rex);
exceptionPresent = Boolean.TRUE;
errorText = rex.toString();
break;
} catch (Exception ex) {
Logger.getLogger(OFReportTimeoutService.class.getName()).log(Level.SEVERE, null, ex);
exceptionPresent = Boolean.TRUE;
errorText = ex.toString();
break;
}
if(exceptionPresent) {
return;
}
isProcessing = Boolean.FALSE;
queueManagerService.resetLastReport();
}
public Boolean isProcessing() {
return isProcessing;
}
public void setProcessing(Boolean isProcessing) {
this.isProcessing = isProcessing;
}
}
最佳答案
我已经解决了这个问题。我们正在使用 bucardo
来复制我们的 postgresql 数据库。这就是我遇到问题的原因。在 postgresql 日志中,我看到了这样的错误日志:
ERROR: cannot PREPARE a transaction that has executed LISTEN, UNLISTEN or NOTIFY
在this blog post问题原因已说明:
The problem is that the Postgres LISTEN/NOTIFY system cannot be used with prepared transactions. Bucardo uses a trigger on the source tables that issues a NOTIFY to let the main Bucardo daemon know that something has changed and needs to be replicated. However, their application was issuing a PREPARE TRANSACTION as an occasional part of its work. Thus, they would update the table, which would fire the trigger, which would send the NOTIFY. Then the application would issue the PREPARE TRANSACTION which produced the error given above. Bucardo is setup to deal with this situation; rather than using notify triggers, the Bucardo daemon can be set to look for any changes at a set interval. The steps to change Bucardo's behavior for a given sync is simply:
博文中的解决方案对我们不起作用。我们可以承受不复制导致错误的数据库。因此,我们使用以下命令删除了复制:
[root@Baskan config]# bucardo deactivate synclrms
Deactivating sync synclrms
[root@Baskan config]# bucardo purge synclrms
Purging name synclrms
[root@Baskan config]# bucardo remove sync synclrms
Removed sync "synclrms"
Note: table triggers (if any) are not automatically removed!
由于触发器不会自动删除,因此应手动删除它们:在我们的例子中,有三个触发器。他们的名字是:bucardo_delta、bucardo_kick_synclrms、bucardo_note_trunc_synclrms
bucardo_note_trunc_synclrms
要删除触发器,请使用以下命令:
drop TRIGGER trigger_name on table_name;
以防万一bucardo放置的表上可能有其他触发器,您可以在postgresql中使用以下命令查看表上的所有触发器:
\dS table_name;
完成这些步骤后,系统开始正常工作,没有抛出任何异常。
关于java - glassfish 抛出 org.postgresql.xa.PGXAException,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27318722/
Schema.org、Goodrelations-vocabulary.org 和 Productontology.org 之间有什么关系? Schema.org 告知,“W3C schema.org
大家好,我想知道包 org.ietf、org.omg、org.w3c 和 org 是如何实现的.xml 已进入 "official" Java classes ? 例如,默认 JDK 不会包含 Apa
首先,我试图用来自 Schema.org 的属性定义数据库表,例如,例如,我有一个名为“JobPosting”的表,它或多或少具有与 http://schema.org/JobPosting 中定义的
我有一个 org.w3c.dom.Document 被 org.dom4j.io.DOMReader 解析。 我想通过 org.w3c.dom.Element 搜索 dom4j DOM 文档。 比方说
我正在将我的应用程序部署到 Tomcat 6.0.20。 应用程序使用 Hibernate 作为 Web 层的 ORM、Spring 和 JSF。 我还从 main() 方法制作了简单的运行器来测试
我有一个使用 hibernate > 4 的 gradle 项目。如果我在 Apache tomcat 中运行我的 war 文件,我不会收到任何错误。但是当我在 Wildfly 8.2 中部署它时,出
我正在尝试将 JaCoCo 添加到我的 Android 以覆盖 Sonar Qube。但是在运行命令 ./gradlew jacocoTestReport 时,我收到以下错误。 Task :app:
如何在 emacs 组织模式中格式化日期? 例如,在下表中,我希望日期显示为“Aug 29”或“Wed, Aug 29”而不是“” #+ATTR_HTML: border="2" rules="all
我想使用 org 模式来写一本技术书籍。我正在寻找一种将外部文件中的现有代码插入到 babel 代码块中的方法,该代码块在导出为 pdf 时会提供很好的格式。 例如 #+BEGIN_SRC pytho
用作引用:https://support.google.com/webmasters/answer/146750?hl=en 您会注意到在“产品”下有一个属性类别,此外页面下方还有一个示例: Too
我读了这个Google doc .它说我们不使用列表中的产品。 那么对于产品列表(具有多页的类似产品的类别,如“鞋子”),推荐使用哪种模式? 我用这个: { "@context": "htt
我目前在做DBpedia数据集,想通过wikidata实现schema.org和DBpedia的映射。因此我想知道 schema.org 和 wikidata 之间是否存在任何映射。 最佳答案 我认为
我爱org-tables ,我用它们来记录各种事情。我现在正在为 Nix 记录一些单行代码(在阅读了 Domen Kožar 的 excellent guide 后,在 this year's Eur
如果看一下 Movie在 schema.org 中输入,actor 和 actors 属性都是允许的(actor 取代 actors)。但是 author 和 contributor 属性没有等效项。
我们有一些餐厅有多个地点或分支机构。我想包含正确的 Schema.org 标记,但找不到任何允许列出多个餐厅的内容。 每家餐厅都有自己的地址、电子邮件、电话和营业时间,甚至可能是“分店名称”。 两个分
我在一个页面中有多个综合评分片段。 有没有办法让其中之一成为默认值?将显示在搜索引擎结果中的那个? 谢谢大家! 更新:该网页本质上是品牌的页面。它包含品牌评论的总评分及其产品列表(每个产品的总评分)。
我提到了一些相关的职位,但并没有解决我的问题。因为我正在使用maven-jar-plugin-2.4 jar。 我正在使用JBoss Developer Studio 7.1.1 GA IDE,并且正
网站的根页面(即 http://example.com/ )的特殊之处在于它是默认的着陆页。它可能包含许多不同的对象类型。 它可能被认为是一个网站,或者一个博客等... 但它是否也应该被标记为给定对象
我想将一些文本放入一个 org 文件中,当我将内容导出到其中一种目标类型(在本例中为 HTML)时,该文件不会发布。有什么方法可以实现这个目标吗? 最佳答案 您可能想要使用 :noexport: 标签
org-mode 是否有一个键绑定(bind)可以在编号/项目符号列表项之间移动,就像您可以对标题一样? 喜欢的功能: org-forward-heading-same-level 大纲下一个可见标题
我是一名优秀的程序员,十分优秀!