如何使用2个单独的数据库,一个用于写端,一个用于读端。 (两个数据库通过事件总线同步)

时间:2019-04-02 01:42:34

标签: javascript node.js typescript cqrs nestjs

我正在使用@nestjs/cqrs模块。如何使用两个单独的数据库,一个用于写端,一个用于读端。 (两个数据库通过事件总线同步)

谢谢

1 个答案:

答案 0 :(得分:0)

使用typeorm,您可以通过指定连接名称来指定多个数据库(如果未指定名称,则将使用默认连接):

@Module({
  imports: [
    TypeOrmModule.forRoot({
      ...defaultOptions,
      name: 'WriteConnection',
      host: 'write_db_host',
      entities: [WriteEntity],
    }),
    TypeOrmModule.forRoot({
      ...defaultOptions,
      name: 'readConnection',
      host: 'read_db_host',
      entities: [ReadEntity],
    }),
  ],
})
export class ApplicationModule {}

然后在功能模块中,通过指定连接名称导入实体:

@Module({
  imports: [
    TypeOrmModule.forFeature([ReadEntity], 'readConnection'),
    TypeOrmModule.forFeature([WriteEntity], 'writeConnection'),
  ],
})
export class FeatureModule {}

有关更多信息,请参见docs