You are viewing a plain text version of this content. The canonical link for it is here.
Posted to users@deltaspike.apache.org by 十三郎 <mi...@163.com> on 2013/10/27 02:50:31 UTC
Unsatisfied dependencies for type TransactionStrategy error on
tomcat8
hi everyone:
i write a simple apache deltaspike jpa demo,run to error on tomcat8.0.
(i use tomcat8.0rc5 ; jdk1.7 ,deltaspike0.5)
1,first,i define a EntityManagerProducer
public class EntityManagerProducer
{
@PersistenceContext(unitName = "persistence0")
private EntityManager entityManager;
@Produces
@RequestScoped
protected EntityManager createEntityManager()
{
return this.entityManager;
}
protected void closeEntityManager(@Disposes EntityManager entityManager)
{
if (entityManager.isOpen())
{
entityManager.close();
}
}
}
2,and i want do some database transactional work manually(i wanna a manual way).
---------------------------
@Named
@SessionScoped
public class Test implements Serializable
{
private static final long serialVersionUID = -1231439157655757940L;
public String test1(){
EntityManager entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
entityManager0.getTransaction().begin();
try{
//just fill some test data to database
String sql="insert into grandscape_user (user_name,user_password) values (:u,:p)";
Query query=entityManager0.createNativeQuery(sql);
query.setParameter("u", "Jason Porter");
query.setParameter("p", "secrete");
query.executeUpdate();
entityManager0.getTransaction().commit();
return "success";
}catch(Exception ex){
entityManager0.getTransaction().rollback();
return ex.getMessage();
}
}
}
-------------------
3,and persistence.xml.
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
version="2.0">
<persistence-unit name="persistence0" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<properties>
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
<property name="hibernate.connection.username" value="root" />
<property name="hibernate.connection.password" value="root" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect"/>
<property name="hibernate.connection.autocommit" value="true" />
<property name="hibernate.hbm2ddl.auto" value="validate"/>
<property name="hibernate.show_sql" value="false"/>
<property name="hibernate.cache.use_second_level_cache" value="true"/>
<property name="hibernate.cache.provider_class" value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
<property name="hibernate.search.default.directory_provider" value="org.hibernate.search.store.FSDirectoryProvider"/>
<property name="hibernate.search.default.indexBase" value="./lucene/indexes"/>
<property name="hibernate.search.default.batch.merge_factor" value="10"/>
<property name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
</properties>
</persistence-unit>
</persistence>
------------
4,finally,when i deployed the program to tomcat,the error occured:
----------
26-Oct-2013 12:04:51.642 SEVERE [http-nio-8080-exec-6] org.apache.catalina.core.StandardContext.listenerStart Exception sending context initialized event to listener instance of class org.jboss.weld.environment.servlet.Listener
org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied dependencies for type TransactionStrategy with qualifiers @Default
at injection point [BackedAnnotatedField] @Inject private org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy
at org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0)
at org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405)
at org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327)
at org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565)
at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88)
at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86)
at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
at java.util.concurrent.FutureTask.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
26-Oct-2013 12:04:52.161 SEVERE [http-nio-8080-exec-6] org.apache.catalina.core.StandardContext.listenerStop Exception sending context destroyed event to listener instance of class org.jboss.weld.environment.servlet.Listener
java.lang.NullPointerException
at org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
at org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
at org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:456)
at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1534)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:300)
at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(Unknown Source)
at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(Unknown Source)
at org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1430)
at org.apache.catalina.manager.ManagerServlet.deploy(ManagerServlet.java:704)
at org.apache.catalina.manager.ManagerServlet.doPut(ManagerServlet.java:430)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.filters.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:108)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:221)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:107)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:616)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:76)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:934)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:90)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:515)
at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1012)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:642)
at org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:223)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1597)
at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1555)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
--------
5.the pom.xml
------
<?xml version="1.0"?>
<project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<modelVersion>4.0.0</modelVersion>
<groupId>grandscape</groupId>
<artifactId>prog_tomcat</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>prog_tomcat Maven Webapp</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<deltaspike.version>0.5</deltaspike.version>
<picketlink.version>2.5.2.Final</picketlink.version>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>com.sun.faces</groupId>
<artifactId>jsf-api</artifactId>
<version>2.2.4</version>
</dependency>
<dependency>
<groupId>com.sun.faces</groupId>
<artifactId>jsf-impl</artifactId>
<version>2.2.4</version>
</dependency>
<dependency>
<groupId>javax.enterprise</groupId>
<artifactId>cdi-api</artifactId>
<version>1.1</version>
</dependency>
<dependency>
<groupId>org.jboss.weld.servlet</groupId>
<artifactId>weld-servlet</artifactId>
<version>2.0.4.Final</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.5</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.5</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
<version>1.1.3</version>
</dependency>
<dependency>
<groupId>org.apache.deltaspike.core</groupId>
<artifactId>deltaspike-core-api</artifactId>
<version>${deltaspike.version}</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.deltaspike.core</groupId>
<artifactId>deltaspike-core-impl</artifactId>
<version>${deltaspike.version}</version>
<scope>runtime</scope>
</dependency>
<dependency>
<version>1.0.1.Final</version>
<groupId>org.hibernate.javax.persistence</groupId>
<artifactId>hibernate-jpa-2.0-api</artifactId>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.2.6.Final</version>
</dependency>
<dependency>
<groupId>org.apache.deltaspike.modules</groupId>
<artifactId>deltaspike-jpa-module-api</artifactId>
<version>${deltaspike.version}</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.deltaspike.modules</groupId>
<artifactId>deltaspike-jpa-module-impl</artifactId>
<version>${deltaspike.version}</version>
<scope>runtime</scope>
</dependency>
</dependencies>
<repositories>
<repository>
<id>people.apache.snapshots</id>
<url>
http://repository.apache.org/content/groups/snapshots-group/
</url>
<releases>
<enabled>false</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories> <pluginRepository>
<id>apache.snapshots</id>
<name>Apache Snapshots</name>
<url>
http://repository.apache.org/content/groups/snapshots-group/
</url>
<releases>
<enabled>false</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</pluginRepository></pluginRepositories>
<build>
<finalName>prog_tomcat</finalName>
<plugins>
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.1</version>
<configuration>
<server>mytomcat</server>
<url>http://localhost:8080/manager/text</url>
<contextReloadable>true</contextReloadable>
</configuration>
</plugin>
</plugins>
</build>
</project>
thanks everyone !!!
Re: Unsatisfied dependencies for type TransactionStrategy error on tomcat8
Posted by Gerhard Petracek <ge...@gmail.com>.
hi,
here i've basically the same in a demo-app (just with owb instead of weld)
and it works fine.
-> if your setup works with tomcat 7, you could contact the weld-list
(since our tests pass with weld 2.0.4).
fyi: you can use TransactionHelper for #2.
regards,
gerhard
2013/10/27 十三郎 <mi...@163.com>
>
> hi everyone:
>
> i write a simple apache deltaspike jpa demo,run to error on tomcat8.0.
> (i use tomcat8.0rc5 ; jdk1.7 ,deltaspike0.5)
>
> 1,first,i define a EntityManagerProducer
> public class EntityManagerProducer
> {
> @PersistenceContext(unitName = "persistence0")
> private EntityManager entityManager;
> @Produces
> @RequestScoped
> protected EntityManager createEntityManager()
> {
> return this.entityManager;
> }
> protected void closeEntityManager(@Disposes EntityManager
> entityManager)
> {
> if (entityManager.isOpen())
> {
> entityManager.close();
> }
> }
> }
>
>
> 2,and i want do some database transactional work manually(i wanna a manual
> way).
> ---------------------------
> @Named
> @SessionScoped
> public class Test implements Serializable
> {
> private static final long serialVersionUID = -1231439157655757940L;
> public String test1(){
> EntityManager
> entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
> entityManager0.getTransaction().begin();
> try{
> //just fill some test data to database
> String sql="insert into grandscape_user
> (user_name,user_password) values (:u,:p)";
> Query query=entityManager0.createNativeQuery(sql);
> query.setParameter("u", "Jason Porter");
> query.setParameter("p", "secrete");
> query.executeUpdate();
> entityManager0.getTransaction().commit();
> return "success";
> }catch(Exception ex){
> entityManager0.getTransaction().rollback();
> return ex.getMessage();
> }
> }
> }
> -------------------
>
>
> 3,and persistence.xml.
> <?xml version="1.0" encoding="UTF-8"?>
> <persistence xmlns="http://java.sun.com/xml/ns/persistence"
> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
> xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
> http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
> version="2.0">
> <persistence-unit name="persistence0"
> transaction-type="RESOURCE_LOCAL">
> <provider>org.hibernate.ejb.HibernatePersistence</provider>
> <properties>
> <property name="hibernate.connection.driver_class"
> value="com.mysql.jdbc.Driver"/>
> <property name="hibernate.connection.url"
> value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
> <property name="hibernate.connection.username" value="root" />
> <property name="hibernate.connection.password" value="root" />
> <property name="hibernate.dialect"
> value="org.hibernate.dialect.MySQLInnoDBDialect"/>
> <property name="hibernate.connection.autocommit" value="true"
> />
> <property name="hibernate.hbm2ddl.auto" value="validate"/>
> <property name="hibernate.show_sql" value="false"/>
> <property name="hibernate.cache.use_second_level_cache"
> value="true"/>
> <property name="hibernate.cache.provider_class"
> value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
> <property name="hibernate.search.default.directory_provider"
> value="org.hibernate.search.store.FSDirectoryProvider"/>
> <property name="hibernate.search.default.indexBase"
> value="./lucene/indexes"/>
> <property name="hibernate.search.default.batch.merge_factor"
> value="10"/>
> <property
> name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
> </properties>
> </persistence-unit>
> </persistence>
> ------------
>
>
> 4,finally,when i deployed the program to tomcat,the error occured:
> ----------
> 26-Oct-2013 12:04:51.642 SEVERE [http-nio-8080-exec-6]
> org.apache.catalina.core.StandardContext.listenerStart Exception sending
> context initialized event to listener instance of class
> org.jboss.weld.environment.servlet.Listener
> org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied
> dependencies for type TransactionStrategy with qualifiers @Default
> at injection point [BackedAnnotatedField] @Inject private
> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy
> at
> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0)
>
> at
> org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405)
> at
> org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327)
> at
> org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565)
> at
> org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88)
> at
> org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86)
> at
> org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
> at
> org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
> at java.util.concurrent.FutureTask.run(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
> at java.lang.Thread.run(Unknown Source)
>
> 26-Oct-2013 12:04:52.161 SEVERE [http-nio-8080-exec-6]
> org.apache.catalina.core.StandardContext.listenerStop Exception sending
> context destroyed event to listener instance of class
> org.jboss.weld.environment.servlet.Listener
> java.lang.NullPointerException
> at
> org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
> at
> org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
> at
> org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
> at
> org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
> at
> org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
> at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
> at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
> at
> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
> at
> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
> at
> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
> at
> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
> at
> org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:456)
> at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1534)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
> at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
> at java.lang.reflect.Method.invoke(Unknown Source)
> at
> org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:300)
> at
> com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(Unknown Source)
> at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(Unknown Source)
> at
> org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1430)
> at
> org.apache.catalina.manager.ManagerServlet.deploy(ManagerServlet.java:704)
> at
> org.apache.catalina.manager.ManagerServlet.doPut(ManagerServlet.java:430)
> at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
> at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
> at
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
> at
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> at
> org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)
> at
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
> at
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> at
> org.apache.catalina.filters.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:108)
> at
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
> at
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> at
> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:221)
> at
> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:107)
> at
> org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:616)
> at
> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155)
> at
> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:76)
> at
> org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:934)
> at
> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:90)
> at
> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:515)
> at
> org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1012)
> at
> org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:642)
> at
> org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:223)
> at
> org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1597)
> at
> org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1555)
> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
> at java.lang.Thread.run(Unknown Source)
> --------
>
> 5.the pom.xml
> ------
> <?xml version="1.0"?>
> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
> http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="
> http://maven.apache.org/POM/4.0.0"
> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
> <modelVersion>4.0.0</modelVersion>
> <groupId>grandscape</groupId>
> <artifactId>prog_tomcat</artifactId>
> <version>0.0.1-SNAPSHOT</version>
> <packaging>war</packaging>
> <name>prog_tomcat Maven Webapp</name>
> <url>http://maven.apache.org</url>
>
> <properties>
> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
> <deltaspike.version>0.5</deltaspike.version>
> <picketlink.version>2.5.2.Final</picketlink.version>
> </properties>
> <dependencies>
> <dependency>
> <groupId>junit</groupId>
> <artifactId>junit</artifactId>
> <version>4.11</version>
> <scope>test</scope>
> </dependency>
> <dependency>
> <groupId>com.sun.faces</groupId>
> <artifactId>jsf-api</artifactId>
> <version>2.2.4</version>
> </dependency>
> <dependency>
> <groupId>com.sun.faces</groupId>
> <artifactId>jsf-impl</artifactId>
> <version>2.2.4</version>
> </dependency>
> <dependency>
> <groupId>javax.enterprise</groupId>
> <artifactId>cdi-api</artifactId>
> <version>1.1</version>
> </dependency>
> <dependency>
> <groupId>org.jboss.weld.servlet</groupId>
> <artifactId>weld-servlet</artifactId>
> <version>2.0.4.Final</version>
> </dependency>
> <dependency>
> <groupId>log4j</groupId>
> <artifactId>log4j</artifactId>
> <version>1.2.17</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.slf4j</groupId>
> <artifactId>slf4j-api</artifactId>
> <version>1.7.5</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.slf4j</groupId>
> <artifactId>slf4j-log4j12</artifactId>
> <version>1.7.5</version>
> <scope>compile</scope>
> </dependency>
>
> <dependency>
> <groupId>commons-logging</groupId>
> <artifactId>commons-logging</artifactId>
> <version>1.1.3</version>
> </dependency>
> <dependency>
> <groupId>org.apache.deltaspike.core</groupId>
> <artifactId>deltaspike-core-api</artifactId>
> <version>${deltaspike.version}</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.apache.deltaspike.core</groupId>
> <artifactId>deltaspike-core-impl</artifactId>
> <version>${deltaspike.version}</version>
> <scope>runtime</scope>
> </dependency>
> <dependency>
> <version>1.0.1.Final</version>
> <groupId>org.hibernate.javax.persistence</groupId>
> <artifactId>hibernate-jpa-2.0-api</artifactId>
> <scope>provided</scope>
> </dependency>
>
> <dependency>
> <groupId>org.hibernate</groupId>
> <artifactId>hibernate-core</artifactId>
> <version>4.2.6.Final</version>
> </dependency>
>
> <dependency>
> <groupId>org.apache.deltaspike.modules</groupId>
> <artifactId>deltaspike-jpa-module-api</artifactId>
> <version>${deltaspike.version}</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.apache.deltaspike.modules</groupId>
> <artifactId>deltaspike-jpa-module-impl</artifactId>
> <version>${deltaspike.version}</version>
> <scope>runtime</scope>
> </dependency>
> </dependencies>
> <repositories>
> <repository>
> <id>people.apache.snapshots</id>
> <url>
> http://repository.apache.org/content/groups/snapshots-group/
> </url>
> <releases>
> <enabled>false</enabled>
> </releases>
> <snapshots>
> <enabled>true</enabled>
> </snapshots>
> </repository>
> </repositories>
> <pluginRepositories> <pluginRepository>
> <id>apache.snapshots</id>
> <name>Apache Snapshots</name>
> <url>
> http://repository.apache.org/content/groups/snapshots-group/
> </url>
> <releases>
> <enabled>false</enabled>
> </releases>
> <snapshots>
> <enabled>true</enabled>
> </snapshots>
> </pluginRepository></pluginRepositories>
> <build>
> <finalName>prog_tomcat</finalName>
> <plugins>
> <plugin>
> <groupId>org.apache.tomcat.maven</groupId>
> <artifactId>tomcat7-maven-plugin</artifactId>
> <version>2.1</version>
> <configuration>
> <server>mytomcat</server>
> <url>http://localhost:8080/manager/text</url>
> <contextReloadable>true</contextReloadable>
> </configuration>
> </plugin>
> </plugins>
> </build>
> </project>
>
> thanks everyone !!!
Re:Re: Re: Unsatisfied dependencies for type TransactionStrategy
error on tomcat8
Posted by 十三郎 <mi...@163.com>.
Rodrigo:thanks!!!
if i remove this block from bean.xml
------
<interceptors>
<class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
</interceptors>
------
the error message occured.
-----
29-Oct-2013 18:57:40.366 SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.listenerStart Exception sending context initialized event to listener instance of class org.jboss.weld.environment.servlet.Listener
org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied dependencies for type TransactionStrategy with qualifiers @Default
at injection point [BackedAnnotatedField] @Inject private org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy
at org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0)
at org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405)
at org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327)
at org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565)
at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88)
at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86)
at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
at java.util.concurrent.FutureTask.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
29-Oct-2013 18:57:41.237 SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.listenerStop Exception sending context destroyed event to listener instance of class org.jboss.weld.environment.servlet.Listener
java.lang.NullPointerException
at org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
at org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
at org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742)
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source)
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
at java.util.concurrent.FutureTask.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
----
At 2013-10-29 18:38:11,"Rodrigo Mesquita" <ro...@tre-se.jus.br> wrote:
>Try to remove of your beans.xml
>
> <interceptors>
> <class>org.apache.deltaspike.jpa.impl.transaction.
>TransactionalInterceptor</class>
> </interceptors>
>
>Don't know if 0.5 version of jpa module need this configuration, because it
>has an already configured beans.xml
>
>
>--
>
>Rodrigo Cardoso Mesquita
>
>Tel.: (79) 2106-8703
>Seção de Desenvolvimento de Sistemas
>Tribunal Regional Eleitoral de Sergipe
>SEDES / COSIS / STI / TRE-SE
>
>
>
>2013/10/29 十三郎 <mi...@163.com>
>
>> Rodrigo:thanks very much!!!
>>
>> i change my code to use @Transactional annotation instead of a
>> BMT(manual) way.
>> i want to test if code work fine in a CMT way.
>>
>> 1.EntityManagerProducer
>> ---
>> public class EntityManagerProducer
>> {
>> @PersistenceContext(unitName = "persistence0")
>> private EntityManager entityManager;
>> @Produces
>> @SessionScoped
>> protected EntityManager createEntityManager()
>> {
>> return this.entityManager;
>> }
>> protected void closeEntityManager(@Disposes EntityManager
>> entityManager)
>> {
>> if (entityManager.isOpen())
>> {
>> entityManager.close();
>> }
>> }
>> }
>> ---
>> 2.do some database transactional work in a CMT way
>> ---
>> import java.io.Serializable;
>> import javax.enterprise.context.SessionScoped;
>> import javax.inject.Inject;
>> import javax.inject.Named;
>> import javax.persistence.EntityManager;
>> import javax.persistence.Query;
>> import org.apache.deltaspike.core.api.provider.BeanProvider;
>> import org.apache.deltaspike.jpa.api.transaction.Transactional;
>>
>> @Named
>> @SessionScoped
>> @Transactional
>> public class Test implements Serializable
>> {
>> private static final long serialVersionUID = -1231439157655757940L;
>> @Inject CurrentUser currentUser;
>> @Transactional
>> public String test1(){
>> EntityManager
>> entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
>> //just fill some test data to database
>> String sql="insert into grandscape_user
>> (user_name,user_password) values (:u,:p)";
>> Query query=entityManager0.createNativeQuery(sql);
>> query.setParameter("u", "Jason Porter");
>> query.setParameter("p", "secrete");
>> query.executeUpdate();
>> return "success";
>> }
>> }
>> ---
>>
>> 3.persistence.xml
>> ---
>> <?xml version="1.0" encoding="UTF-8"?>
>> <persistence xmlns="http://java.sun.com/xml/ns/persistence"
>> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
>> xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
>> http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
>> version="2.0">
>> <persistence-unit name="persistence0"
>> transaction-type="RESOURCE_LOCAL">
>> <provider>org.hibernate.ejb.HibernatePersistence</provider>
>> <properties>
>> <property name="hibernate.connection.driver_class"
>> value="com.mysql.jdbc.Driver"/>
>> <property name="hibernate.connection.url"
>> value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
>> <property name="hibernate.connection.username"
>> value="root" />
>> <property name="hibernate.connection.password"
>> value="root" />
>> <property name="hibernate.dialect"
>> value="org.hibernate.dialect.MySQLInnoDBDialect"/>
>> <property name="hibernate.connection.autocommit" value="true"
>> />
>> <property name="hibernate.hbm2ddl.auto" value="validate"/>
>> <property name="hibernate.show_sql" value="false"/>
>> <property name="hibernate.cache.use_second_level_cache"
>> value="true"/>
>> <property name="hibernate.cache.provider_class"
>> value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
>> <property name="hibernate.search.default.directory_provider"
>> value="org.hibernate.search.store.FSDirectoryProvider"/>
>> <property name="hibernate.search.default.indexBase"
>> value="./lucene/indexes"/>
>> <property name="hibernate.search.default.batch.merge_factor"
>> value="10"/>
>> <property
>> name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
>> </properties>
>> </persistence-unit>
>> </persistence>
>> ---
>>
>> 4.bean.xml
>> ---
>> <?xml version="1.0" encoding="UTF-8"?>
>> <beans xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="
>> http://www.w3.org/2001/XMLSchema-instance"
>> xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
>> http://java.sun.com/xml/ns/javaee/beans_1_0.xsd">
>> <interceptors>
>>
>> <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
>> </interceptors>
>> </beans>
>> ---
>>
>> when i deployed the program to tomcat,the error occured.
>> -----
>> 29-Oct-2013 18:05:16.536 SEVERE [localhost-startStop-1]
>> org.apache.catalina.core.StandardContext.listenerStart Exception sending
>> context initialized event to listener instance of class
>> org.jboss.weld.environment.servlet.Listener
>> org.jboss.weld.exceptions.DeploymentException: WELD-001416 Enabled
>> interceptor class
>> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor
>> specified twice:
>> -
>> <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
>> in
>> jar:file:/D:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/lib/deltaspike-jpa-module-impl-0.5.jar!/META-INF/beans.xml@24
>> ,
>> -
>> <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
>> in file:/d:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/beans.xml@5
>> at
>> org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.checkForDuplicates(GlobalEnablementBuilder.java:249)
>> at
>> org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.createModuleEnablement(GlobalEnablementBuilder.java:226)
>> at
>> org.jboss.weld.bootstrap.BeanDeployment.createEnabled(BeanDeployment.java:221)
>> at
>> org.jboss.weld.bootstrap.WeldBootstrap.startInitialization(WeldBootstrap.java:488)
>> at
>> org.jboss.weld.environment.servlet.Listener.contextInitialized(Listener.java:141)
>> at
>> org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4830)
>> at
>> org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5276)
>> at
>> org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
>> at
>> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
>> at
>> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
>> at
>> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
>> at
>> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
>> at
>> org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742)
>> at java.util.concurrent.Executors$RunnableAdapter.call(Unknown
>> Source)
>> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
>> at java.util.concurrent.FutureTask.run(Unknown Source)
>> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown
>> Source)
>> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown
>> Source)
>> at java.lang.Thread.run(Unknown Source)
>>
>> 29-Oct-2013 18:05:17.174 SEVERE [localhost-startStop-1]
>> org.apache.catalina.core.StandardContext.listenerStop Exception sending
>> context destroyed event to listener instance of class
>> org.jboss.weld.environment.servlet.Listener
>> java.lang.NullPointerException
>> at
>> org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
>> at
>> org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
>> at
>> org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
>> at
>> org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
>> at
>> org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
>> at
>> org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
>> at
>> org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
>> at
>> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
>> at
>> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
>> at
>> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
>> at
>> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
>> at
>> org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742)
>> at java.util.concurrent.Executors$RunnableAdapter.call(Unknown
>> Source)
>> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
>> at java.util.concurrent.FutureTask.run(Unknown Source)
>> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown
>> Source)
>> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown
>> Source)
>> at java.lang.Thread.run(Unknown Source)
>> -----
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>>
>> At 2013-10-27 17:10:34,Rodrigo <rc...@gmail.com> wrote:
>> >I think the problem is the use of PersistenceContext annotation on
>> Resource_local entityManager. If you want to manage the transactions, dont
>> use this annotation, because it indicates container responsability of
>> entity managers.
>> >
>> >You must have a static EntityManagerFactory created and the producer
>> method must create the entitymanager from factory.
>> >
>> >Rodrigo
>> >
>> >
>> >
>> >
>> >Enviado via iPhone
>> >
>> >Em 26/10/2013, às 23:50, 十三郎 <mi...@163.com> escreveu:
>> >
>> >>
>> >> hi everyone:
>> >>
>> >> i write a simple apache deltaspike jpa demo,run to error on tomcat8.0.
>> >> (i use tomcat8.0rc5 ; jdk1.7 ,deltaspike0.5)
>> >>
>> >> 1,first,i define a EntityManagerProducer
>> >> public class EntityManagerProducer
>> >> {
>> >> @PersistenceContext(unitName = "persistence0")
>> >> private EntityManager entityManager;
>> >> @Produces
>> >> @RequestScoped
>> >> protected EntityManager createEntityManager()
>> >> {
>> >> return this.entityManager;
>> >> }
>> >> protected void closeEntityManager(@Disposes EntityManager
>> entityManager)
>> >> {
>> >> if (entityManager.isOpen())
>> >> {
>> >> entityManager.close();
>> >> }
>> >> }
>> >> }
>> >>
>> >>
>> >> 2,and i want do some database transactional work manually(i wanna a
>> manual way).
>> >> ---------------------------
>> >> @Named
>> >> @SessionScoped
>> >> public class Test implements Serializable
>> >> {
>> >> private static final long serialVersionUID = -1231439157655757940L;
>> >> public String test1(){
>> >> EntityManager
>> entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
>> >> entityManager0.getTransaction().begin();
>> >> try{
>> >> //just fill some test data to database
>> >> String sql="insert into grandscape_user
>> (user_name,user_password) values (:u,:p)";
>> >> Query query=entityManager0.createNativeQuery(sql);
>> >> query.setParameter("u", "Jason Porter");
>> >> query.setParameter("p", "secrete");
>> >> query.executeUpdate();
>> >> entityManager0.getTransaction().commit();
>> >> return "success";
>> >> }catch(Exception ex){
>> >> entityManager0.getTransaction().rollback();
>> >> return ex.getMessage();
>> >> }
>> >> }
>> >> }
>> >> -------------------
>> >>
>> >>
>> >> 3,and persistence.xml.
>> >> <?xml version="1.0" encoding="UTF-8"?>
>> >> <persistence xmlns="http://java.sun.com/xml/ns/persistence"
>> >> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
>> >> xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
>> http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
>> >> version="2.0">
>> >> <persistence-unit name="persistence0"
>> transaction-type="RESOURCE_LOCAL">
>> >> <provider>org.hibernate.ejb.HibernatePersistence</provider>
>> >> <properties>
>> >> <property name="hibernate.connection.driver_class"
>> value="com.mysql.jdbc.Driver"/>
>> >> <property name="hibernate.connection.url"
>> value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
>> >> <property name="hibernate.connection.username" value="root"
>> />
>> >> <property name="hibernate.connection.password" value="root"
>> />
>> >> <property name="hibernate.dialect"
>> value="org.hibernate.dialect.MySQLInnoDBDialect"/>
>> >> <property name="hibernate.connection.autocommit"
>> value="true" />
>> >> <property name="hibernate.hbm2ddl.auto" value="validate"/>
>> >> <property name="hibernate.show_sql" value="false"/>
>> >> <property name="hibernate.cache.use_second_level_cache"
>> value="true"/>
>> >> <property name="hibernate.cache.provider_class"
>> value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
>> >> <property name="hibernate.search.default.directory_provider"
>> value="org.hibernate.search.store.FSDirectoryProvider"/>
>> >> <property name="hibernate.search.default.indexBase"
>> value="./lucene/indexes"/>
>> >> <property name="hibernate.search.default.batch.merge_factor"
>> value="10"/>
>> >> <property
>> name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
>> >> </properties>
>> >> </persistence-unit>
>> >> </persistence>
>> >> ------------
>> >>
>> >>
>> >> 4,finally,when i deployed the program to tomcat,the error occured:
>> >> ----------
>> >> 26-Oct-2013 12:04:51.642 SEVERE [http-nio-8080-exec-6]
>> org.apache.catalina.core.StandardContext.listenerStart Exception sending
>> context initialized event to listener instance of class
>> org.jboss.weld.environment.servlet.Listener
>> >> org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied
>> dependencies for type TransactionStrategy with qualifiers @Default
>> >> at injection point [BackedAnnotatedField] @Inject private
>> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy
>> >> at
>> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0)
>> >>
>> >> at
>> org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405)
>> >> at
>> org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327)
>> >> at
>> org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565)
>> >> at
>> org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88)
>> >> at
>> org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86)
>> >> at
>> org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
>> >> at
>> org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
>> >> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
>> >> at java.util.concurrent.FutureTask.run(Unknown Source)
>> >> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
>> >> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
>> >> at java.lang.Thread.run(Unknown Source)
>> >>
>> >> 26-Oct-2013 12:04:52.161 SEVERE [http-nio-8080-exec-6]
>> org.apache.catalina.core.StandardContext.listenerStop Exception sending
>> context destroyed event to listener instance of class
>> org.jboss.weld.environment.servlet.Listener
>> >> java.lang.NullPointerException
>> >> at
>> org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
>> >> at
>> org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
>> >> at
>> org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
>> >> at
>> org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
>> >> at
>> org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
>> >> at
>> org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
>> >> at
>> org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
>> >> at
>> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
>> >> at
>> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
>> >> at
>> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
>> >> at
>> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
>> >> at
>> org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:456)
>> >> at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1534)
>> >> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>> >> at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
>> >> at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
>> >> at java.lang.reflect.Method.invoke(Unknown Source)
>> >> at
>> org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:300)
>> >> at
>> com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(Unknown Source)
>> >> at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(Unknown Source)
>> >> at
>> org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1430)
>> >> at
>> org.apache.catalina.manager.ManagerServlet.deploy(ManagerServlet.java:704)
>> >> at
>> org.apache.catalina.manager.ManagerServlet.doPut(ManagerServlet.java:430)
>> >> at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
>> >> at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
>> >> at
>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
>> >> at
>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
>> >> at
>> org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)
>> >> at
>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
>> >> at
>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
>> >> at
>> org.apache.catalina.filters.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:108)
>> >> at
>> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
>> >> at
>> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
>> >> at
>> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:221)
>> >> at
>> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:107)
>> >> at
>> org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:616)
>> >> at
>> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155)
>> >> at
>> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:76)
>> >> at
>> org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:934)
>> >> at
>> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:90)
>> >> at
>> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:515)
>> >> at
>> org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1012)
>> >> at
>> org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:642)
>> >> at
>> org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:223)
>> >> at
>> org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1597)
>> >> at
>> org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1555)
>> >> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
>> >> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
>> >> at java.lang.Thread.run(Unknown Source)
>> >> --------
>> >>
>> >> 5.the pom.xml
>> >> ------
>> >> <?xml version="1.0"?>
>> >> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
>> http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="
>> http://maven.apache.org/POM/4.0.0"
>> >> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
>> >> <modelVersion>4.0.0</modelVersion>
>> >> <groupId>grandscape</groupId>
>> >> <artifactId>prog_tomcat</artifactId>
>> >> <version>0.0.1-SNAPSHOT</version>
>> >> <packaging>war</packaging>
>> >> <name>prog_tomcat Maven Webapp</name>
>> >> <url>http://maven.apache.org</url>
>> >>
>> >> <properties>
>> >>
>> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
>> >> <deltaspike.version>0.5</deltaspike.version>
>> >> <picketlink.version>2.5.2.Final</picketlink.version>
>> >> </properties>
>> >> <dependencies>
>> >> <dependency>
>> >> <groupId>junit</groupId>
>> >> <artifactId>junit</artifactId>
>> >> <version>4.11</version>
>> >> <scope>test</scope>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>com.sun.faces</groupId>
>> >> <artifactId>jsf-api</artifactId>
>> >> <version>2.2.4</version>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>com.sun.faces</groupId>
>> >> <artifactId>jsf-impl</artifactId>
>> >> <version>2.2.4</version>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>javax.enterprise</groupId>
>> >> <artifactId>cdi-api</artifactId>
>> >> <version>1.1</version>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>org.jboss.weld.servlet</groupId>
>> >> <artifactId>weld-servlet</artifactId>
>> >> <version>2.0.4.Final</version>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>log4j</groupId>
>> >> <artifactId>log4j</artifactId>
>> >> <version>1.2.17</version>
>> >> <scope>compile</scope>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>org.slf4j</groupId>
>> >> <artifactId>slf4j-api</artifactId>
>> >> <version>1.7.5</version>
>> >> <scope>compile</scope>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>org.slf4j</groupId>
>> >> <artifactId>slf4j-log4j12</artifactId>
>> >> <version>1.7.5</version>
>> >> <scope>compile</scope>
>> >> </dependency>
>> >>
>> >> <dependency>
>> >> <groupId>commons-logging</groupId>
>> >> <artifactId>commons-logging</artifactId>
>> >> <version>1.1.3</version>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>org.apache.deltaspike.core</groupId>
>> >> <artifactId>deltaspike-core-api</artifactId>
>> >> <version>${deltaspike.version}</version>
>> >> <scope>compile</scope>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>org.apache.deltaspike.core</groupId>
>> >> <artifactId>deltaspike-core-impl</artifactId>
>> >> <version>${deltaspike.version}</version>
>> >> <scope>runtime</scope>
>> >> </dependency>
>> >> <dependency>
>> >> <version>1.0.1.Final</version>
>> >> <groupId>org.hibernate.javax.persistence</groupId>
>> >> <artifactId>hibernate-jpa-2.0-api</artifactId>
>> >> <scope>provided</scope>
>> >> </dependency>
>> >>
>> >> <dependency>
>> >> <groupId>org.hibernate</groupId>
>> >> <artifactId>hibernate-core</artifactId>
>> >> <version>4.2.6.Final</version>
>> >> </dependency>
>> >>
>> >> <dependency>
>> >> <groupId>org.apache.deltaspike.modules</groupId>
>> >> <artifactId>deltaspike-jpa-module-api</artifactId>
>> >> <version>${deltaspike.version}</version>
>> >> <scope>compile</scope>
>> >> </dependency>
>> >> <dependency>
>> >> <groupId>org.apache.deltaspike.modules</groupId>
>> >> <artifactId>deltaspike-jpa-module-impl</artifactId>
>> >> <version>${deltaspike.version}</version>
>> >> <scope>runtime</scope>
>> >> </dependency>
>> >> </dependencies>
>> >> <repositories>
>> >> <repository>
>> >> <id>people.apache.snapshots</id>
>> >> <url>
>> >> http://repository.apache.org/content/groups/snapshots-group/
>> >> </url>
>> >> <releases>
>> >> <enabled>false</enabled>
>> >> </releases>
>> >> <snapshots>
>> >> <enabled>true</enabled>
>> >> </snapshots>
>> >> </repository>
>> >> </repositories>
>> >> <pluginRepositories> <pluginRepository>
>> >> <id>apache.snapshots</id>
>> >> <name>Apache Snapshots</name>
>> >> <url>
>> >> http://repository.apache.org/content/groups/snapshots-group/
>> >> </url>
>> >> <releases>
>> >> <enabled>false</enabled>
>> >> </releases>
>> >> <snapshots>
>> >> <enabled>true</enabled>
>> >> </snapshots>
>> >> </pluginRepository></pluginRepositories>
>> >> <build>
>> >> <finalName>prog_tomcat</finalName>
>> >> <plugins>
>> >> <plugin>
>> >> <groupId>org.apache.tomcat.maven</groupId>
>> >> <artifactId>tomcat7-maven-plugin</artifactId>
>> >> <version>2.1</version>
>> >> <configuration>
>> >> <server>mytomcat</server>
>> >> <url>http://localhost:8080/manager/text</url>
>> >> <contextReloadable>true</contextReloadable>
>> >> </configuration>
>> >> </plugin>
>> >> </plugins>
>> >> </build>
>> >> </project>
>> >>
>> >> thanks everyone !!!
>>
Re: Re: Unsatisfied dependencies for type TransactionStrategy error
on tomcat8
Posted by Rodrigo Mesquita <ro...@tre-se.jus.br>.
Try to remove of your beans.xml
<interceptors>
<class>org.apache.deltaspike.jpa.impl.transaction.
TransactionalInterceptor</class>
</interceptors>
Don't know if 0.5 version of jpa module need this configuration, because it
has an already configured beans.xml
--
Rodrigo Cardoso Mesquita
Tel.: (79) 2106-8703
Seção de Desenvolvimento de Sistemas
Tribunal Regional Eleitoral de Sergipe
SEDES / COSIS / STI / TRE-SE
2013/10/29 十三郎 <mi...@163.com>
> Rodrigo:thanks very much!!!
>
> i change my code to use @Transactional annotation instead of a
> BMT(manual) way.
> i want to test if code work fine in a CMT way.
>
> 1.EntityManagerProducer
> ---
> public class EntityManagerProducer
> {
> @PersistenceContext(unitName = "persistence0")
> private EntityManager entityManager;
> @Produces
> @SessionScoped
> protected EntityManager createEntityManager()
> {
> return this.entityManager;
> }
> protected void closeEntityManager(@Disposes EntityManager
> entityManager)
> {
> if (entityManager.isOpen())
> {
> entityManager.close();
> }
> }
> }
> ---
> 2.do some database transactional work in a CMT way
> ---
> import java.io.Serializable;
> import javax.enterprise.context.SessionScoped;
> import javax.inject.Inject;
> import javax.inject.Named;
> import javax.persistence.EntityManager;
> import javax.persistence.Query;
> import org.apache.deltaspike.core.api.provider.BeanProvider;
> import org.apache.deltaspike.jpa.api.transaction.Transactional;
>
> @Named
> @SessionScoped
> @Transactional
> public class Test implements Serializable
> {
> private static final long serialVersionUID = -1231439157655757940L;
> @Inject CurrentUser currentUser;
> @Transactional
> public String test1(){
> EntityManager
> entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
> //just fill some test data to database
> String sql="insert into grandscape_user
> (user_name,user_password) values (:u,:p)";
> Query query=entityManager0.createNativeQuery(sql);
> query.setParameter("u", "Jason Porter");
> query.setParameter("p", "secrete");
> query.executeUpdate();
> return "success";
> }
> }
> ---
>
> 3.persistence.xml
> ---
> <?xml version="1.0" encoding="UTF-8"?>
> <persistence xmlns="http://java.sun.com/xml/ns/persistence"
> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
> xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
> http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
> version="2.0">
> <persistence-unit name="persistence0"
> transaction-type="RESOURCE_LOCAL">
> <provider>org.hibernate.ejb.HibernatePersistence</provider>
> <properties>
> <property name="hibernate.connection.driver_class"
> value="com.mysql.jdbc.Driver"/>
> <property name="hibernate.connection.url"
> value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
> <property name="hibernate.connection.username"
> value="root" />
> <property name="hibernate.connection.password"
> value="root" />
> <property name="hibernate.dialect"
> value="org.hibernate.dialect.MySQLInnoDBDialect"/>
> <property name="hibernate.connection.autocommit" value="true"
> />
> <property name="hibernate.hbm2ddl.auto" value="validate"/>
> <property name="hibernate.show_sql" value="false"/>
> <property name="hibernate.cache.use_second_level_cache"
> value="true"/>
> <property name="hibernate.cache.provider_class"
> value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
> <property name="hibernate.search.default.directory_provider"
> value="org.hibernate.search.store.FSDirectoryProvider"/>
> <property name="hibernate.search.default.indexBase"
> value="./lucene/indexes"/>
> <property name="hibernate.search.default.batch.merge_factor"
> value="10"/>
> <property
> name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
> </properties>
> </persistence-unit>
> </persistence>
> ---
>
> 4.bean.xml
> ---
> <?xml version="1.0" encoding="UTF-8"?>
> <beans xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="
> http://www.w3.org/2001/XMLSchema-instance"
> xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
> http://java.sun.com/xml/ns/javaee/beans_1_0.xsd">
> <interceptors>
>
> <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
> </interceptors>
> </beans>
> ---
>
> when i deployed the program to tomcat,the error occured.
> -----
> 29-Oct-2013 18:05:16.536 SEVERE [localhost-startStop-1]
> org.apache.catalina.core.StandardContext.listenerStart Exception sending
> context initialized event to listener instance of class
> org.jboss.weld.environment.servlet.Listener
> org.jboss.weld.exceptions.DeploymentException: WELD-001416 Enabled
> interceptor class
> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor
> specified twice:
> -
> <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
> in
> jar:file:/D:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/lib/deltaspike-jpa-module-impl-0.5.jar!/META-INF/beans.xml@24
> ,
> -
> <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
> in file:/d:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/beans.xml@5
> at
> org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.checkForDuplicates(GlobalEnablementBuilder.java:249)
> at
> org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.createModuleEnablement(GlobalEnablementBuilder.java:226)
> at
> org.jboss.weld.bootstrap.BeanDeployment.createEnabled(BeanDeployment.java:221)
> at
> org.jboss.weld.bootstrap.WeldBootstrap.startInitialization(WeldBootstrap.java:488)
> at
> org.jboss.weld.environment.servlet.Listener.contextInitialized(Listener.java:141)
> at
> org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4830)
> at
> org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5276)
> at
> org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
> at
> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
> at
> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
> at
> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
> at
> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
> at
> org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742)
> at java.util.concurrent.Executors$RunnableAdapter.call(Unknown
> Source)
> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
> at java.util.concurrent.FutureTask.run(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown
> Source)
> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown
> Source)
> at java.lang.Thread.run(Unknown Source)
>
> 29-Oct-2013 18:05:17.174 SEVERE [localhost-startStop-1]
> org.apache.catalina.core.StandardContext.listenerStop Exception sending
> context destroyed event to listener instance of class
> org.jboss.weld.environment.servlet.Listener
> java.lang.NullPointerException
> at
> org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
> at
> org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
> at
> org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
> at
> org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
> at
> org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
> at
> org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
> at
> org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
> at
> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
> at
> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
> at
> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
> at
> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
> at
> org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742)
> at java.util.concurrent.Executors$RunnableAdapter.call(Unknown
> Source)
> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
> at java.util.concurrent.FutureTask.run(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown
> Source)
> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown
> Source)
> at java.lang.Thread.run(Unknown Source)
> -----
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
> At 2013-10-27 17:10:34,Rodrigo <rc...@gmail.com> wrote:
> >I think the problem is the use of PersistenceContext annotation on
> Resource_local entityManager. If you want to manage the transactions, dont
> use this annotation, because it indicates container responsability of
> entity managers.
> >
> >You must have a static EntityManagerFactory created and the producer
> method must create the entitymanager from factory.
> >
> >Rodrigo
> >
> >
> >
> >
> >Enviado via iPhone
> >
> >Em 26/10/2013, às 23:50, 十三郎 <mi...@163.com> escreveu:
> >
> >>
> >> hi everyone:
> >>
> >> i write a simple apache deltaspike jpa demo,run to error on tomcat8.0.
> >> (i use tomcat8.0rc5 ; jdk1.7 ,deltaspike0.5)
> >>
> >> 1,first,i define a EntityManagerProducer
> >> public class EntityManagerProducer
> >> {
> >> @PersistenceContext(unitName = "persistence0")
> >> private EntityManager entityManager;
> >> @Produces
> >> @RequestScoped
> >> protected EntityManager createEntityManager()
> >> {
> >> return this.entityManager;
> >> }
> >> protected void closeEntityManager(@Disposes EntityManager
> entityManager)
> >> {
> >> if (entityManager.isOpen())
> >> {
> >> entityManager.close();
> >> }
> >> }
> >> }
> >>
> >>
> >> 2,and i want do some database transactional work manually(i wanna a
> manual way).
> >> ---------------------------
> >> @Named
> >> @SessionScoped
> >> public class Test implements Serializable
> >> {
> >> private static final long serialVersionUID = -1231439157655757940L;
> >> public String test1(){
> >> EntityManager
> entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
> >> entityManager0.getTransaction().begin();
> >> try{
> >> //just fill some test data to database
> >> String sql="insert into grandscape_user
> (user_name,user_password) values (:u,:p)";
> >> Query query=entityManager0.createNativeQuery(sql);
> >> query.setParameter("u", "Jason Porter");
> >> query.setParameter("p", "secrete");
> >> query.executeUpdate();
> >> entityManager0.getTransaction().commit();
> >> return "success";
> >> }catch(Exception ex){
> >> entityManager0.getTransaction().rollback();
> >> return ex.getMessage();
> >> }
> >> }
> >> }
> >> -------------------
> >>
> >>
> >> 3,and persistence.xml.
> >> <?xml version="1.0" encoding="UTF-8"?>
> >> <persistence xmlns="http://java.sun.com/xml/ns/persistence"
> >> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
> >> xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
> http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
> >> version="2.0">
> >> <persistence-unit name="persistence0"
> transaction-type="RESOURCE_LOCAL">
> >> <provider>org.hibernate.ejb.HibernatePersistence</provider>
> >> <properties>
> >> <property name="hibernate.connection.driver_class"
> value="com.mysql.jdbc.Driver"/>
> >> <property name="hibernate.connection.url"
> value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
> >> <property name="hibernate.connection.username" value="root"
> />
> >> <property name="hibernate.connection.password" value="root"
> />
> >> <property name="hibernate.dialect"
> value="org.hibernate.dialect.MySQLInnoDBDialect"/>
> >> <property name="hibernate.connection.autocommit"
> value="true" />
> >> <property name="hibernate.hbm2ddl.auto" value="validate"/>
> >> <property name="hibernate.show_sql" value="false"/>
> >> <property name="hibernate.cache.use_second_level_cache"
> value="true"/>
> >> <property name="hibernate.cache.provider_class"
> value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
> >> <property name="hibernate.search.default.directory_provider"
> value="org.hibernate.search.store.FSDirectoryProvider"/>
> >> <property name="hibernate.search.default.indexBase"
> value="./lucene/indexes"/>
> >> <property name="hibernate.search.default.batch.merge_factor"
> value="10"/>
> >> <property
> name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
> >> </properties>
> >> </persistence-unit>
> >> </persistence>
> >> ------------
> >>
> >>
> >> 4,finally,when i deployed the program to tomcat,the error occured:
> >> ----------
> >> 26-Oct-2013 12:04:51.642 SEVERE [http-nio-8080-exec-6]
> org.apache.catalina.core.StandardContext.listenerStart Exception sending
> context initialized event to listener instance of class
> org.jboss.weld.environment.servlet.Listener
> >> org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied
> dependencies for type TransactionStrategy with qualifiers @Default
> >> at injection point [BackedAnnotatedField] @Inject private
> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy
> >> at
> org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0)
> >>
> >> at
> org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405)
> >> at
> org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327)
> >> at
> org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565)
> >> at
> org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88)
> >> at
> org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86)
> >> at
> org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
> >> at
> org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
> >> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
> >> at java.util.concurrent.FutureTask.run(Unknown Source)
> >> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
> >> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
> >> at java.lang.Thread.run(Unknown Source)
> >>
> >> 26-Oct-2013 12:04:52.161 SEVERE [http-nio-8080-exec-6]
> org.apache.catalina.core.StandardContext.listenerStop Exception sending
> context destroyed event to listener instance of class
> org.jboss.weld.environment.servlet.Listener
> >> java.lang.NullPointerException
> >> at
> org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
> >> at
> org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
> >> at
> org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
> >> at
> org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
> >> at
> org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
> >> at
> org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
> >> at
> org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
> >> at
> org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
> >> at
> org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
> >> at
> org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
> >> at
> org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
> >> at
> org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:456)
> >> at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1534)
> >> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> >> at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
> >> at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
> >> at java.lang.reflect.Method.invoke(Unknown Source)
> >> at
> org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:300)
> >> at
> com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(Unknown Source)
> >> at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(Unknown Source)
> >> at
> org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1430)
> >> at
> org.apache.catalina.manager.ManagerServlet.deploy(ManagerServlet.java:704)
> >> at
> org.apache.catalina.manager.ManagerServlet.doPut(ManagerServlet.java:430)
> >> at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
> >> at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
> >> at
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
> >> at
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> >> at
> org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)
> >> at
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
> >> at
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> >> at
> org.apache.catalina.filters.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:108)
> >> at
> org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
> >> at
> org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> >> at
> org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:221)
> >> at
> org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:107)
> >> at
> org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:616)
> >> at
> org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155)
> >> at
> org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:76)
> >> at
> org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:934)
> >> at
> org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:90)
> >> at
> org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:515)
> >> at
> org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1012)
> >> at
> org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:642)
> >> at
> org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:223)
> >> at
> org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1597)
> >> at
> org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1555)
> >> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
> >> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
> >> at java.lang.Thread.run(Unknown Source)
> >> --------
> >>
> >> 5.the pom.xml
> >> ------
> >> <?xml version="1.0"?>
> >> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0
> http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="
> http://maven.apache.org/POM/4.0.0"
> >> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
> >> <modelVersion>4.0.0</modelVersion>
> >> <groupId>grandscape</groupId>
> >> <artifactId>prog_tomcat</artifactId>
> >> <version>0.0.1-SNAPSHOT</version>
> >> <packaging>war</packaging>
> >> <name>prog_tomcat Maven Webapp</name>
> >> <url>http://maven.apache.org</url>
> >>
> >> <properties>
> >>
> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
> >> <deltaspike.version>0.5</deltaspike.version>
> >> <picketlink.version>2.5.2.Final</picketlink.version>
> >> </properties>
> >> <dependencies>
> >> <dependency>
> >> <groupId>junit</groupId>
> >> <artifactId>junit</artifactId>
> >> <version>4.11</version>
> >> <scope>test</scope>
> >> </dependency>
> >> <dependency>
> >> <groupId>com.sun.faces</groupId>
> >> <artifactId>jsf-api</artifactId>
> >> <version>2.2.4</version>
> >> </dependency>
> >> <dependency>
> >> <groupId>com.sun.faces</groupId>
> >> <artifactId>jsf-impl</artifactId>
> >> <version>2.2.4</version>
> >> </dependency>
> >> <dependency>
> >> <groupId>javax.enterprise</groupId>
> >> <artifactId>cdi-api</artifactId>
> >> <version>1.1</version>
> >> </dependency>
> >> <dependency>
> >> <groupId>org.jboss.weld.servlet</groupId>
> >> <artifactId>weld-servlet</artifactId>
> >> <version>2.0.4.Final</version>
> >> </dependency>
> >> <dependency>
> >> <groupId>log4j</groupId>
> >> <artifactId>log4j</artifactId>
> >> <version>1.2.17</version>
> >> <scope>compile</scope>
> >> </dependency>
> >> <dependency>
> >> <groupId>org.slf4j</groupId>
> >> <artifactId>slf4j-api</artifactId>
> >> <version>1.7.5</version>
> >> <scope>compile</scope>
> >> </dependency>
> >> <dependency>
> >> <groupId>org.slf4j</groupId>
> >> <artifactId>slf4j-log4j12</artifactId>
> >> <version>1.7.5</version>
> >> <scope>compile</scope>
> >> </dependency>
> >>
> >> <dependency>
> >> <groupId>commons-logging</groupId>
> >> <artifactId>commons-logging</artifactId>
> >> <version>1.1.3</version>
> >> </dependency>
> >> <dependency>
> >> <groupId>org.apache.deltaspike.core</groupId>
> >> <artifactId>deltaspike-core-api</artifactId>
> >> <version>${deltaspike.version}</version>
> >> <scope>compile</scope>
> >> </dependency>
> >> <dependency>
> >> <groupId>org.apache.deltaspike.core</groupId>
> >> <artifactId>deltaspike-core-impl</artifactId>
> >> <version>${deltaspike.version}</version>
> >> <scope>runtime</scope>
> >> </dependency>
> >> <dependency>
> >> <version>1.0.1.Final</version>
> >> <groupId>org.hibernate.javax.persistence</groupId>
> >> <artifactId>hibernate-jpa-2.0-api</artifactId>
> >> <scope>provided</scope>
> >> </dependency>
> >>
> >> <dependency>
> >> <groupId>org.hibernate</groupId>
> >> <artifactId>hibernate-core</artifactId>
> >> <version>4.2.6.Final</version>
> >> </dependency>
> >>
> >> <dependency>
> >> <groupId>org.apache.deltaspike.modules</groupId>
> >> <artifactId>deltaspike-jpa-module-api</artifactId>
> >> <version>${deltaspike.version}</version>
> >> <scope>compile</scope>
> >> </dependency>
> >> <dependency>
> >> <groupId>org.apache.deltaspike.modules</groupId>
> >> <artifactId>deltaspike-jpa-module-impl</artifactId>
> >> <version>${deltaspike.version}</version>
> >> <scope>runtime</scope>
> >> </dependency>
> >> </dependencies>
> >> <repositories>
> >> <repository>
> >> <id>people.apache.snapshots</id>
> >> <url>
> >> http://repository.apache.org/content/groups/snapshots-group/
> >> </url>
> >> <releases>
> >> <enabled>false</enabled>
> >> </releases>
> >> <snapshots>
> >> <enabled>true</enabled>
> >> </snapshots>
> >> </repository>
> >> </repositories>
> >> <pluginRepositories> <pluginRepository>
> >> <id>apache.snapshots</id>
> >> <name>Apache Snapshots</name>
> >> <url>
> >> http://repository.apache.org/content/groups/snapshots-group/
> >> </url>
> >> <releases>
> >> <enabled>false</enabled>
> >> </releases>
> >> <snapshots>
> >> <enabled>true</enabled>
> >> </snapshots>
> >> </pluginRepository></pluginRepositories>
> >> <build>
> >> <finalName>prog_tomcat</finalName>
> >> <plugins>
> >> <plugin>
> >> <groupId>org.apache.tomcat.maven</groupId>
> >> <artifactId>tomcat7-maven-plugin</artifactId>
> >> <version>2.1</version>
> >> <configuration>
> >> <server>mytomcat</server>
> >> <url>http://localhost:8080/manager/text</url>
> >> <contextReloadable>true</contextReloadable>
> >> </configuration>
> >> </plugin>
> >> </plugins>
> >> </build>
> >> </project>
> >>
> >> thanks everyone !!!
>
Re:Re: Unsatisfied dependencies for type TransactionStrategy error
on tomcat8
Posted by 十三郎 <mi...@163.com>.
Rodrigo:thanks very much!!!
i change my code to use @Transactional annotation instead of a BMT(manual) way.
i want to test if code work fine in a CMT way.
1.EntityManagerProducer
---
public class EntityManagerProducer
{
@PersistenceContext(unitName = "persistence0")
private EntityManager entityManager;
@Produces
@SessionScoped
protected EntityManager createEntityManager()
{
return this.entityManager;
}
protected void closeEntityManager(@Disposes EntityManager entityManager)
{
if (entityManager.isOpen())
{
entityManager.close();
}
}
}
---
2.do some database transactional work in a CMT way
---
import java.io.Serializable;
import javax.enterprise.context.SessionScoped;
import javax.inject.Inject;
import javax.inject.Named;
import javax.persistence.EntityManager;
import javax.persistence.Query;
import org.apache.deltaspike.core.api.provider.BeanProvider;
import org.apache.deltaspike.jpa.api.transaction.Transactional;
@Named
@SessionScoped
@Transactional
public class Test implements Serializable
{
private static final long serialVersionUID = -1231439157655757940L;
@Inject CurrentUser currentUser;
@Transactional
public String test1(){
EntityManager entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
//just fill some test data to database
String sql="insert into grandscape_user (user_name,user_password) values (:u,:p)";
Query query=entityManager0.createNativeQuery(sql);
query.setParameter("u", "Jason Porter");
query.setParameter("p", "secrete");
query.executeUpdate();
return "success";
}
}
---
3.persistence.xml
---
<?xml version="1.0" encoding="UTF-8"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
version="2.0">
<persistence-unit name="persistence0" transaction-type="RESOURCE_LOCAL">
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<properties>
<property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
<property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
<property name="hibernate.connection.username" value="root" />
<property name="hibernate.connection.password" value="root" />
<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect"/>
<property name="hibernate.connection.autocommit" value="true" />
<property name="hibernate.hbm2ddl.auto" value="validate"/>
<property name="hibernate.show_sql" value="false"/>
<property name="hibernate.cache.use_second_level_cache" value="true"/>
<property name="hibernate.cache.provider_class" value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
<property name="hibernate.search.default.directory_provider" value="org.hibernate.search.store.FSDirectoryProvider"/>
<property name="hibernate.search.default.indexBase" value="./lucene/indexes"/>
<property name="hibernate.search.default.batch.merge_factor" value="10"/>
<property name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
</properties>
</persistence-unit>
</persistence>
---
4.bean.xml
---
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/beans_1_0.xsd">
<interceptors>
<class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class>
</interceptors>
</beans>
---
when i deployed the program to tomcat,the error occured.
-----
29-Oct-2013 18:05:16.536 SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.listenerStart Exception sending context initialized event to listener instance of class org.jboss.weld.environment.servlet.Listener
org.jboss.weld.exceptions.DeploymentException: WELD-001416 Enabled interceptor class org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor specified twice:
- <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> in jar:file:/D:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/lib/deltaspike-jpa-module-impl-0.5.jar!/META-INF/beans.xml@24,
- <class>org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor</class> in file:/d:/Tomcat%208.0rc5/temp/0-prog_tomcat/WEB-INF/beans.xml@5
at org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.checkForDuplicates(GlobalEnablementBuilder.java:249)
at org.jboss.weld.bootstrap.enablement.GlobalEnablementBuilder.createModuleEnablement(GlobalEnablementBuilder.java:226)
at org.jboss.weld.bootstrap.BeanDeployment.createEnabled(BeanDeployment.java:221)
at org.jboss.weld.bootstrap.WeldBootstrap.startInitialization(WeldBootstrap.java:488)
at org.jboss.weld.environment.servlet.Listener.contextInitialized(Listener.java:141)
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4830)
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5276)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742)
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source)
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
at java.util.concurrent.FutureTask.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
29-Oct-2013 18:05:17.174 SEVERE [localhost-startStop-1] org.apache.catalina.core.StandardContext.listenerStop Exception sending context destroyed event to listener instance of class org.jboss.weld.environment.servlet.Listener
java.lang.NullPointerException
at org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
at org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
at org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1742)
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source)
at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
at java.util.concurrent.FutureTask.run(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
at java.lang.Thread.run(Unknown Source)
-----
At 2013-10-27 17:10:34,Rodrigo <rc...@gmail.com> wrote:
>I think the problem is the use of PersistenceContext annotation on Resource_local entityManager. If you want to manage the transactions, dont use this annotation, because it indicates container responsability of entity managers.
>
>You must have a static EntityManagerFactory created and the producer method must create the entitymanager from factory.
>
>Rodrigo
>
>
>
>
>Enviado via iPhone
>
>Em 26/10/2013, às 23:50, 十三郎 <mi...@163.com> escreveu:
>
>>
>> hi everyone:
>>
>> i write a simple apache deltaspike jpa demo,run to error on tomcat8.0.
>> (i use tomcat8.0rc5 ; jdk1.7 ,deltaspike0.5)
>>
>> 1,first,i define a EntityManagerProducer
>> public class EntityManagerProducer
>> {
>> @PersistenceContext(unitName = "persistence0")
>> private EntityManager entityManager;
>> @Produces
>> @RequestScoped
>> protected EntityManager createEntityManager()
>> {
>> return this.entityManager;
>> }
>> protected void closeEntityManager(@Disposes EntityManager entityManager)
>> {
>> if (entityManager.isOpen())
>> {
>> entityManager.close();
>> }
>> }
>> }
>>
>>
>> 2,and i want do some database transactional work manually(i wanna a manual way).
>> ---------------------------
>> @Named
>> @SessionScoped
>> public class Test implements Serializable
>> {
>> private static final long serialVersionUID = -1231439157655757940L;
>> public String test1(){
>> EntityManager entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
>> entityManager0.getTransaction().begin();
>> try{
>> //just fill some test data to database
>> String sql="insert into grandscape_user (user_name,user_password) values (:u,:p)";
>> Query query=entityManager0.createNativeQuery(sql);
>> query.setParameter("u", "Jason Porter");
>> query.setParameter("p", "secrete");
>> query.executeUpdate();
>> entityManager0.getTransaction().commit();
>> return "success";
>> }catch(Exception ex){
>> entityManager0.getTransaction().rollback();
>> return ex.getMessage();
>> }
>> }
>> }
>> -------------------
>>
>>
>> 3,and persistence.xml.
>> <?xml version="1.0" encoding="UTF-8"?>
>> <persistence xmlns="http://java.sun.com/xml/ns/persistence"
>> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
>> xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
>> version="2.0">
>> <persistence-unit name="persistence0" transaction-type="RESOURCE_LOCAL">
>> <provider>org.hibernate.ejb.HibernatePersistence</provider>
>> <properties>
>> <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
>> <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
>> <property name="hibernate.connection.username" value="root" />
>> <property name="hibernate.connection.password" value="root" />
>> <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect"/>
>> <property name="hibernate.connection.autocommit" value="true" />
>> <property name="hibernate.hbm2ddl.auto" value="validate"/>
>> <property name="hibernate.show_sql" value="false"/>
>> <property name="hibernate.cache.use_second_level_cache" value="true"/>
>> <property name="hibernate.cache.provider_class" value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
>> <property name="hibernate.search.default.directory_provider" value="org.hibernate.search.store.FSDirectoryProvider"/>
>> <property name="hibernate.search.default.indexBase" value="./lucene/indexes"/>
>> <property name="hibernate.search.default.batch.merge_factor" value="10"/>
>> <property name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
>> </properties>
>> </persistence-unit>
>> </persistence>
>> ------------
>>
>>
>> 4,finally,when i deployed the program to tomcat,the error occured:
>> ----------
>> 26-Oct-2013 12:04:51.642 SEVERE [http-nio-8080-exec-6] org.apache.catalina.core.StandardContext.listenerStart Exception sending context initialized event to listener instance of class org.jboss.weld.environment.servlet.Listener
>> org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied dependencies for type TransactionStrategy with qualifiers @Default
>> at injection point [BackedAnnotatedField] @Inject private org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy
>> at org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0)
>>
>> at org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405)
>> at org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327)
>> at org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565)
>> at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88)
>> at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86)
>> at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
>> at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
>> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
>> at java.util.concurrent.FutureTask.run(Unknown Source)
>> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
>> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
>> at java.lang.Thread.run(Unknown Source)
>>
>> 26-Oct-2013 12:04:52.161 SEVERE [http-nio-8080-exec-6] org.apache.catalina.core.StandardContext.listenerStop Exception sending context destroyed event to listener instance of class org.jboss.weld.environment.servlet.Listener
>> java.lang.NullPointerException
>> at org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
>> at org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
>> at org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
>> at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
>> at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
>> at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
>> at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
>> at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
>> at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
>> at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
>> at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
>> at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:456)
>> at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1534)
>> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>> at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
>> at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
>> at java.lang.reflect.Method.invoke(Unknown Source)
>> at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:300)
>> at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(Unknown Source)
>> at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(Unknown Source)
>> at org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1430)
>> at org.apache.catalina.manager.ManagerServlet.deploy(ManagerServlet.java:704)
>> at org.apache.catalina.manager.ManagerServlet.doPut(ManagerServlet.java:430)
>> at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
>> at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
>> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
>> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
>> at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)
>> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
>> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
>> at org.apache.catalina.filters.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:108)
>> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
>> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
>> at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:221)
>> at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:107)
>> at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:616)
>> at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155)
>> at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:76)
>> at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:934)
>> at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:90)
>> at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:515)
>> at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1012)
>> at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:642)
>> at org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:223)
>> at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1597)
>> at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1555)
>> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
>> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
>> at java.lang.Thread.run(Unknown Source)
>> --------
>>
>> 5.the pom.xml
>> ------
>> <?xml version="1.0"?>
>> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
>> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
>> <modelVersion>4.0.0</modelVersion>
>> <groupId>grandscape</groupId>
>> <artifactId>prog_tomcat</artifactId>
>> <version>0.0.1-SNAPSHOT</version>
>> <packaging>war</packaging>
>> <name>prog_tomcat Maven Webapp</name>
>> <url>http://maven.apache.org</url>
>>
>> <properties>
>> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
>> <deltaspike.version>0.5</deltaspike.version>
>> <picketlink.version>2.5.2.Final</picketlink.version>
>> </properties>
>> <dependencies>
>> <dependency>
>> <groupId>junit</groupId>
>> <artifactId>junit</artifactId>
>> <version>4.11</version>
>> <scope>test</scope>
>> </dependency>
>> <dependency>
>> <groupId>com.sun.faces</groupId>
>> <artifactId>jsf-api</artifactId>
>> <version>2.2.4</version>
>> </dependency>
>> <dependency>
>> <groupId>com.sun.faces</groupId>
>> <artifactId>jsf-impl</artifactId>
>> <version>2.2.4</version>
>> </dependency>
>> <dependency>
>> <groupId>javax.enterprise</groupId>
>> <artifactId>cdi-api</artifactId>
>> <version>1.1</version>
>> </dependency>
>> <dependency>
>> <groupId>org.jboss.weld.servlet</groupId>
>> <artifactId>weld-servlet</artifactId>
>> <version>2.0.4.Final</version>
>> </dependency>
>> <dependency>
>> <groupId>log4j</groupId>
>> <artifactId>log4j</artifactId>
>> <version>1.2.17</version>
>> <scope>compile</scope>
>> </dependency>
>> <dependency>
>> <groupId>org.slf4j</groupId>
>> <artifactId>slf4j-api</artifactId>
>> <version>1.7.5</version>
>> <scope>compile</scope>
>> </dependency>
>> <dependency>
>> <groupId>org.slf4j</groupId>
>> <artifactId>slf4j-log4j12</artifactId>
>> <version>1.7.5</version>
>> <scope>compile</scope>
>> </dependency>
>>
>> <dependency>
>> <groupId>commons-logging</groupId>
>> <artifactId>commons-logging</artifactId>
>> <version>1.1.3</version>
>> </dependency>
>> <dependency>
>> <groupId>org.apache.deltaspike.core</groupId>
>> <artifactId>deltaspike-core-api</artifactId>
>> <version>${deltaspike.version}</version>
>> <scope>compile</scope>
>> </dependency>
>> <dependency>
>> <groupId>org.apache.deltaspike.core</groupId>
>> <artifactId>deltaspike-core-impl</artifactId>
>> <version>${deltaspike.version}</version>
>> <scope>runtime</scope>
>> </dependency>
>> <dependency>
>> <version>1.0.1.Final</version>
>> <groupId>org.hibernate.javax.persistence</groupId>
>> <artifactId>hibernate-jpa-2.0-api</artifactId>
>> <scope>provided</scope>
>> </dependency>
>>
>> <dependency>
>> <groupId>org.hibernate</groupId>
>> <artifactId>hibernate-core</artifactId>
>> <version>4.2.6.Final</version>
>> </dependency>
>>
>> <dependency>
>> <groupId>org.apache.deltaspike.modules</groupId>
>> <artifactId>deltaspike-jpa-module-api</artifactId>
>> <version>${deltaspike.version}</version>
>> <scope>compile</scope>
>> </dependency>
>> <dependency>
>> <groupId>org.apache.deltaspike.modules</groupId>
>> <artifactId>deltaspike-jpa-module-impl</artifactId>
>> <version>${deltaspike.version}</version>
>> <scope>runtime</scope>
>> </dependency>
>> </dependencies>
>> <repositories>
>> <repository>
>> <id>people.apache.snapshots</id>
>> <url>
>> http://repository.apache.org/content/groups/snapshots-group/
>> </url>
>> <releases>
>> <enabled>false</enabled>
>> </releases>
>> <snapshots>
>> <enabled>true</enabled>
>> </snapshots>
>> </repository>
>> </repositories>
>> <pluginRepositories> <pluginRepository>
>> <id>apache.snapshots</id>
>> <name>Apache Snapshots</name>
>> <url>
>> http://repository.apache.org/content/groups/snapshots-group/
>> </url>
>> <releases>
>> <enabled>false</enabled>
>> </releases>
>> <snapshots>
>> <enabled>true</enabled>
>> </snapshots>
>> </pluginRepository></pluginRepositories>
>> <build>
>> <finalName>prog_tomcat</finalName>
>> <plugins>
>> <plugin>
>> <groupId>org.apache.tomcat.maven</groupId>
>> <artifactId>tomcat7-maven-plugin</artifactId>
>> <version>2.1</version>
>> <configuration>
>> <server>mytomcat</server>
>> <url>http://localhost:8080/manager/text</url>
>> <contextReloadable>true</contextReloadable>
>> </configuration>
>> </plugin>
>> </plugins>
>> </build>
>> </project>
>>
>> thanks everyone !!!
Re: Unsatisfied dependencies for type TransactionStrategy error on tomcat8
Posted by Rodrigo <rc...@gmail.com>.
I think the problem is the use of PersistenceContext annotation on Resource_local entityManager. If you want to manage the transactions, dont use this annotation, because it indicates container responsability of entity managers.
You must have a static EntityManagerFactory created and the producer method must create the entitymanager from factory.
Rodrigo
Enviado via iPhone
Em 26/10/2013, às 23:50, 十三郎 <mi...@163.com> escreveu:
>
> hi everyone:
>
> i write a simple apache deltaspike jpa demo,run to error on tomcat8.0.
> (i use tomcat8.0rc5 ; jdk1.7 ,deltaspike0.5)
>
> 1,first,i define a EntityManagerProducer
> public class EntityManagerProducer
> {
> @PersistenceContext(unitName = "persistence0")
> private EntityManager entityManager;
> @Produces
> @RequestScoped
> protected EntityManager createEntityManager()
> {
> return this.entityManager;
> }
> protected void closeEntityManager(@Disposes EntityManager entityManager)
> {
> if (entityManager.isOpen())
> {
> entityManager.close();
> }
> }
> }
>
>
> 2,and i want do some database transactional work manually(i wanna a manual way).
> ---------------------------
> @Named
> @SessionScoped
> public class Test implements Serializable
> {
> private static final long serialVersionUID = -1231439157655757940L;
> public String test1(){
> EntityManager entityManager0=BeanProvider.getContextualReference(EntityManager.class,false);
> entityManager0.getTransaction().begin();
> try{
> //just fill some test data to database
> String sql="insert into grandscape_user (user_name,user_password) values (:u,:p)";
> Query query=entityManager0.createNativeQuery(sql);
> query.setParameter("u", "Jason Porter");
> query.setParameter("p", "secrete");
> query.executeUpdate();
> entityManager0.getTransaction().commit();
> return "success";
> }catch(Exception ex){
> entityManager0.getTransaction().rollback();
> return ex.getMessage();
> }
> }
> }
> -------------------
>
>
> 3,and persistence.xml.
> <?xml version="1.0" encoding="UTF-8"?>
> <persistence xmlns="http://java.sun.com/xml/ns/persistence"
> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
> xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
> version="2.0">
> <persistence-unit name="persistence0" transaction-type="RESOURCE_LOCAL">
> <provider>org.hibernate.ejb.HibernatePersistence</provider>
> <properties>
> <property name="hibernate.connection.driver_class" value="com.mysql.jdbc.Driver"/>
> <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/grandscape_websit/"></property>
> <property name="hibernate.connection.username" value="root" />
> <property name="hibernate.connection.password" value="root" />
> <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect"/>
> <property name="hibernate.connection.autocommit" value="true" />
> <property name="hibernate.hbm2ddl.auto" value="validate"/>
> <property name="hibernate.show_sql" value="false"/>
> <property name="hibernate.cache.use_second_level_cache" value="true"/>
> <property name="hibernate.cache.provider_class" value="net.sf.ehcache.hibernate.SingletonEhCacheProvider"/>
> <property name="hibernate.search.default.directory_provider" value="org.hibernate.search.store.FSDirectoryProvider"/>
> <property name="hibernate.search.default.indexBase" value="./lucene/indexes"/>
> <property name="hibernate.search.default.batch.merge_factor" value="10"/>
> <property name="hibernate.search.default.batch.max_buffered_docs" value="10"/>
> </properties>
> </persistence-unit>
> </persistence>
> ------------
>
>
> 4,finally,when i deployed the program to tomcat,the error occured:
> ----------
> 26-Oct-2013 12:04:51.642 SEVERE [http-nio-8080-exec-6] org.apache.catalina.core.StandardContext.listenerStart Exception sending context initialized event to listener instance of class org.jboss.weld.environment.servlet.Listener
> org.jboss.weld.exceptions.DeploymentException: WELD-001408 Unsatisfied dependencies for type TransactionStrategy with qualifiers @Default
> at injection point [BackedAnnotatedField] @Inject private org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy
> at org.apache.deltaspike.jpa.impl.transaction.TransactionalInterceptor.transactionStrategy(TransactionalInterceptor.java:0)
>
> at org.jboss.weld.bootstrap.Validator.validateInjectionPointForDeploymentProblems(Validator.java:405)
> at org.jboss.weld.bootstrap.Validator.validateInjectionPoint(Validator.java:327)
> at org.jboss.weld.bootstrap.Validator.validateInterceptor(Validator.java:565)
> at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:88)
> at org.jboss.weld.bootstrap.ConcurrentValidator$2.doWork(ConcurrentValidator.java:86)
> at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:60)
> at org.jboss.weld.executor.IterativeWorkerTaskFactory$1.call(IterativeWorkerTaskFactory.java:53)
> at java.util.concurrent.FutureTask$Sync.innerRun(Unknown Source)
> at java.util.concurrent.FutureTask.run(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
> at java.lang.Thread.run(Unknown Source)
>
> 26-Oct-2013 12:04:52.161 SEVERE [http-nio-8080-exec-6] org.apache.catalina.core.StandardContext.listenerStop Exception sending context destroyed event to listener instance of class org.jboss.weld.environment.servlet.Listener
> java.lang.NullPointerException
> at org.jboss.weld.servlet.WeldInitialListener.contextDestroyed(WeldInitialListener.java:76)
> at org.jboss.weld.servlet.api.helpers.ForwardingServletListener.contextDestroyed(ForwardingServletListener.java:30)
> at org.jboss.weld.environment.servlet.Listener.contextDestroyed(Listener.java:86)
> at org.apache.catalina.core.StandardContext.listenerStop(StandardContext.java:4871)
> at org.apache.catalina.core.StandardContext.stopInternal(StandardContext.java:5499)
> at org.apache.catalina.util.LifecycleBase.stop(LifecycleBase.java:232)
> at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:160)
> at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:726)
> at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:702)
> at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:698)
> at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:968)
> at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:456)
> at org.apache.catalina.startup.HostConfig.check(HostConfig.java:1534)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
> at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
> at java.lang.reflect.Method.invoke(Unknown Source)
> at org.apache.tomcat.util.modeler.BaseModelMBean.invoke(BaseModelMBean.java:300)
> at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.invoke(Unknown Source)
> at com.sun.jmx.mbeanserver.JmxMBeanServer.invoke(Unknown Source)
> at org.apache.catalina.manager.ManagerServlet.check(ManagerServlet.java:1430)
> at org.apache.catalina.manager.ManagerServlet.deploy(ManagerServlet.java:704)
> at org.apache.catalina.manager.ManagerServlet.doPut(ManagerServlet.java:430)
> at javax.servlet.http.HttpServlet.service(HttpServlet.java:650)
> at javax.servlet.http.HttpServlet.service(HttpServlet.java:728)
> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:51)
> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> at org.apache.catalina.filters.SetCharacterEncodingFilter.doFilter(SetCharacterEncodingFilter.java:108)
> at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
> at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
> at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:221)
> at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:107)
> at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:616)
> at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:155)
> at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:76)
> at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:934)
> at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:90)
> at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:515)
> at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1012)
> at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:642)
> at org.apache.coyote.http11.Http11NioProtocol$Http11ConnectionHandler.process(Http11NioProtocol.java:223)
> at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1597)
> at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.run(NioEndpoint.java:1555)
> at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source)
> at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source)
> at java.lang.Thread.run(Unknown Source)
> --------
>
> 5.the pom.xml
> ------
> <?xml version="1.0"?>
> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0"
> xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
> <modelVersion>4.0.0</modelVersion>
> <groupId>grandscape</groupId>
> <artifactId>prog_tomcat</artifactId>
> <version>0.0.1-SNAPSHOT</version>
> <packaging>war</packaging>
> <name>prog_tomcat Maven Webapp</name>
> <url>http://maven.apache.org</url>
>
> <properties>
> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
> <deltaspike.version>0.5</deltaspike.version>
> <picketlink.version>2.5.2.Final</picketlink.version>
> </properties>
> <dependencies>
> <dependency>
> <groupId>junit</groupId>
> <artifactId>junit</artifactId>
> <version>4.11</version>
> <scope>test</scope>
> </dependency>
> <dependency>
> <groupId>com.sun.faces</groupId>
> <artifactId>jsf-api</artifactId>
> <version>2.2.4</version>
> </dependency>
> <dependency>
> <groupId>com.sun.faces</groupId>
> <artifactId>jsf-impl</artifactId>
> <version>2.2.4</version>
> </dependency>
> <dependency>
> <groupId>javax.enterprise</groupId>
> <artifactId>cdi-api</artifactId>
> <version>1.1</version>
> </dependency>
> <dependency>
> <groupId>org.jboss.weld.servlet</groupId>
> <artifactId>weld-servlet</artifactId>
> <version>2.0.4.Final</version>
> </dependency>
> <dependency>
> <groupId>log4j</groupId>
> <artifactId>log4j</artifactId>
> <version>1.2.17</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.slf4j</groupId>
> <artifactId>slf4j-api</artifactId>
> <version>1.7.5</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.slf4j</groupId>
> <artifactId>slf4j-log4j12</artifactId>
> <version>1.7.5</version>
> <scope>compile</scope>
> </dependency>
>
> <dependency>
> <groupId>commons-logging</groupId>
> <artifactId>commons-logging</artifactId>
> <version>1.1.3</version>
> </dependency>
> <dependency>
> <groupId>org.apache.deltaspike.core</groupId>
> <artifactId>deltaspike-core-api</artifactId>
> <version>${deltaspike.version}</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.apache.deltaspike.core</groupId>
> <artifactId>deltaspike-core-impl</artifactId>
> <version>${deltaspike.version}</version>
> <scope>runtime</scope>
> </dependency>
> <dependency>
> <version>1.0.1.Final</version>
> <groupId>org.hibernate.javax.persistence</groupId>
> <artifactId>hibernate-jpa-2.0-api</artifactId>
> <scope>provided</scope>
> </dependency>
>
> <dependency>
> <groupId>org.hibernate</groupId>
> <artifactId>hibernate-core</artifactId>
> <version>4.2.6.Final</version>
> </dependency>
>
> <dependency>
> <groupId>org.apache.deltaspike.modules</groupId>
> <artifactId>deltaspike-jpa-module-api</artifactId>
> <version>${deltaspike.version}</version>
> <scope>compile</scope>
> </dependency>
> <dependency>
> <groupId>org.apache.deltaspike.modules</groupId>
> <artifactId>deltaspike-jpa-module-impl</artifactId>
> <version>${deltaspike.version}</version>
> <scope>runtime</scope>
> </dependency>
> </dependencies>
> <repositories>
> <repository>
> <id>people.apache.snapshots</id>
> <url>
> http://repository.apache.org/content/groups/snapshots-group/
> </url>
> <releases>
> <enabled>false</enabled>
> </releases>
> <snapshots>
> <enabled>true</enabled>
> </snapshots>
> </repository>
> </repositories>
> <pluginRepositories> <pluginRepository>
> <id>apache.snapshots</id>
> <name>Apache Snapshots</name>
> <url>
> http://repository.apache.org/content/groups/snapshots-group/
> </url>
> <releases>
> <enabled>false</enabled>
> </releases>
> <snapshots>
> <enabled>true</enabled>
> </snapshots>
> </pluginRepository></pluginRepositories>
> <build>
> <finalName>prog_tomcat</finalName>
> <plugins>
> <plugin>
> <groupId>org.apache.tomcat.maven</groupId>
> <artifactId>tomcat7-maven-plugin</artifactId>
> <version>2.1</version>
> <configuration>
> <server>mytomcat</server>
> <url>http://localhost:8080/manager/text</url>
> <contextReloadable>true</contextReloadable>
> </configuration>
> </plugin>
> </plugins>
> </build>
> </project>
>
> thanks everyone !!!