server - Nginx配置webapp问题
问题描述
新手自学,nginx在AWS部署。在服务器正常安装nginx无问题顺利打开欢迎页Welcome to Nginx!
然后创建nginx配置文件,软连接到/etc/nginx/sites-enabled/,检查软链正确,通过nginx自带检查配置文件命令显示语法等也显示正确
server { listen 80; server_name xxxxx;location / {proxy_pass http://localhost:8000; }}
删除掉/etc/nginx/sites-enabled/里面的default,重启nginx服务启动python django的webapp,无报错,运行在127.0.0.1:8000上
然而最后结果是:“无法连接”。后看过nginx的doc里面的example,看不出问题所在。目前认为问题应该出在配置nginx方面,因为我一旦删掉我自己的配置文件,恢复default,重启nginx就能够恢复到欢迎页。而webapp多次测试路径也经过校正不存在问题。请求解决办法,谢谢!

新的代码为:
server { listen 80; server_name xxxxx;location / {root ~/sites/source #网站根目录index index.htmlproxy_pass http://localhost:8000; }}
或把root和index放到location上面,见下图
运行时端口依然被占:
后proxy_pass改为转发5000端口,正常运作,但网页依然无法打开
问题解答
回答1:应该是你没有指定document_root和index。
回答2:问题解决
因为问题肯定出现在配置上,而apt-get的方法安装nginx造成无法自定义编译很难查清楚所在,nginx不支持添加模块,只能在编译时进行。故apt-get也没有日志可看。所以重新下载nginx-1.10.1编译安装,编译包模块选择最基本的http模块方便调试起见再加debug模块,证实,最后最简方案为编译到--prefix=/usr/local下完成安装,直接修改总的配置文件为(无需uwsgi和root等):
http{ server {listen 80;server_name xxxxx; location / { proxy_pass http://localhost:8000;} }}
另加上默认的events就可以通过最基本的配置文件验证,其他全部注释掉,也无需再去删除默认的配置文件,reload重启,并顺利运行。

相关文章:
1. html5 - 图片一般一怎么的形式存放在服务器中的?2. node.js - mongodb查找子对象的名称为某个值的对象的方法3. 网页爬虫 - python 爬取网站 并解析非json内容4. vue.js - vue-router开启HTML5的history模式后nginx配置5. 百度地图api - Android 百度地图 集成了定位,导航 相互的jar包有冲突?6. python - flask post提交timestamp不能作为参数,这是为什么?7. javascript - 如何获取未来元素的父元素在页面中所有相同元素中是第几个?8. java - 如何点击按钮,重新运行(我是初学者)?9. node.js - express框架,设置浏览器从缓存中读取静态文件,只有js从缓存中读取了,css还有一些图片为何没有从缓存中读取?10. 使用list和each配合,的作业,输出一行后,如何换行

网公网安备