AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 732959
Accepted
David W
David W
Asked: 2015-11-01 03:44:43 +0800 CST2015-11-01 03:44:43 +0800 CST 2015-11-01 03:44:43 +0800 CST

chroot php-fpm 进程到用户家

  • 772

我正在从单个 PHP 实例移动位于单个服务器上的每个网站(因此所有网站中的所有文件都归 apache 所有,并且仅安装了默认的 php 库而没有安装 php-fpm) ...我正在为每个单独的网站安装一个 php-fpm 池。

更好的安全性和网站分离是我的目标,最大的目标是 1 个网站中的 PHP 脚本将无法从另一个网站访问 PHP 脚本。

我显然做错了什么。

我的环境:

  • CentOS 7
  • PHP 5.4.16
  • 阿帕奇 2.4.6

这是一个示例 php-fpm 池配置文件:

[root@host]# cat /etc/php-fpm.d/website1.com.conf 
    [website1.com]
    user = user1
    group = user1
    listen = /var/run/php-fpm/website1.com.sock
    listen.owner = user1
    listen.group = user1
    php_admin_value[disable_functions] = exec,passthru,shell_exec,system
    php_admin_flag[allow_url_fopen] = on
    php_admin_value[short_open_tag] = On
    pm = ondemand
    pm.max_children = 5
    pm.start_servers = 2
    pm.min_spare_servers = 1
    pm.max_spare_servers = 3
    chdir = /home/www/website1.com/

这是它在 Apache 中对应的 vhost 文件:

[root@host]# cat /etc/httpd/conf.d/website1.com.conf 
        <VirtualHost *:80>
                ServerAdmin [email protected]
                ServerName website1.com
        ServerAlias www.website1.com
        DocumentRoot /home/www/website1.com/www
                <Directory "/home/www/website1.com/www">
                        Options Includes FollowSymLinks
                        AllowOverride All
                        Order allow,deny
                        Allow from all
                </Directory>
        ErrorLog /home/www/website1.com/logs/errors
        CustomLog /home/www/website1.com/logs/access_log common
                <FilesMatch "\.php$">
                        SetHandler "proxy:unix:///var/run/php-fpm/website1.com.sock|fcgi://website1.com/"
                </FilesMatch>

        </VirtualHost>

所有文件和文件夹都由 user1 单独拥有(该组也设置为 user1)。

我在“website2”中有一个 PHP 脚本,它仍然能够访问“website1”内容。“website2”的 php-fpm 池配置文件中的设置和“website2”Apache vhost 配置文件中的设置与网站 1 相同(除了不同的文件夹路径、主目录、chroot 等...)。

这是我的测试脚本,位于 /home/www/website2/www/ 并可通过 website2.com 域名访问:

<?php
$test = file_get_contents('/home/www/website1.com/www/wp-config.php');
echo $test;
#$files = scandir('/home/www');
#print_r($files);
?>

然而,这个脚本的输出有点出乎意料。我没有看到 wp-config.php 的全部内容。相反,我看到的是文件中某个点之外的所有内容(如果您熟悉 wp-config.php,我会在define('SECURE_AUTH_KEY','foo')条目之后看到所有内容)。

为什么这个在“user2”下运行的测试脚本可以访问并回显在“user1”目录中找到的 wp-config.php 的一些内容?我认为该chdir = /home/www/website1.com/指令会阻止这种事情。

php-fpm
  • 1 1 个回答
  • 8857 Views

1 个回答

  • Voted
  1. Best Answer
    Joshua Griffiths
    2015-11-01T04:15:01+08:002015-11-01T04:15:01+08:00

    看来您已经设置chdir而不是chroot在您的 php-fpm 池配置中。

    该chdir指令只是更改该池的 php 进程的工作目录;它不会在 chroot 中启动进程。

    看到这个问题。

    • 5

相关问题

  • 不小心将 chown “root” 设置为我所有的服务器

  • Nginx + PHP-FPM = "随机" 502 错误网关

  • PHP-FPM + NGINX:PHP-CGI 进程在空闲一段时间后死亡,然后 502 bad gateway 和需要手动重启

  • 如何使程序从源代码保持最新?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve