上一篇,我写了关于用一个map管理mongodb多个数据源(每个数据源,只有单例)的内容。
临到部署到阿里云的测试环境,发现还需要考虑一下主从的问题,阿里云买的数据库,不是说让你无感知的,而是给了2个url,一个主一个从的,这个只能我们在java代码里初始化实例的时候,配置进去。
庆幸的是,实例化MongoClient的时候,初始化方法里,有考虑集群的这种情况。
所以从单例改主从,只需要把原来的以String connectionString参数的构造方法,
MongoClient client = MongoClients.create(String类型的mongoUrl地址);
改为使用MongoClientSettings参数的构造方法,即可。
代码如下改动:
- //账号密码认证
- MongoCredential credentia =
- MongoCredential.createScramSha1Credential(
- 用户名, mongo权限验证库-默认是admin, 用户密码.toCharArray());
- //将主从地址以数组的形式进行传入,第一个是主,除了第一个之外的是从库
- List
serverList = new ArrayList<>(); - serverList.add(new ServerAddress(主域名, 主端口));
- //serverList.add(new ServerAddress(从域名, 从端口));
- MongoClientSettings settings =
- MongoClientSettings.builder()
- .applyToClusterSettings(builder -> builder.hosts(serverList).这里还可以设置集群的各种属性,自己决定吧)
- .credential(credentia)
- .build();
- MongoClient client = MongoClients.create(settings);
然后使用MongoTemplate的下列初始化方法,即可得到指定主从的template