使用Mongodb版本4和副本配置flappedoodle嵌入式mongo

问题描述 投票:3回答:1

我目前正在开发Spring Boot应用程序2.0.3。我想用MongoDb 4.0版配置Flapdoodle MongoDb,我也想设置一个mongo实例并为其创建副本。

到目前为止,我还没有弄清楚使用flappoodle创建集群和副本的过程。

我正在使用

         MongodConfigBuilder().version(Version.Main.DEVELOPMENT)
        .replication(new Storage(null, null, 0))
        .build();

我在这里阅读了许多与此配置有关的问题,但没有一个与我的问题有关。例如How to configure two instance mongodb use spring boot and spring data

Flapdoodle配置对此有一个实现,但是我不确定如何访问它。

https://github.com/flapdoodle-oss/de.flapdoodle.embed.mongo/blob/master/src/main/java/de/flapdoodle/embed/mongo/tests/MongosSystemForTestFactory.java

在应用程序启动之前,是否可以通过任何方法在测试类中对其进行配置。谢谢

java spring spring-boot embedded-database spring-mongodb
1个回答
0
投票

我必须在Web集成测试中使用复制集启动Embedded mongo,使用下面的代码

@Configuration
public class MongoConfig {

    public static int mongodPort;
    public static String defaultHost = "localhost";
    static {
        try {
            mongodPort = Network.getFreeServerPort();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Bean
    public IMongodConfig prepareMongodConfig() throws IOException {
        IMongoCmdOptions cmdOptions = new MongoCmdOptionsBuilder()
                .useNoPrealloc(false)
                .useSmallFiles(false)
                .master(false)
                .verbose(false)
                .useNoJournal(false)
                .syncDelay(0)
                .build();

        IMongodConfig mongoConfigConfig = new MongodConfigBuilder()
                .version(Version.Main.PRODUCTION)
                .net(new Net(mongodPort, Network.localhostIsIPv6()))
                .replication(new Storage(null, "testRepSet", 5000))
                .configServer(false)
                .cmdOptions(cmdOptions)
                .build();
        return mongoConfigConfig;
    }

}

在调用控制器之前,我使用下面的代码启用了具有副本集的数据库

 Public class ITtest {
    public  void  setSystemProperty() {
            System.setProperty("spring.data.mongodb.port", String.valueOf(MongoConfig.mongodPort));
            System.setProperty("spring.data.mongodb.host", MongoConfig.defaultHost);
        }

        public static boolean isReplicaSetRun = false;

        public static void setupMongoReplica() {
            if (! isReplicaSetRun) {
                System.out.println("Starting db on port: " +MongoConfig.mongodPort);
                MongoClient client = new MongoClient(MongoConfig.defaultHost, MongoConfig.mongodPort);
                client.getDatabase("admin").runCommand(new Document("replSetInitiate", new Document()));
                client.close();
                isReplicaSetRun = true;
            }
        }

        @Test
        @Order(1)
        public void testParallel() {
            setSystemProperty();
            setupMongoReplica();
            // call web controller
      }
   }

如果要运行应用程序,则可以在ApplicationListener的实现中启用副本集

© www.soinside.com 2019 - 2024. All rights reserved.