zoukankan      html  css  js  c++  java
  • windows 下编译php扩展库pecl里的扩展memcache

    Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

    本篇主要简述编译php及其扩展memcache,在阅读后面内容之前,建议先阅读一下官方文档介绍的“从源程序编译”。下面我们以php-5.3.10为例。

    一、编译环境

    根据你的php版本选择相应的编译器:

    php 5.3-5.4 :Visual C++ 9.0(Visual Studio 2008)

    php 5.5+ :Visual C++ 11.0(Visual Studio 2012)

    如果是php5.3-5.4,还要下载并安装Windows SDK 6.1(下载地址)//用作后面执行命令

    二、编译文件

    1、下载php源代码,http://php.net/releases/

    2、下载php sdk文件,http://windows.php.net/downloads/php-sdk/

    3、下载memcache扩展代码包,http://pecl.php.net/package/memcache

    4、下载完毕后一共有这些文件

    戳这里一键打包下载http://pan.baidu.com/s/1pJ3esav

    三、编译工作

    1、创建编译目录“C:php_sdk”  //在C盘下创建php_sdk目录

    2、解压php-sdk-binary-tools-20110915.zip里面的文件到php_sdk目录下

    3、在开始菜单找到并打开Windows SDK CMD Shell,然后执行

    setenv /x86 /xp /release  
    cd php_sdk  
    binphpsdk_setvars.bat  
    binphpsdk_buildtree.bat phpdev  
    

      执行后,目录下会生成phpdev文件夹

    4、进入C:php_sdkphpdevvc9x86,把deps-5.3-vc9-x86.7z解压到该目录下,覆盖deps文件夹。

    5、把php源代码也解压到x86目录下。

    6、在x86目录下创建pecl文件夹,把memcache压缩包内容解压到pecl目录,并把文件夹名memcache-2.2.7改为memcache

    7、在x86目录下创建obj文件夹,用于保存编译时生成的文件

    8、执行以下命令,用于创建php编译配置

    cd phpdevvc9x86php5.3-201308211030  
    buildconf  
    configure --help >..configure_help.txt  
    configure --disable-all --enable-snapshot-build --enable-cli --enable-cgi --enable-memcache=shared --enable-object-out-dir=..obj --enable-session  
    

      

    注:配置中的--enable-memcache=shared意思是 memcache 以 dll 形式生成,否则就和php集成在一起了。

    如果提示bison.exe不存在,执行命令,再重新执行上面的操作

    set path=%path%;C:php_sdkin  
    

    9、编译php,执行以下命令

    nmake
    

    10、如果想打包php,执行以下命令

    nmake snap
    

    编译中需要一点时间,请耐心等待编译。

    到这里,编译工作应该结束了。可以在C:php_sdkphpdevvc9x86objReleaseTS目录中找到php_memcache.dll

    注:本文参考http://blog.csdn.net/mycwq/article/details/10165955

  • 相关阅读:
    Postgresql
    Partitioning with PostgreSQL v11 (转发)
    Partitioning with PostgreSQL v11 (转发)
    What is Data Partitioning?(转发)(未完待续)
    How to use table partitioning to scale PostgreSQL(转发)
    PostgreSQL 创建分区表(转发)
    json vs jsonb
    性能不佳的多线程应用程序的常见模式(microsoft)
    提高.net程序性能和稳定性-CLR Profile(转发)
    检查c#代码内存泄露工具-CLR Profiler工具使用(转发)
  • 原文地址:https://www.cnblogs.com/songlen/p/4548004.html
Copyright © 2011-2022 走看看