2017-05-04 62 views
0

目前,我正在使用Bluemix来部署和使用PencilBlue托管网站。我的问题在于连接一个存储服务“compone-for-mongo”和pencilblue框架。 此连接通过VCAP JSON完成。 VCAP带有以下结构;Compose-for-mongodb与pencilblue的Bluemix连接

{ 
    "compose-for-mongodb": [ 
     { 
      "credentials": { 
       "db_type": "mongodb", 
       "name": "**************************************", 
       "uri_cli": "**************************************", 
       "ca_certificate_base64": "*********************************************************************", 
       "deployment_id": "*********************************", 
       "uri": "******************************************************" 
      }, 
      "syslog_drain_url": null, 
      "label": "compose-for-mongodb", 
      "provider": null, 
      "plan": "***********", 
      "name": "************************", 
      "tags": [ 
       "big_data", 
       "data_management", 
       "ibm_created" 
      ] 
     } 
    ] 
} 

据我了解这一点,“撰写换MongoDB的”是一个集群而不是服务器。我们需要通过VCAP JSON在PencilBlue和这个“集群”之间建立连接。目前,我们正试图带领JSO​​N解析在config.js像这样:

if (typeof process.env.VCAP_SERVICES === 'string') { 
     try { 
      var vcapServices = JSON.parse(process.env.VCAP_SERVICES); 
      var vcapMongo = vcapServices['compose-for-mongodb'][0].credentials; 

      var uri = vcapMongo.uri; 

      mongoConfig.servers = [ 
       uri 
      ]; 

      var userPassword = uri.split('mongodb://')[1].split('@')[0].split(':'); 

      mongoConfig.authentication = { 
       un: userPassword[0], 
       pw: userPassword[1] 
      }; 

      var db = uri.split('?uri=')[0].split('/')[1]; 

      mongoConfig.options.mongos = { 
       ssl: true, 
       sslValidate: true, 
       sslCA: [new Buffer(vcapMongo.ca_certificate_base64, 'base64')], 
       poolSize: 1, 
       reconnectTries: 1 
      }; 

      mongoConfig.name = db; 

我们已经尝试没有成功多种方式。

有没有人遇到过这个问题呢?有没有关于这个问题的任何文件?

重现步骤:

创建Bluemix节点应用程序,并将它与“撰写换MongoDB的”存储服务连接。

PencilBlue版本:0.8.0

环境说明:Node.js的SDK中Bluemix和撰写换MongoDB的服务连接

回答

1

我已经有经验和成功与NoSQL的数据源连接pencilblue框架如Compose-for-MongoDB。这里有一个sample repo,有一些方便的部署到bluemix按钮,为你设置一切 - 如果你想要一个交钥匙方法(注意:需要一些耐心:-)管道脚本包含一些硬编码延迟(~8分钟),以适应服务实例化的不确定性)。对于您的特定问题,存储库的config.js应该有所帮助。最后,该回购还使用this repo内的使用Bluemix Object Storage服务的媒体提供商插件。

下面是摘录:

[....] 

try { 
    var services = JSON.parse(process.env.VCAP_SERVICES); 
    // look for a service starting with 'mysql' 
    // MySQL is the only one supported by Ghost right now 
    for (var svcName in services) { 
     if (svcName.match(/^compose-for-mongodb/)) { 
      mongoCreds = services[svcName][0]['credentials']; 
      var uriObject = mongodbUri.parse(mongoCreds.uri) 
      mongoCreds.host = uriObject.hosts[0].host 
      mongoCreds.port = uriObject.hosts[0].port 
      mongoCreds.user = uriObject.username 
      mongoCreds.password = uriObject.password 
      mongoCreds.client = 'mongo'; 
      mongoCreds.userpass = mongoCreds.user + ":" + mongoCreds.password + "@" 
      mongoCreds.db = uriObject.database; 
     } 
    } 
} 

[....] 

"db": { 
     "type": mongoCreds.client, 
     "servers": [ 
      "mongodb://" + mongoCreds.userpass + mongoCreds.host + ":" + mongoCreds.port 
     ], 
     "name": mongoCreds.db, 
     "options": { 
      "server": { 
      "ssl": cloud, 
      "sslValidate": cloud, 
      "sslCert": Buffer.from(mongoCreds.ca_certificate_base64, 'base64').toString('ascii'), 
      "sslCA" : [Buffer.from(mongoCreds.ca_certificate_base64, 'base64').toString('ascii')] 
      } 
     }, 
     "writeConcern": "majority", 
     "query_logging": false, 
     "authentication": { 
      "un": mongoCreds.user, 
      "pw": mongoCreds.password 
     } 
    }, 

[....] 
+0

该文件是一个救星,谢谢 –