2016-08-04 20 views
0

私は狂気のようにGoogleで検索しましたが、私はJava永続性を使用して何がうまくいかないのか探していません。ValidationException例外の説明:データソースを取得できません[jdbc/MyDataBase]

私はグラスフィッシュを使用しています。4.1.1。 NetBeans 8.1。 Glassfishはネットビーンと統合されており、サーバーとJDBCのリソースはすべてWindows->サービスエリアに表示されます。接続のための

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から細かいプールのpingので、私はそれがありますかなり確信しています。

私の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] 

サーバーにリソースがありますが、これは間違っていますか? Entity Managerを作成するのではなく、接続を確立する必要があると思いましたか?現在実行中のサーバーはありません。私は非常にシンプルなものを見逃しているように感じますが、それが何であるか分かりません。

+0

あなたのクライアントは何ですか?グラスフィッシュのウェブアプリケーションとしてこれを導入しているのですか?またはグラスフィッシュの外部からアクセスしようとしていますか? あなたが外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サーバーを使用するのではなく、独自のものを使用していました。

GlassFishドメインをシャットダウンしてエラーが発生し、使用中のポートのエラーを取得した後、そのことが分かりました。私はついに、サーバーの2つの実行インスタンスがあることを認識しました。私がダウンロードしてインストールしたものとNetBeansが実行していたもの。

ローカルテスト用にインストールされたサーバーを使用するか(簡単に)、NetBeansのインストールにコピーしたローカルのdomain.xmlにすべての設定を行うようにNetBeansを設定することをお勧めしますあまり簡単ではない)。

関連する問題