grails创建程序
最近,我想使用相同的Postgres数据库,但将我的持久性层拆分为使用独立模式的独立组件。 其动机是促进模块化设计,分离关注点并阻止开发人员彼此绊倒。 垂直域模型可能很难实现,但并非不可能。
在我的购物应用程序中,我有一个用户组件,一个购物组件和一个产品组件。 现在,如果您使用单独的数据库,这将非常容易,但是有时在同一数据库中使用单独的模式将关注点分离是一件好事,因为使用同一数据库可以使灾难恢复,日志传送,复制等工作变得更加容易。
虽然我可以找到用于单独数据库的文档,但是发现很难找到Grails文档来建议我的特定问题- 使用Postgres时如何在使用同一数据库时使用单独的模式 。 所以这就是我最终做的方式。
这是我的datasource.groovy。
String db_url = "jdbc:postgresql://localhost:5432/testdb"
String usernameVar = "db_user"
String passwordVar = "db_secret"
String dbCreateVar = "update"
String dialect = "net.kaleidos.hibernate.PostgresqlExtensionsDialect"
dataSource_user {
pooled = true
jmxExport = true
dialect = dialect
driverClassName = "org.postgresql.Driver"
username = usernameVar
password = passwordVar
url = platform_url
dbCreate= "validate"
}
hibernate_user {
cache.use_second_level_cache = false
cache.use_query_cache = false
cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
singleSession = true // configure OSIV singleSession mode
default_schema = "user"
}
dataSource_shopping {
pooled = true
jmxExport = true
dialect = dialect
driverClassName = "org.postgresql.Driver"
username = usernameVar
password = passwordVar
url = platform_url
dbCreate = "validate"
}
hibernate_shopping {
cache.use_second_level_cache = false
cache.use_query_cache = false
cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
singleSession = true // configure OSIV singleSession mode
default_schema = "shopping"
}
dataSource_product {
pooled = true
jmxExport = true
dialect = dialect
driverClassName = "org.postgresql.Driver"
username = usernameVar
password = passwordVar
url = platform_url
dbCreate= "validate"
}
hibernate_product {
cache.use_second_level_cache = false
cache.use_query_cache = false
cache.region.factory_class = 'net.sf.ehcache.hibernate.EhCacheRegionFactory' // Hibernate 3
singleSession = true // configure OSIV singleSession mode
default_schema = "product"
}
注意:上面的配置中有一些明显的优化,但是以上只是使解释变得简单。
然后,我将每个GORM对象映射到适当的架构。
class Cart {
// ...
// ...
static mapping = {
datasource 'shopping'
// ...
}
}
class Address {
// ...
// ...
static mapping = {
datasource 'user'
}
}
class Stock {
// ...
// ...
static mapping = {
datasource 'product'
}
}
然后,我启动了我的应用程序,并说“是的,这有效”,稍作休息,转到下一个问题。 可以看出,诀窍是使用单独的Hibernate闭包,在其中指定架构,并对单独的数据库使用相同的命名格式为闭包命名,但是使数据库闭包指向同一数据库。
grails创建程序