nginx proxy server localhost permission denied

2019-01-22 14:25发布

I am just setting up nginx as a webserver that proxies directly to a tomcat app server. When the user connects to my website Nginx should redirect the request to port 8080 where the tomcat app server is running.

I am doing everything on amazon ec2 instance that is running Redhat 7.

What I have so far is this:

nginx.conf file

user nginx;
worker_processes  1;

server {
 listen 80;
 server_name mydomainname;
 access_log  /var/log/nginx/example.log;
 error_log /var/log/nginx/example.error.log;

 location / {
  proxy_pass http://localhost:8080/example/;
 }
}

The error that I am getting is (13: Permission denied) while connecting to upstream, client

This is definitely a user access issue, but cannot seem to figure it out. It seems like nginx does not have access to redirect to port 8080.

Also, nginx is running under myuser

root     15736   nginx: master process   /usr/sbin/nginx
myuser  15996   nginx: worker process
root     16017   grep --color=auto nginx

I have tried to put 127.0.0.1 instead of localhost, but no luck. I have also tried to change the user in the nginx.conf to myuser, still no luck. When I connect directly to the application sever I have no issues.

Example URL of my tomcat http://mydomain:8080/example/

Thank you in advance.

2条回答
干净又极端
2楼-- · 2019-01-22 14:51

you can move to see this issue: stackoverflow questions 23443398

Basically it's the problem of the permission for socket:

Set permissions for unix socket, if one is used. In Linux, read/write permissions must be set in order to allow connections from a web server...

查看更多
来,给爷笑一个
3楼-- · 2019-01-22 14:58

I was able to find a solution after 2 days of searching. Somehow SELinux was not permitting Nginx to proxy to my server. Running the command below fixed the issue.

 /usr/sbin/setsebool httpd_can_network_connect true 
查看更多
登录 后发表回答