Linux部署PHP选LAMP方案?

环境准备

  1. 更新系统

    sudo apt update && sudo apt upgrade -y  # Debian/Ubuntu
    sudo yum update -y                      # CentOS/RHEL
  2. 安装Apache服务器

    sudo apt install apache2 -y  # Debian/Ubuntu
    sudo yum install httpd -y    # CentOS/RHEL
    sudo systemctl start apache2 && sudo systemctl enable apache2  # 启动并设置开机自启
  3. 安装PHP及扩展

    sudo apt install php libapache2-mod-php php-mysql -y  # Debian/Ubuntu
    sudo yum install php php-mysqlnd -y                   # CentOS/RHEL
    sudo systemctl restart apache2  # 重启Apache使PHP生效

部署PHP文件

  1. 上传文件到服务器

    • 通过SFTP工具(如FileZilla)或命令行(scp)将PHP文件上传至Web根目录:
      • Apache默认目录:
        • Debian/Ubuntu: /var/www/html/
        • CentOS/RHEL: /var/www/html/
      • 示例:
        scp your_file.php user@server_ip:/var/www/html/
  2. 设置文件权限(确保安全)

    sudo chown -R www-data:www-data /var/www/html/  # Debian/Ubuntu (www-data为Apache用户)
    sudo chown -R apache:apache /var/www/html/      # CentOS/RHEL
    sudo chmod -R 755 /var/www/html/                # 设置目录可执行权限
    sudo chmod 644 /var/www/html/your_file.php      # 设置文件只读权限

配置Apache支持PHP

  1. 确认PHP模块已启用

    sudo a2enmod php8.x  # Debian/Ubuntu(替换x为版本号)
    sudo systemctl restart apache2
  2. 优先级设置(确保PHP文件优先解析)
    编辑Apache配置文件:

    sudo nano /etc/apache2/mods-enabled/dir.conf  # Debian/Ubuntu

    index.php 移到首位:

    <IfModule mod_dir.c>
         DirectoryIndex index.php index.html index.cgi index.pl index.xhtml index.htm
    </IfModule>

安全与优化

  1. 防火墙放行HTTP/HTTPS

    sudo ufw allow 80/tcp && sudo ufw allow 443/tcp  # Debian/Ubuntu
    sudo firewall-cmd --permanent --add-service={http,https}  # CentOS/RHEL
  2. 禁用危险函数
    编辑 php.ini

    sudo nano /etc/php/8.x/apache2/php.ini  # 路径根据版本调整

    修改:

    disable_functions = exec,passthru,shell_exec,system
  3. 安装SSL证书(推荐Let’s Encrypt)

    sudo apt install certbot python3-certbot-apache -y  # Debian/Ubuntu
    sudo certbot --apache -d your_domain.com

验证部署

  1. 创建测试文件 /var/www/html/info.php
    <?php phpinfo(); ?>
  2. 浏览器访问 http://your_server_ip/info.php,显示PHP配置信息即成功。

故障排查

  • 403 Forbidden:检查文件权限(chmod 644)和目录所有权(chown www-data)。
  • 500 Internal Error:查看Apache错误日志:
    sudo tail -f /var/log/apache2/error.log  # Debian/Ubuntu
    sudo journalctl -xe -u httpd             # CentOS/RHEL
  • PHP代码不执行:确认已安装 libapache2-mod-php 并重启Apache。

扩展方案

  • Nginx替代Apache
    1. 安装Nginx与PHP-FPM:
      sudo apt install nginx php-fpm -y
    2. 配置Nginx站点:
      server {
          listen 80;
          root /var/www/html;
          index index.php;
          location ~ \.php$ {
              include snippets/fastcgi-php.conf;
              fastcgi_pass unix:/run/php/php8.x-fpm.sock;
          }
      }

最佳实践

  1. 定期更新:使用 apt upgradeyum update 保持软件最新。
  2. 备份配置:修改关键文件前备份(如 cp php.ini php.ini.bak)。
  3. 最小权限原则:避免使用 777 权限,推荐 755(目录)和 644(文件)。
  4. 使用版本控制:通过Git管理代码,避免直接修改生产环境文件。

引用说明:本文操作基于Ubuntu 22.04/CentOS 7实测,参考Apache官方文档(https://httpd.apache.org/docs/)、PHP手册(https://www.php.net/manual/)及Let’s Encrypt指南(https://certbot.eff.org/),安全建议遵循OWASP PHP安全规范(https://owasp.org/www-project-php-security-guide/)。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/7342.html

(0)
酷番叔酷番叔
上一篇 6天前
下一篇 6天前

相关推荐

  • 如何停止运行中的Telnet服务?

    为什么必须禁用Telnet?安全风险:所有通信未加密,攻击者可轻松截获敏感信息,合规要求:多数安全标准(如PCI DSS)明确禁止使用Telnet,替代方案:SSH(Secure Shell)提供加密通信,是更安全的远程管理方式,禁用Telnet的两种方法方法1:停止并禁用Telnet服务适用系统:CentOS……

    2025年7月6日
    1200
  • 为什么firewalld无法开放指定端口?

    在Linux系统中,防火墙是保护系统安全的关键组件,它通过控制网络流量阻止未授权访问,禁用防火墙会显著增加系统遭受网络攻击的风险,仅建议在测试环境、内部安全网络或明确知晓后果的情况下操作,以下是不同防火墙工具的禁用方法,操作前请确保具备管理员权限(使用sudo),操作前准备确认当前防火墙工具执行以下命令查看系统……

    2025年7月7日
    1000
  • 如何进入Linux根目录?

    通过命令行进入根目录(推荐)适用场景:服务器管理、脚本编写、高级用户操作步骤:打开终端桌面用户:按 Ctrl+Alt+T(Ubuntu/CentOS等主流发行版通用)无图形界面:直接登录后进入命令行切换至根目录输入以下命令:cd /验证路径:执行 pwd,若显示 即表示成功,:运行 ls 可列出根目录下的子目录……

    2025年7月6日
    1000
  • Linux安装软件命令怎么选?

    安装前的准备更新系统安装前先更新软件源和已安装包,避免依赖冲突:# Debian/Ubuntusudo apt update && sudo apt upgrade# Red Hat/CentOSsudo dnf update # 或 sudo yum update# Arch/Manjaros……

    3天前
    600
  • 如何轻松备份数据?3步防丢失!

    在Linux系统中更新数据库通常涉及两个层面:更新数据库软件版本(如MySQL、PostgreSQL等)和更新数据库内的数据(执行SQL操作),以下是详细操作指南,涵盖常见场景和注意事项,确保安全性与专业性,更新数据库软件(升级版本)重要提示:务必先备份数据(见第四节),生产环境建议在低峰期操作,并提前测试,不……

    2025年6月15日
    1400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信