标签:cgi index fcgi sudo nginx ubuntu fastcgi
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程序名}
标签:cgi,index,fcgi,sudo,nginx,ubuntu,fastcgi 来源: https://www.cnblogs.com/hnxxcxg/p/15086238.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。