• 通过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
    [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>";
    ?>

    通过浏览器进行浏览,看到如下内容:

    说明数据已经插入成功。

  • 相关阅读:
    二进制文件分析工具-hexdump使用指南
    麦克风阵列技术-beaforming开源算法源码分析
    CMake的作用和价值--概念简介
    matlab load函数用法 实例
    SparkSQL(3.1.1)源码分析
    Spark SQL: Relational Data Processing in Spark (SIGMOD’15)
    论文解析 -- QuickSel: Quick Selectivity Learning with Mixture Models (SIGMOD’20)
    Is Query Optimization a “Solved” Problem? (2014, Guy Lohman)
    Adaptive Statistics in Oracle 12c(PVLDB 2017)
    论文解析 -- A Survey on Advancing the DBMS Query Optimizer: Cardinality Estimation, Cost Model, and Plan Enumeration (Data Science and Engineering 2021)
  • 原文地址:https://www.cnblogs.com/hengwei/p/5930658.html
Copyright © 2020-2023  润新知