Использование Postgres с Grails
Кто-нибудь получил Grails, работающего с Postgres? Я использовал этот учебник, и все, кажется, имеет смысл и будет правильным для меня. Однако, когда я "grails run-app", я получаю эту ошибку
Cannot create JDBC driver of class 'org.postgresql.Driver' for connect URL 'jdbc:postgres://10.0.0.21/tribes'
java.sql.SQLException: No suitable driver
Мой файл DataSource
dataSource {
pooled = true
driverClassName = "org.postgresql.Driver"
dialect = org.hibernate.dialect.PostgreSQLDialect
}
hibernate {
cache.use_second_level_cache=true
cache.use_query_cache=true
cache.provider_class='com.opensymphony.oscache.hibernate.OSCacheProvider'
}
// environment specific settings
environments {
development {
dataSource {
dbCreate = "update"
url = "jdbc:postgres://10.0.0.21:5432/tribes"
username = "grails"
password = "grails"
}
}
test {
dataSource {
dbCreate = "update"
url = "jdbc:postgres://10.0.0.21:5432/tribes"
username = "grails"
password = "grails"
}
}
production {
dataSource {
dbCreate = "update"
url = "jdbc:postgres://10.0.0.21:5432/tribes"
username = "grails"
password = "grails"
}
}
}
Ответы
Ответ 1
Из FAQ: "[if] вы получаете ошибку времени выполнения, которая гласит:" Не найдено подходящего драйвера ", скорее всего, URL передано в DriverManager.getConnection, неверно или неверно". Так что с тобой не так? Ну, примеры в учебнике выглядят так:
jdbc:postgresql://localhost:5432/grails
Ваш выглядит следующим образом:
jdbc:postgres://10.0.0.21:5432/tribes
Я предполагаю, что эти недостающие две буквы вызывают проблемы.
Ответ 2
В файле BuildConfig.groovy раскомментируйте внешние хранилища maven и добавьте эту строку
runtime 'postgresql: postgresql: 9.0-801.jdbc4' в разделе зависимостей