theoforce 发表于 2017-6-30 18:24:15

通过php的MongoDB driver连接Azure的DocumentDB PaaS

  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

name=epel
baseurl=http://mirrors.sohu.com/fedora-epel/6/$basearch
enabled=1
gpgcheck=0


mongo.repo

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');
($mongo);
echo "<br>";
$mongodb = $mongo->mydb;
($mongodb);
echo "<br>";
$collection = $mongodb->selectCollection('stu');
($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->()."<br>";
?>
  通过浏览器进行浏览,看到如下内容:

  说明数据已经插入成功。
页: [1]
查看完整版本: 通过php的MongoDB driver连接Azure的DocumentDB PaaS