更多内容参考系列文章: nodejs系列提纲
如果你使用CloudFoundry(简称CF)这样一个PaaS做为你的NodeJs项目的部署环境,的确可以省事,起码不用自己安装nodejs和相关的service,而其部署方式也比AWS似乎来得更加容易。至少我的经历是这样的。ASW的Elastic Beanstalk老半天都不能通过Eclipse的插件同步到服务器,最后只能打包成war包,然后通过网页上传。而CF的vmc则要方便快捷高效得多。但是如果你使用了CF的mongodb,如何才能直接访问CF的mongodb呢?幸好CF提供了一个Tunnel功能。这里就是要讲述如何使用这个东西。
1. 准备工作
前提条件是要有vmc,如何安装vmc可以参考官方的文章
2. 安装caldecott
运行下面的命令安装caldecott
$sudo gem install caldecott
3. 创建Tunnel
创建mongodb service
$vmc create-service mongodb foodb
如果已经存在mongodb service自然可以越过这一步。
创建Tunnel
$vmc tunnel foodb
运行之后提示你输入密码,也就是你的CF帐号密码。
Deploying tunnel application 'caldecott'.
Create a password:*******
成功之后输出如下信息
Uploading Application:
Checking for available resources: OK
Packing application: OK
Uploading (1K): OK
Push Status: OK
Binding Service [mongodb-blog]: OK
Staging Application: OK
Starting Application: OK
Getting tunnel connection info: OK
Service connection info:
username : *******
password : *******
name : db
Starting tunnel to mongodb-blog on port 10000.
1: none
2: mongo
Which client would you like to start?:
注意这里的显示的用户名和密码是一长串字符串,应该是GUID,是作为你用客户端登陆时使用的,而显示的名字则是登陆时要指定的数据库名字,而不是你自己真正的数据库名字。接下来选择你要使用的client,我们这里使用1:none,也就是不要连接这个tunnel,因为待会我们自己另外启一个shell来连接。于是乎输入1,然后输出结果为。
Open another shell to run command-line clients or
use a UI tool to connect using the displayed information.
Press Ctrl-C to exit...
如果开始就决定使用1选项的话,可以在创建Tunnel的时候就直接使用下面的命令
$vmc tunnel foodb none
4. 连接Tunnel
重开一个shell,运行下面的命令:
mongo -port 10000 -u <your username> -p <your password> db
注意这里要求使用上面提到的用户名和密码,而且我们指定的数据库名称时上面生成的名称"db",而不是我们真实的db名称"foodb".
这样就可以连接成功了,接下来也就是象普通的mongodb命令行操作了。