2016-08-04 30 views
0

我瘋狂搜索,但我沒有找到使用java persistence發生了什麼問題。ValidationException異常說明:無法獲取數據源[jdbc/MyDataBase]

我正在使用glassfish 4.1.1。 NetBeans 8.1。 Glassfish與netbeans集成,Server和JDBC資源都顯示在Windows-> Services區域。

的persistence.xml

<?xml version="1.0" encoding="UTF-8"?> 
<persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd"> 
    <persistence-unit name="testDB" transaction-type="JTA">  
     <jta-data-source>jdbc/MyDataBase</jta-data-source> 
     <class>person.Person</class> 
     <exclude-unlisted-classes>false</exclude-unlisted-classes> 
    </persistence-unit> 
</persistence> 

的GlassFish在domain.xml的連接池入口和資源

<jdbc-resource pool-name="MyDataBase" object-type="system-all" jndi-name="jdbc/MyDataBase"></jdbc-resource> 
<jdbc-connection-pool driver-classname="java.sql.Driver" ping="true" datasource-classname="org.postgresql.Driver" name="MyDataBase" res-type="java.sql.Driver"> 
     <property name="URL" value="jdbc:postgresql://localhost:5432/testDB"></property> 
     <property name="connectionAttributes" value=";create=true"></property> 
     <property name="user" value="*****"></property> 
     <property name="password" value="****"></property> 
     <property name="portNumber" value="5432"></property> 
     <property name="databaseName" value="testDB"></property> 
     <property name="serverName" value="localhost"></property> 
</jdbc-connection-pool> 

泳池坪從GlassFish管理GUI很好,所以我敢肯定它的存在。

我的Java對象: 類與實體管理器:

package person; 

import javax.inject.Named; 
import javax.enterprise.context.RequestScoped; 
import javax.persistence.EntityManager; 
import javax.persistence.EntityManagerFactory; 
import javax.persistence.Persistence; 

/** 
* 
* @author jameszeigler 
*/ 
@Named(value = "personCreator") 
@RequestScoped 
public class PersonCreator { 

    private Person person; 

    /** 
     * Creates a new instance of PersonCreator 
     */ 
    public PersonCreator() { 
    } 

    public void setPersonValues(){ 
      person = new Person(); 
      person.setAge(10); 
      person.setFirstName("James"); 
      person.setLastName("Zeigler"); 
    } 

    public String getPersonValues(){ 
      return "Test"; 
    } 

    public void persistPerson(){ 
     EntityManagerFactory emfactory = Persistence.createEntityManagerFactory("testDB"); 

     EntityManager entitymanager = emfactory.createEntityManager(); 
     entitymanager.getTransaction().begin(); 

     setPersonValues(); 

     entitymanager.persist(person); 
     entitymanager.getTransaction().commit(); 

     entitymanager.close(); 
     emfactory.close(); 
    } 

} 

與實體類:

package person; 

import java.io.Serializable; 
import javax.persistence.Column; 
import javax.persistence.Entity; 
import javax.persistence.GeneratedValue; 
import javax.persistence.GenerationType; 
import javax.persistence.Id; 

/** 
* 
* @author jameszeigler 
*/ 
@Entity 
public class Person implements Serializable { 

    // Data Members // 
    private static final long serialVersionUID = 1L; 
    @Id 
    @GeneratedValue(strategy = GenerationType.AUTO) 
    private Long id; 
    @Column(name="firstName") 
    private String firstName; 
    @Column(name="lastName") 
    private String lastName; 
    @Column(name="age") 
    private int age; 


    // Methods // 
    public Long getId() { 
      return id; 
    } 

    public void setId(Long id) { 
      this.id = id; 
    } 

    public void setFirstName(String firstName){ 
      this.firstName = firstName; 
    } 

    public String getFirstName(){ 
      return firstName; 
    } 

    public void setLastName(String lastName){ 
      this.lastName = lastName; 
    } 

    public String getLastName(){ 
      return lastName; 
    } 

    public void setAge(int age){ 
      this.age = age; 
    } 

    public int getAge(){ 
      return age; 
    } 

    @Override 
    public int hashCode() { 
      int hash = 0; 
      hash += (id != null ? id.hashCode() : 0); 
      return hash; 
    } 

    @Override 
    public boolean equals(Object object) { 
      // TODO: Warning - this method won't work in the case the id fields are not set 
      if (!(object instanceof Person)) { 
       return false; 
      } 
      Person other = (Person) object; 
      if ((this.id == null && other.id != null) || (this.id != null && !this.id.equals(other.id))) { 
       return false; 
      } 
      return true; 
    } 

    @Override 
    public String toString() { 
      return "person.Person[ id=" + id + " ]"; 
    } 

} 

我發誓這應該工作,但我得到了檢驗除外:

javax.persistence.PersistenceException: Exception [EclipseLink-7060] (Eclipse Persistence Services - 2.6.1.v20150605-31e8258): 
org.eclipse.persistence.exceptions.ValidationException Exception Description: 
Cannot acquire data source [jdbc/MyDataBase]. Internal Exception: javax.naming.NamingException: Lookup failed for 'jdbc/MyDataBase' in SerialContext[myEnv={java.naming.factory.initial=com.sun.enterprise.naming.impl.SerialInitContextFactory, 
java.naming.factory.state=com.sun.corba.ee.impl.presentation.rmi.JNDIStateFactoryImpl, java.naming.factory.url.pkgs=com.sun.enterprise.naming} [Root exception is javax.naming.NameNotFoundException: MyDataBase not found] 

服務器有這個作爲一個資源,我做錯了嗎?我認爲我可能需要建立連接而不是創建實體管理器?目前沒有其他服務器正在運行。我覺得我錯過了很簡單的事情,但我不確定它是什麼。

+0

你的客戶是什麼?你是否將這個應用程序部署爲glassfish中的Web應用程序,或試圖從外部glassfish訪問? 如果您正在運行外的GlassFish環境,確保你有額外的GlassFish罐子 <! - https://mvnrepository.com/artifact/org.glassfish.extras/glassfish-embedded-all - > 組織.glassfish.extras 與GlassFish嵌入式所有 3.2-B06 Kenshin

+0

此外,由於它的EclipseLink,你嘗試加入這一行 <屬性名= 「eclipselink.target服務器」 值=」 SunAS9" /> – Kenshin

回答

1

不得不回到這一個。我似乎通過從Galssfish 4.1切換到Payara解決了這個問題。 Glassfish 4.1顯然在JDBC資源和連接池方面存在問題。而且我完全錯誤地配置了我的NetBeans。 NetBeans自帶GlassFish安裝,因此我沒有使用已安裝和配置的GlassFish服務器,而是使用自己的服務器,並且不知道我在談論什麼jdbc池。

在得到關閉GlassFish域名和獲取端口使用錯誤的錯誤後,我能夠弄清楚這一點。我終於意識到我有兩個正在運行的服務器實例。我下載並安裝的那個,以及一個NetBeans也在運行。

確保我將NetBeans配置爲使用已安裝的服務器進行本地測試(更簡單),或確保在本地domain.xml中進行的任何配置(我已將其複製到NetBeans安裝中)不那麼容易)。

相關問題