sudo apt updatesudo apt install nginx
验证结果,使用命令:
sudo systemctl status nginx
若有结果如下则说明成功:
但注意,此时只是在服务器上配置好了nginx,执行nginx -v
应当可以看到版本号。此外,如果对nginx更新了配置,如增加了PHP解释,则应当重启nginx服务器:
【资料图】
sudo systemctl restart nginx
1.2但是从外界还是无法访问,所以我们还需要配置防火墙,使用UFW防火墙管理工具可以轻松完成:
安装UFW:
sudo apt-get install ufw -y
启动UFW服务:
sudo ufw enable
(或者相反的,也可以关闭/重置防火墙,下面命令不在安装流程内,不要执行)
sudo ufw disablesudo ufw reset
!注意:一定要先开启ssh端口的开放,不然下次连接就G了!!!连不上了!!!
sudo ufw allow 22
启动服务后,需要配置防火墙,使得局域网内其他IP地址可以访问服务器的 HTTP(80
)和 HTTPS(443
)端口
sudo ufw allow "Nginx Full"
验证状态:
sudo ufw status
成功则会如下所示:
测试连通性:
在本地浏览器输入服务器IP地址,默认使用http端口,即可访问nginx默认界面:
2. 安装PHP:PHP是服务端经常使用的编程语言,命令只需一行:
sudo apt install php-fpm
一旦安装完成,FPM 服务将会自动启动。想要检查服务状态,运行(这里安装的是7.4版本,可以使用命令php -v
查看,将7.4改成实际安装版本即可):
sudo systemctl status php7.4-fpm
还可以安装mysql扩展,以便使得PHP可以做数据库相关操作:
sudo apt install php-mysql
安装后也需要重启PHP-FPM服务,以确保新更新被运行:
sudo systemctl restart php7.4-fpm
3. Nginx的相关配置3.1创建文件:sudo vim /etc/nginx/php-fpm74.conf
,写入如下内容:
location ~ .*\.php$ { fastcgi_pass 127.0.0.1:9004; fastcgi_param PHP_SELF $uri; fastcgi_param SERVER_NAME $host; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_index index.php; include fastcgi_params; include php_cgi.conf;}
fastcgi_pass 127.0.0.1:9004代表要将信息通过9004端口传递给php-fpm处理,2~6行都是定义的变量,7,8行是include的两个文件。
3.2创建文件:sudo vim /etc/nginx/php_cgi.conf
,写入如下内容:
fastcgi_connect_timeout 300s;fastcgi_send_timeout 300s;fastcgi_read_timeout 300s;fastcgi_buffer_size 128k;fastcgi_buffers 8 128k;fastcgi_busy_buffers_size 256k;fastcgi_temp_file_write_size 256k;fastcgi_intercept_errors on;
3.3创建文件:sudo vim /etc/nginx/conf.d/www.conf
,写入如下内容:
server { server_name 210.45.124.82; index index.php; root /opt/www; include php-fpm74.conf;}
进入/opt目录,新建www目录,这个目录就是默认网站的页面所在的目录了:
cd /optsudo mkdir www
4. php-fpm的相关配置创建文件:sudo vim /etc/php-fpm.d/www.conf
,(注意这个地方写的位置需要自己注意一下,我的安装位置是/etc/php/7.4/fpm,里面有这样四个文件或目录:conf.d php-fpm.conf php.ini pool.d,php-fpm.conf即主配置文件,其中有一句这样的语句:include=/etc/php/7.4/fpm/pool.d/*.conf
,意思是导入以conf结尾的文件配置,所以我的文件位置在这个地方/etc/php/7.4/fpm/pool.d/www.conf
),写入如下内容:
[global]pid = run/php-fpm.piderror_log = log/error.log[www]listen = 127.0.0.1:9004user = www-datagroup = www-datapm = staticpm.max_children = 5rlimit_files = 20000request_terminate_timeout = 10pm.max_requests = 20000
user,group也需要自定义化,打开文件/etc/nginx/nginx.conf
,看第一行user www-data
,需与此值相同。
sudo systemctl restart nginx php7.4-fpm
也可以将两个服务加入开机服务(disable取消):
sudo systemctl enable nginx php7.4-fpm
6. 测试文件回到/opt/www目录,创建文件:sudo vim info.php
然后在浏览器输入:ServerIP/info.php即可看到
7.可能错误排查查看错误日志
// nginxtail /var/log/nginx/error.log// phpsystemctl status php7.4-fpm.service
错误1:403,无文件或者权限不足无文件问题根据3.3节设置的index去看对应的文件夹是否有文件权限不足问题,则需要文件所有者账户将index的对应文件夹提权:sudo chmod R 777 /opt/www错误2:503 gateway error,一般是php-fpm配置出错,需注意配置文件不要写错位置(要自己找安装位置,一般在/etc或者/usr/local/etc中并且要从主配置文件顺藤摸瓜,找到include的文件位置,并在相应位置创建),另外配置listen端口一定需与nginx的pass端口相同。