ubuntu通过nginx部署fastcgi程序
ubuntu安装nginx
// 更新包 sudo apt-get update // 下载安装nginx sudo apt-get install nginx
测试安装sudo nginx -t
卸载nginx
sudo apt-get --purge remove nginx
nginx的操作命令如下:
service nginx start service nginx stop service nginx restart
配置nginx
最新版本nginx配置是由4个文件构成:
-
conf.d
:用户自己定义的conf配置文件 -
sites-available
:系统默认设置的配置文件 -
sites-enabled
:由sites-available
中的配置文件转换生成 -
nginx.conf
:汇总以上三个配置文件的内容,同时配置我们所需要的参数
在部署需要的web服务时,我们可以拷贝sites-enabled
中的default
文件到conf.d并且修改名字为**.conf
,然后进行配置
server { #服务启动时监听的端口 listen 80 default_server; listen [::]:80 default_server; #服务启动时文件加载的路径 root /var/www/html/wordpress; #默认加载的第一个文件 index index.php index.html index.htm index.nginx-debian.html; #页面访问域名,如果没有域名也可以填写_ server_name www.xiexianbo.xin; location / { #页面加载失败后所跳转的页面 try_files $uri $uri/ =404; } #以下配置只服务于php # 将PHP脚本传递给在127.0.0.1:9000上监听的FastCGI服务器 location ~ \.php$ { include snippets/fastcgi-php.conf; # With php7.0-cgi alone: #fastcgi_pass 127.0.0.1:9000; # With php7.0-fpm: fastcgi_pass unix:/run/php/php7.0-fpm.sock; } # 如果Apache的文档为root,则拒绝访问.htaccess文件 location ~ /\.ht { deny all; } }
注意事项:
- apache的端口也是80,所以我们可以选择关闭apache或者,在这里更换端口,例如81,82等,但是我们需要吧这个端口开放出来
-
React、Vue等由于是单页面应用,所以我们在刷新的会遇到资源加载不到的错误,这时我们需要把页面重定向到index.html
try_files $uri /index.html;
- 每次配置完成后,都需要重启nginx。
配置nginx支持fastcgi
开发fastcgi程序并将编译成功的fastcgi程序复制到工作目录(随意)
mkdir /usr/share/nginx/cgi-bin
cp upload /usr/share/nginx/cgi-bin
安装spawn-fcgi
sudo apt-get install spawn-fcgi
安装完成之后, spawn-fcgi的目录为 /usr/bin/spawn-fcgi
启动spawn-fcgi
/usr/bin/spawn-fcgi -a 127.0.0.1 -p 9002 -C 25 -f /usr/share/nginx/cgi-bin/upload
更改Nginx配置
sudo vim /etc/nginx/sites-available/default
添加以下内容
location ~ \.cgi$ {
fastcgi_pass 127.0.0.1:9002;
fastcgi_index index.cgi;
fastcgi_param SCRIPT_FILENAME fcgi$fastcgi_script_name;
include fastcgi_params;
}
重启Nginx
sudo service nginx restart
测试
在浏览器输入以下网址http://{ip}/{fcgi程序名}