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

时间:2018-07-24 13:10:03

标签: java spring spring-boot embedded-database spring-mongodb

我目前正在研究Spring Boot应用程序2.0.3.RELEASE。我想用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

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

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

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

1 个答案:

答案 0 :(得分: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的实现中启用复制集