Невозможно подключиться к встроенной базе данных дерби в Glassfish с Hibernate - PullRequest
2 голосов
/ 25 ноября 2011

Ошибка:

Connection could not be allocated because: 
The connection was refused because the database chapter2 was not found.

Persistence.xml

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="1.0"
   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_1_0.xsd">
   <persistence-unit name="users" transaction-type="JTA">
      <provider>org.hibernate.ejb.HibernatePersistence</provider>
      <jta-data-source>jdbc/chapter2</jta-data-source>
      <properties>
         <property name="hibernate.hbm2ddl.auto" value="create-drop" />
         <property name="hibernate.dialect" value="org.hibernate.dialect.DerbyDialect" />
      </properties>
   </persistence-unit>
</persistence>

Domain.xml: весь домен .xml можно найти здесь

<resources>
    <jdbc-resource pool-name="Chapter2Pool" description="Chapter 2 Datasource" jndi-name="jdbc/chapter2" />
    <jdbc-connection-pool datasource-classname="org.apache.derby.jdbc.ClientDataSource" res-type="javax.sql.DataSource" name="Chapter2Pool">
        <property name="DatabaseName" value="chapter2" />
        <property name="Password" value="password" />
        <property name="PortNumber" value="1527" />
        <property name="ServerName" value="localhost" />
        <property name="User" value="admin" />
        <property name="URL" value="jdbc:derby://localhost:1527/chapter2" />
        <property name="connectionAttributes" value="create=true" />
    </jdbc-connection-pool>
</resources>
<servers>
        <server name="server" config-ref="server-config">
            <application-ref ref="__admingui" virtual-servers="__asadmin" />
            <resource-ref ref="jdbc/__TimerPool" />
            <resource-ref ref="jdbc/__default" />
            <resource-ref ref="jdbc/chapter2" />
        </server>
</servers>

полный исходный код, включая pom.xml, находится здесь

Я запустил сервер derby снаружи, используя команду setNetworkServerCP

 % sudo lsof -i :1527
COMMAND  PID    USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
java    3369 bhaarat   27u  IPv6  29472      0t0  TCP localhost:1527 (LISTEN)

Ответы [ 2 ]

2 голосов
/ 26 ноября 2011

разрешений может быть трудно иметь дело. derby работал под /usr/share/javadb/bin, а пользователь, запустивший intelliJ, не был пользователем root и, следовательно, не имел права записи в эту папку. Поэтому, чтобы решить эту проблему, я должен был предоставить права на запись в эту папку пользователю, запустившему intelliJ. Таким образом, база данных была успешно создана. Я все еще желаю, чтобы ошибка была более информативной. все, что связано с Permission, дало бы мне этот совет намного раньше.

2 голосов
/ 25 ноября 2011

О, верно, я пропустил заголовок.

Вы пытаетесь подключиться к встроенному Derby, используя драйверы для автономного сервера. Сервер не работает, следовательно, ошибка.

Это свойство обязательно должно быть изменено:

<property name="URL" value="jdbc:derby:path_to_database;create=true" />

И драйвер должен быть: org.apache.derby.jdbc.EmbeddedDriver

Кроме того, реализация пула соединений во встроенном не имеет смысла, поскольку в этом режиме может быть только одно соединение.

...