0

0

php怎么安装_在云服务器上部署PHP环境的步骤

蓮花仙者

蓮花仙者

发布时间:2025-09-27 23:28:01

|

922人浏览过

|

来源于php中文网

原创

答案:在云服务器上部署PHP环境需搭建LEMP栈(Linux+Nginx+MySQL+PHP-FPM),依次更新系统、安装Nginx、MariaDB、PHP-FPM及扩展,配置Nginx解析PHP并测试,最后通过权限控制、安全配置、防火墙和HTTPS等措施保障环境安全稳定。

php怎么安装_在云服务器上部署php环境的步骤

在云服务器上部署PHP环境,本质上就是搭建一个能够解析和运行PHP代码的Web服务栈,通常会包含一个Web服务器(如Nginx或Apache)、PHP解释器(通常是PHP-FPM)以及一个数据库(如MySQL或MariaDB)。这听起来可能有点复杂,但其实只要理清思路,一步步来,并不难。关键在于理解每个组件的作用,并正确地将它们连接起来。

解决方案

在云服务器上部署PHP环境,我个人倾向于使用LEMP栈(Linux + Nginx + MySQL/MariaDB + PHP-FPM),因为它在性能和资源占用上表现出色,尤其适合高并发场景。以下是在Ubuntu Server上部署PHP环境的详细步骤。

我们首先要确保系统是最新的。这总是一个好习惯,能避免一些不必要的依赖问题。

sudo apt update
sudo apt upgrade -y

安装Nginx Web服务器 Nginx是一个高性能的Web服务器,它的事件驱动架构让它在处理静态文件和反向代理方面非常高效。

sudo apt install nginx -y
sudo systemctl start nginx
sudo systemctl enable nginx

安装完成后,你可以在浏览器中访问你的服务器IP地址,应该能看到Nginx的欢迎页面。如果看不到,检查防火墙设置(如UFW)。

立即学习PHP免费学习笔记(深入)”;

安装MySQL/MariaDB数据库 大多数PHP应用都需要数据库来存储数据。MariaDB是MySQL的一个分支,功能强大且开源。

sudo apt install mariadb-server -y
sudo mysql_secure_installation

mysql_secure_installation这个脚本非常重要,它会引导你设置root密码、删除匿名用户、禁止root远程登录、删除测试数据库等,这是数据库安全的第一步。务必认真完成。

安装PHP和PHP-FPM PHP-FPM(FastCGI Process Manager)是PHP的FastCGI实现,它负责管理PHP进程,并将PHP请求传递给Nginx。Nginx本身不能直接解析PHP代码,需要PHP-FPM来处理。

我们还需要安装一些常用的PHP扩展,比如php-mysql用于连接MySQL数据库,php-cli用于命令行操作,php-fpm是核心,还有一些其他常用的如php-gd(图片处理)、php-xml(XML解析)、php-mbstring(多字节字符串处理)等。

sudo apt install php-fpm php-mysql php-cli php-gd php-xml php-mbstring php-zip php-curl -y

安装完成后,PHP-FPM服务会自动启动并设置为开机自启。你可以检查一下它的状态:

sudo systemctl status php*-fpm

请注意,php*-fpm中的星号是通配符,因为PHP版本可能会是php7.4-fpmphp8.1-fpm等。

配置Nginx以处理PHP请求 这是将Nginx和PHP-FPM连接起来的关键一步。我们需要修改Nginx的站点配置文件。通常,默认的配置文件位于/etc/nginx/sites-available/default

sudo nano /etc/nginx/sites-available/default

在文件中找到location ~ \.php$这一段(通常是被注释掉的),将其修改成类似下面的样子。这里我假设你的Web根目录是/var/www/html

server {
    listen 80 default_server;
    listen [::]:80 default_server;
    root /var/www/html;
    index index.php index.html index.htm;
    server_name your_domain_or_ip; # 替换成你的域名或IP

    location / {
        try_files $uri $uri/ =404;
    }

    location ~ \.php$ {
        include snippets/fastcgi-php.conf;
        fastcgi_pass unix:/var/run/php/php*-fpm.sock; # 确保这里的socket路径与你的PHP-FPM版本匹配
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        include fastcgi_params;
    }

    # 可选:禁止访问.htaccess文件
    location ~ /\.ht {
        deny all;
    }
}

保存并退出(Ctrl+O, Enter, Ctrl+X)。

检查Nginx配置文件的语法是否有误:

sudo nginx -t

如果显示syntax is oktest is successful,就可以重启Nginx服务了:

sudo systemctl restart nginx

测试PHP环境 在Web根目录/var/www/html下创建一个info.php文件来测试PHP是否正常工作:

sudo nano /var/www/html/info.php

文件内容:

<?php
phpinfo();
?>

保存并退出。现在,在浏览器中访问http://your_domain_or_ip/info.php,如果能看到详细的PHP信息页面,那么恭喜你,PHP环境已经成功部署了!

测试完成后,出于安全考虑,请务必删除info.php文件:

零沫AI工具导航
零沫AI工具导航

零沫AI工具导航-AI导航新标杆,探索全球实用AI工具

下载
sudo rm /var/www/html/info.php

选择合适的PHP版本和Web服务器有什么讲究?

在部署PHP环境时,选择合适的PHP版本和Web服务器确实是个值得深思的问题。这不仅仅是技术偏好,更关乎项目的长期稳定性和性能。

就PHP版本而言,我个人的经验是,优先选择LTS(长期支持)版本。比如,现在PHP 8.x系列是主流,但具体到8.1、8.2还是8.3,我会倾向于选择一个发布时间较长、社区支持成熟的LTS版本。新版本固然有性能提升和新特性,但初期可能会有一些不稳定的bug,或者你使用的某些库和框架还没来得及完全兼容。如果你正在开发一个新项目,可以大胆尝试最新的稳定版;如果是维护现有项目,或者对稳定性要求极高,LTS版本是更稳妥的选择。版本升级本身也是一个需要规划和测试的过程,不是说升就升的。

至于Web服务器,Nginx和Apache是两大巨头,各有千秋。 Nginx:我通常在需要高性能、高并发或作为反向代理时选择它。Nginx以其事件驱动架构著称,处理静态文件非常高效,内存占用也相对较小。它不直接处理PHP,而是通过FastCGI(即PHP-FPM)将请求转发给PHP进程池处理。这种分离架构使得Nginx在处理大量并发连接时表现优异。对于微服务架构或API服务,Nginx也是首选。它的配置相对Apache来说,有时会显得更“极简”一些,但也可能需要一些时间来适应其配置语法。

Apache:如果项目对.htaccess文件有强依赖,或者需要更灵活的模块化扩展(如mod_rewritemod_php等),Apache仍然是一个非常好的选择。Apache的配置方式更直观,社区文档和教程也极其丰富。它既可以通过mod_php直接嵌入PHP解释器,也可以通过mod_proxy_fcgi与PHP-FPM配合使用。虽然在原生高并发处理上Nginx略胜一筹,但对于大多数中小型应用,Apache的性能也完全足够。它的配置灵活性,比如基于目录的权限控制,在某些场景下非常方便。

最终的选择,往往是根据项目的具体需求、团队的技术栈偏好以及预期的流量规模来决定。没有绝对的“最好”,只有“最适合”。我个人在云服务器上,倾向于Nginx + PHP-FPM的组合,因为它在性能和资源利用上确实有优势,尤其是在资源有限的云主机上。

如何确保PHP环境安全稳定运行?

部署好PHP环境只是第一步,确保它安全稳定运行,才是长期运维的关键。这涉及到多个层面,从系统层面到应用层面,都需要我们保持警惕和采取措施。

系统和软件更新: 这是最基础也最重要的一步。操作系统、Nginx、PHP以及数据库(MariaDB/MySQL)都需要定期更新到最新稳定版本。软件漏洞是黑客入侵的常见途径,及时打补丁能有效堵塞这些安全漏洞。我通常会设置自动更新,但关键更新还是会手动确认,以防更新引入新的问题。

最小权限原则:

  • 文件和目录权限: Web服务器(如Nginx)运行的用户(通常是www-data)只需要对Web根目录有读取权限,对需要上传文件或写入日志的目录有写入权限。给所有文件和目录777权限是极其危险的。通常,文件权限设置为644,目录权限设置为755就足够了。
  • PHP-FPM进程用户: 确保PHP-FPM进程也以最小权限用户运行,通常也是www-data。在php-fpm.d/www.conf中,检查usergroup设置。
  • 数据库用户: 不要使用root用户来连接数据库。为每个应用创建专门的数据库用户,并只赋予它所需的最小权限(如SELECT, INSERT, UPDATE, DELETE)。

PHP配置安全: 修改php.ini文件,禁用一些危险函数,并调整错误报告级别:

  • disable_functions:禁用exec, shell_exec, system, passthru, proc_open, popen等可能执行系统命令的函数,除非你的应用确实需要。
  • display_errors = Off:在生产环境中,绝不能直接向用户显示PHP错误信息,这可能会泄露服务器路径、数据库凭据等敏感信息。错误应该记录到日志文件。
  • log_errors = On:确保错误被记录下来,方便调试和监控。
  • expose_php = Off:隐藏PHP版本信息,减少被针对性攻击的风险。
  • upload_max_filesizepost_max_size:限制文件上传大小,防止恶意大文件上传导致服务瘫痪。
  • allow_url_fopen = Offallow_url_include = Off:除非绝对必要,否则禁用远程文件包含,防止远程代码执行漏洞。

防火墙配置: 使用UFW(Uncomplicated Firewall)或iptables只开放必要的端口,如HTTP(80)、HTTPS(443)、SSH(22,最好修改默认端口)等。其他端口一律关闭。

sudo ufw allow 80/tcp
sudo ufw allow 443/tcp
sudo ufw allow 22/tcp # 如果你修改了SSH端口,这里也要相应修改
sudo ufw enable

HTTPS加密: 为你的网站配置SSL/TLS证书(如Let's Encrypt),强制所有流量通过HTTPS传输。这不仅能保护用户数据,也能提升网站在搜索引擎中的排名。

日志监控: 定期检查Nginx、PHP-FPM和系统日志,发现异常行为或错误及时处理。日志是排查问题和发现潜在安全威胁的重要线索。可以考虑使用ELK Stack或类似的日志管理工具进行集中监控。

Web应用防火墙(WAF): 对于重要的生产环境,可以考虑部署WAF来抵御常见的Web攻击,如SQL注入、XSS、CSRF等。ModSecurity是Apache和Nginx都可以使用的开源WAF。

定期备份: 数据无价。定期备份你的代码、数据库和配置文件,并确保备份是可恢复的。这是应对任何灾难性事件的最后一道防线。

稳定和安全是持续性的工作,需要运维人员保持警惕,并根据新的威胁和技术发展不断调整策略。

部署过程中常见的坑和解决思路有哪些?

在云服务器上部署PHP环境,我见过也踩过不少坑。这些坑有些是配置上的疏忽,有些是权限问题,还有些是服务间的协作障碍。提前了解这些,能帮你少走很多弯路。

1. Nginx配置错误导致502 Bad Gateway或404 Not Found:

  • 502 Bad Gateway: 这通常意味着Nginx无法连接到PHP-FPM服务。
    • 原因: PHP-FPM服务未启动,或者Nginx配置文件中的fastcgi_pass指向的socket路径不正确。例如,PHP 7.4的socket可能是/var/run/php/php7.4-fpm.sock,而PHP 8.1则是/var/run/php/php8.1-fpm.sock
    • 解决思路:
      1. 检查PHP-FPM服务状态:sudo systemctl status php*-fpm。如果未运行,尝试启动:sudo systemctl start php*-fpm
      2. 确认fastcgi_pass路径与/etc/php/*/fpm/pool.d/www.conflisten指令的路径一致。
      3. 检查Nginx和PHP-FPM的日志文件(Nginx通常在/var/log/nginx/error.log,PHP-FPM通常在/var/log/php*-fpm.logsyslog)。
  • 404 Not Found: Nginx找不到请求的文件。
    • 原因: root指令指向的Web根目录不正确,或者index指令中没有包含你的入口文件(如index.php)。
    • 解决思路: 检查Nginx配置文件中的root路径是否与你的项目实际路径匹配,并确保index指令包含index.php

2. 权限问题导致文件无法读取或写入:

  • 现象: 网站显示空白页、500错误,或者文件上传失败、日志无法写入。
  • 原因: Web服务器运行用户(www-data)对Web目录或特定文件没有足够的读写权限。
  • 解决思路:
    1. 确认Web根目录及其子目录的文件和目录权限:sudo chown -R www-data:www-data /var/www/html(将/var/www/html替换为你的Web根目录)。
    2. 递归设置目录权限为755,文件权限为644sudo find /var/www/html -type d -exec chmod 755 {} \;sudo find /var/www/html -type f -exec chmod 644 {} \;
    3. 对于需要写入的目录(如缓存、上传目录),可能需要775777(但777要慎用,仅在万不得已且明确风险的情况下使用)。

3. PHP内存或执行时间限制:

  • 现象: 脚本执行到一半突然报错,或者上传大文件失败。
  • 原因: php.inimemory_limit(内存限制)或max_execution_time(最大执行时间)设置过小。
  • 解决思路: 编辑php.ini文件(通常在/etc/php/*/fpm/php.ini),根据你的应用需求调整这两个值。例如,memory_limit = 256Mmax_execution_time = 300。修改后记得重启PHP-FPM服务。

4. 数据库连接问题:

  • 现象: PHP应用无法连接数据库,报错如“Access denied for user...”或“Unknown database...”。
  • 原因: 数据库用户名、密码、主机地址或数据库名配置错误;数据库服务未运行;防火墙阻止了数据库端口(默认为3306)。
  • 解决思路:
    1. 检查应用配置文件中的数据库连接信息是否正确。
    2. 检查MariaDB/MySQL服务状态:sudo systemctl status mariadb
    3. 确认数据库用户是否有权限从localhost(或应用服务器IP)连接到数据库。必要时,在MySQL命令行中授权:GRANT ALL PRIVILEGES ON your_database.* TO 'your_user'@'localhost' IDENTIFIED BY 'your_password'; FLUSH PRIVILEGES;
    4. 检查防火墙是否开放了3306端口(如果数据库和Web服务器不在同一台机器上)。

5. 缓存问题:

  • 现象: 修改了代码或配置,但网站内容没有更新。
  • 原因: Nginx或PHP-FPM的缓存,或者应用本身的缓存机制。
  • 解决思路:
    1. 清除Nginx缓存(如果配置了)。
    2. 重启PHP-FPM:sudo systemctl restart php*-fpm
    3. 清除应用本身的缓存(如Laravel的php artisan cache:clear,WordPress的缓存插件等)。

这些都是部署过程中比较常见的“拦路虎”,但只要保持冷静,善用日志文件,一步步排查,总能找到问题的症结并解决。解决问题的过程,也是对系统理解加深的过程。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

340

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

293

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

773

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

385

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

141

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

85

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

80

2025.08.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

529

2026.03.04

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

1

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 850人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号