为nginx+php环境,增加部署tomcat时,因用户名不同导致的403错误及解决办法。

Nginx+Php+Mysql 是已经部署好并且正常运行的环境。

因为项目需要,要在服务器中部署tomcat,以便运行java工程。

首先,按照相关教程,安装、配置好了tomcat。

然后,在nginx中为部署好的tomcat配置了反向代理。

server {  
          
    listen 443;  
    server_name www.yourdomainname.com;  
    root /opt/tomcat/webapps/ROOT;
    ssl on;
    ssl_certificate cert/214792069390773.pem;
    ssl_certificate_key cert/214792069390773.key;
    ssl_session_timeout 5m;
    ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
    ssl_prefer_server_ciphers on;
        
    location / {     
        proxy_pass http://127.0.0.1:8080;  
        proxy_redirect off;  
        proxy_set_header Host $host;  
        proxy_set_header X-Real-IP $remote_addr;  
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
        client_max_body_size 10m;  
        client_body_buffer_size 128k;  
        proxy_connect_timeout 90;  
        proxy_send_timeout 90;  
        proxy_read_timeout 90;  
        proxy_buffer_size 4k;  
        proxy_buffers 4 32k;  
        proxy_busy_buffers_size 64k;  
        proxy_temp_file_write_size 64k; 
    }  

    access_log  /home/wwwlogs/access_tomcat.log;
}   

这里因为要使用https,所以监听了443端口,并且配置了ssl,注意所使用的证书要和域名匹配。

 

接下来,本以为大功告成,却在访问tomcat默认页面的时候,出现了403错误。

检查配置文件,发现是因为nginx默认的用户名与tomcat布置时使用的用户名不同,所以nginx没有相应目录/文件的访问权限。

 

解决这个问题,需要两个步骤,

  1. 将tomcat相关的目录/文件的所有者,更改为nginx.conf中配置的用户,一般是www-data或者www
  2. 将安装tomcat时,添加的tomcat.service服务文件中的用户名与组,更改为nginx的www-data或者www。

我就是因为忽视了上面的第二步,不得不跟404错误纠缠了2个难眠的夜晚。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值