Azure的DocumentDB是NoSQL类型的数据库。它还可以和目前流行的mongodb兼容,采用mongodb的driver可以直接连接Azure的DucumentDB。
目前在国内的Azure上,DocumentDB已经正式商用了,兼容mongodb的版本目前还在preview阶段。
本文将介绍如何创建,并通过php的mongodb的driver连接documentDB。
一 在Azure的管理界面上创建DocumentDB:
1 点击portal左上角的"+"号,然后输入documentdb,回车:
2 选择DucumentDB-Protocol Support for MongoDB (preview):
中间出现需要accept preview的选项,按接受。
3 点击Create后出现如下对话框,按所需内容进行填写:
4 几分钟后可以看到创建的DocumentDB已经上线:
5 创建db和collection:
点击创建的DocumentDB,在Overview中选择add database:
输入database的名字:
创建成功后,点击这个database:
进入到Database后,点击add collection:
在出现的对话框中输入:
可以根据自己的需要,选择相应performance的服务。
几秒钟,collection就创建好了。
6 记录链接字符串,在DocumentDB的中有一个选项叫Connection String,点击,并复制connection string:
二 在CentOS上安装php mongo driver
1 创建epel和mongo的repo
在/etc/yum.repos.d下,增加两个文件:
Epel.repo [epel] name=epel baseurl=http://mirrors.sohu.com/fedora-epel/6/$basearch enabled=1 gpgcheck=0
mongo.repo [mongodb-org-2.6] name=MongoDB 2.6 Repository baseurl=http://downloads-distro.mongodb.org/repo/redhat/os/x86_64/ gpgcheck=0 enabled=1
2 yum安装相应的软件:
yum install httpd -y yum install php -y yum install php-mysql php-gd libjpeg* php-imap php-ldap php-odbc php-pear php-xml php-xmlrpc php-mbstring php-mcrypt php-bcmath libmcrypt -y yum install openssl-devel -y yum install -y mongodb-org yum install php-pecl-mongo
php-pecl-mongo也可以采用手工的安装方式:
下载mongodb扩展
wget http://pecl.php.net/get/mongodb-1.1.8.tgz tar vxf mongodb-1.1.8.tgz mv mongodb-1.1.8 /usr/local/php-mongodb cd /usr/local/php-mongodb/ ./configure --with-php-config=/usr/bin/php-config Make && make install echo 'extension = mongo.so' > /etc/php.d/mongodb.ini
但这种安装需要注意各个版本的兼容关系。
3 在php中建立与DocumentDB的连接
在/var/www/html中创建index.php
<?php //phpinfo(); $mongo = new mongo('mongodb://hipomdb01:xxxx==@hipomdb01.documents.azure.cn:10250/?ssl=true'); var_dump($mongo); echo "<br>"; $mongodb = $mongo->mydb; var_dump($mongodb); echo "<br>"; $collection = $mongodb->selectCollection('stu'); var_dump($collection); for ($i=0; $i<=200; $i++){ $array= array('_id'=>$i+1,'sn'=>$i+1,'name'=>'zhang san'+$i,'gender'=>'male','age'=>8); $collection->insert($array); } echo "<br>"; echo 'count:' .$collection->count()."<br>"; ?>
通过浏览器进行浏览,看到如下内容:
说明数据已经插入成功。