目录

php

其实php的编译很简单:

  • 获取并解压 PHP 源代码

    tar zxf php-x.x.x
    
  • 配置并构建PHP

    cd ../php-x.x.x
    ./configure --enable-fpm --with-mysql
    make
    sudo make install
    

    需要配置安装更多php扩展,可以通过configure –help 查看

  • 创建配置文件,并将其复制到正确的位置

    cp php.ini-development /usr/local/php/php.ini
    cp /usr/local/etc/php-fpm.d/www.conf.default /usr/local/etc/php-fpm.d/www.conf
    cp sapi/fpm/php-fpm /usr/local/bin
    

    配置文件根据实际情况,有所出入,大概意思明白即可。

nginx

PHP: Unix 系统下的 Nginx 1.4.x - Manual

需要着重提醒的是,如果文件不存在,则阻止 Nginx 将请求发送到后端的 PHP-FPM 模块, 以避免遭受恶意脚本注入的攻击。

将 php.ini 文件中的配置项 cgi.fix_pathinfo 设置为 0 。php7.1中默认值是1。

windows

Windows 下使用 Apache 安装 PHP 应用程序:XAMPP、WampServer 和 BitNami。

FPM

PHP: FastCGI 进程管理器(FPM) - Manual

官方php-fpm配置中文版:PHP-FPM配置 - Manual

FPM(FastCGI进程管理器)提供的函数fastcgi_finish_request()具有特殊功能:用于在请求完成和刷新数据后,继续在后台执行耗时的工作(录入视频转换、统计处理等);后续函数章节细讲。

PECL扩展库安装

要使用共享扩展库,必须经过编译,安装,然后加载。

  • 下载pecl扩展库

    • pecl install extname 命令会自动下载扩展代码,所以在这种情况下不需要再次下载。
    • https://pecl.php.net/ PECL 网站包括有 PHP 开发组提供的不同扩展库的信息。这里的信息包括:更新记录,版本说明,需求,以及其它信息。
  • pear编译pecl扩展库

    $ pecl install extname
    

    这将下载 extname 的源代码,编译之,并将 extname.so 安装到 extension_dir 中。然后 extname.so 就可以通过 php.ini 加载了。

    extension_dir可以通过php-config命令查看(下面会提到),比如:

        --extension-dir     [/usr/lib/php/20160303]
    
  • phpize 编译pecl扩展库

    phpize 命令是用来准备 PHP 扩展库的编译环境的。下面例子中,扩展库的源程序位于 extname 目录中:

    $ cd extname
    $ phpize
    $ ./configure
    $ make
    # make install
    

    成功的安装将创建 extname.so 并放置于 PHP 的扩展库目录中。需要调整 php.ini,加入 extension=extname.so 这一行之后才能使用此扩展库。

php-config

php-config 是一个简单的命令行脚本用于获取所安装的 PHP 配置的信息。

jm@ubuntu:~$ php-config -h
Usage: /usr/bin/php-config [OPTION]
Options:
--prefix            [/usr]
...
--extension-dir     [/usr/lib/php/20160303]
--include-dir       [/usr/include/php/20160303]
--man-dir           [/usr/share/man]
--php-binary        [/usr/bin/php7.1]
--php-sapis         [apache2handler cgi cli fpm ]
--phpapi            [20160303]
...

运行时配置php.ini

配置文件(php.ini)在 PHP 启动时被读取。对于服务器模块版本的 PHP,仅在 web 服务器启动时读取一次。对于 CGI 和 CLI 版本,每次调用都会读取。

.user.ini

自 PHP 5.3.0 起,PHP 支持基于每个目录的 INI 文件配置。此类文件 仅被 CGI/FastCGI SAPI 处理。如果你的 PHP 以模块化运行在 Apache 里,则用 .htaccess 文件有同样效果。

除了主 php.ini 之外,PHP 还会在每个目录下扫描 INI 文件,从被执行的 PHP 文件所在目录开始一直上升到 web 根目录($_SERVER[‘DOCUMENT_ROOT’] 所指定的)。如果被执行的 PHP 文件在 web 根目录之外,则只扫描该目录。

在php.ini中配置.user.ini文件:

  • user_ini.filename 设定了 PHP 会在每个目录下搜寻的文件名;如果设定为空字符串则 PHP 不会搜寻。默认值是 .user.ini。

  • user_ini.cache_ttl 控制着重新读取用户 INI 文件的间隔时间。默认是 300 秒(5 分钟)。

配置生效范围

模式 含义
PHP_INI_USER 可在用户脚本(例如 ini_set())或 Windows 注册表
PHP_INI_PERDIR 可在 php.ini,.htaccess 或 httpd.conf 中设定
PHP_INI_SYSTEM 可在 php.ini 或 httpd.conf 中设定
PHP_INI_ALL 可在任何地方设定

例如 output_buffering 指令是属于 PHP_INI_PERDIR,因而就不能用 ini_set() 来设定。但是 display_errors 指令是属于 PHP_INI_ALL 因而就可以在任何地方被设定,包括 ini_set()。

注:ini_set()就是可以在用户脚本中修改配置。

修改配置

修改配置的方式:

  • httpd.conf
  • .htaccess
  • windows修改注册表
  • ini_set函数

注:ini_set并不能修改所有配置

哪些指令配置可以在当前模式下修改详见:PHP: php.ini 配置选项列表 - Manual

比如upload_max_filesize只能在PHP_INI_PERDIR模式下修改,也就是只有php.ini、httpd.conf、.htaccess配置文件中才能修改生效。