服务器nginx权限被拒绝解决案例


Posted in Servers onSeptember 23, 2022

主题

现在服务器资产多种多样,习惯了阿里云的保姆式配置,其他私有云的装机配置各有各的风格,今天聊聊nginx突发状况,权限被拒绝的问题相关排查过程及解决办法。

经过

本来以为是个相当愉快的过程,上一篇说明了服务器安全原因,相关网络环境的排查,这次继续说一说关于nginx代理遇到的问题 先说说表象,原本的服务器已经预装了nginx找到相关配置进行设置以后,还是无法访问

ps -aux | grep nginx  //查看nginx进程情况
netstat -anp | grep :80 //查看相关端口已正常启动

在确定相关nginx已经启动的情况下,发现代理的网站无法访问,接口相关的500可以正常返回

curl 127.0.0.1:80/web //验证访问内容
/var/log/nginx/      //查看相关日志信息

或者用一下命令查看

systemctl status nginx.service -l

经过对错误日志的排查发现访问网站静态网页时,相关异常为 'Permission denied',这种情况查了很多资料,

最终解决办法

chcon命令是修改对象(文件)的安全上下文,比如:用户、角色、类型、安全级别。也就是将每个文件的安全环境变更至指定环境。

SeLinux概念作用

系统开启了SeLinux,受到了SeLinux的限制 先说说SeLinux的概念和作用

selinux(Security-Enhanced Linux)安全增强型linux,是一个Linux内核模块,也是Linux的一个安全子系统。

三种模式

Enforcing:强制模式,在selinux运作时,已经开始限制domain/type。

permissive: 警告模式,在selinux运作时,会有警告讯息,但不会限制domain/type的存取。

disabled: 关闭模式。

可用getenforce查看selinux状态

selinux对文件的作用:

当开启selinux后,selinux会给每个文件加载标签context,安全上下文必须配对,否则文件不能访问 查看下selinux策略配置(找到能生效的文件夹和当前发布的文件夹权限区别,进行相关的设置)

ls -lrtZ /usr/share/nginx/html
chcon -R -t httpd_sys_content_t  /home/xx/
 nginx -s reload

最终解决了相关问题,以下是进行的一些无效尝试,可能某些服务器环境可以生效

无效尝试

  • 发布文件夹授权的尝试
sudo chmod o+x /home/xxx/
  • 关于nginx配置文件/etc/nginx/nginx.conf,指定用户的尝试,依然无效
user nginx; ->更改为 user root
nginx -s reload
  • 其他比较粗暴一点儿的教程要么直接关闭或临时性解决
setenforce 0 ##设置SELinux 成为permissive模式
 #setenforce 1 ##设置SELinux 成为enforcing模式

永久生效 修改/etc/selinux/config文件,将SELINUX=enforcing改为SELINUX=disabled,重启机器 没敢关闭这个安全策略

总结

、我这种吸引bug的体质,不配顺顺利利完成任务、服务器的问题在最开始上班时,windows环境下经常最头疼的就是服务器环境的预装上线,常常因为这个问题搞到1点多,但那会羁绊少,怀着学习和对事儿的认真,再加上一块和组员和领导搓一顿,幸福感满满。

其后也带过很多人,合作过许多人、形形色色的,慢慢的发现越往后入行的很多人害怕环境部署,害怕出问题,所以拒绝去尝试部署。动辄就是 "福报""PUA" 防身,非是站在道德制高点去指摘,很多事情过犹不及,盲目的随大流去指摘,人生活和工作都是在为自己负责,尽最大的努力,做最好的自己、莫作“总有刁民想要害朕”的心态太久,实在不行,换个环境解放局限性。

linux环境之前一直浅用,之后算是有较多的涉足,沉淀下来的相关内容也会经常去完善补充,部署参考,工作久了很多对自身来说困难的事情,是没办法绕过去或者退缩的,一往无前吧、永远的少年

以上就是服务器nginx权限被拒绝解决案例的详细内容,更多关于nginx服务器权限拒绝的资料请关注三水点靠木其它相关文章!

Servers 相关文章推荐
Nginx tp3.2.3 404问题解决方案
Mar 31 Servers
nginx proxy_cache 缓存配置详解
Mar 31 Servers
如何利用map实现Nginx允许多个域名跨域
Mar 31 Servers
Nginx进程管理和重载原理详解
Apr 22 Servers
Nginx配置https的实现
Nov 27 Servers
tomcat的catalina.out日志按自定义时间格式进行分割的操作方法
Apr 02 Servers
Tomcat执行startup.bat出现闪退的原因及解决办法
Apr 20 Servers
Windows server 2012 R2 安装IIS服务器
Apr 29 Servers
Nginx 常用配置
May 15 Servers
Python安装及建立虚拟环境的完整步骤
Jun 25 Servers
本地搭建minio文件服务器(使用bat脚本启动)的方法
Jul 15 Servers
win10搭建配置ftp服务器的方法
Aug 05 Servers
Fluentd搭建日志收集服务
Sep 23 #Servers
Flink 侧流输出源码示例解析
Sep 23 #Servers
修改Nginx配置返回指定content-type的方法
Sep 23 #Servers
Nginx如何配置多个服务域名解析共用80端口详解
Sep 23 #Servers
VMware虚拟机安装 Windows Server 2022的详细图文教程
zabbix如何添加监控主机和自定义监控项
Aug 14 #Servers
教你使用RustDesk 搭建一个自己的远程桌面中继服务器
Aug 14 #Servers
You might like
PHP字符转义相关函数小结(php下的转义字符串)
2007/04/12 PHP
PHP编实现程动态图像的创建代码
2008/09/28 PHP
smarty模板引擎中自定义函数的方法
2015/01/22 PHP
ThinkPHP中Common/common.php文件常用函数功能分析
2016/05/20 PHP
php读取XML的常见方法实例总结
2017/04/25 PHP
JavaScript对象模型-执行模型
2008/04/28 Javascript
Javascript 判断函数类型完美解决方案
2009/09/02 Javascript
AJAX的跨域与JSONP(为文章自动添加短址的功能)
2010/01/17 Javascript
ExtJS4利根据登录后不同的角色分配不同的树形菜单
2014/05/02 Javascript
解决iView中时间控件选择的时间总是少一天的问题
2018/03/15 Javascript
JS实现灯泡开关特效
2020/03/30 Javascript
浅谈Vue2.4.0 $attrs与inheritAttrs的具体使用
2020/03/08 Javascript
微信小程序分享小程序码的生成(带参数)以及参数的获取
2020/03/25 Javascript
请求时token过期自动刷新token操作
2020/09/11 Javascript
js简单粗暴的发布订阅示例代码
2021/01/23 Javascript
Python中捕捉详细异常信息的代码示例
2014/09/18 Python
Python的Django框架中模板碎片缓存简介
2015/07/24 Python
python 实时得到cpu和内存的使用情况方法
2018/06/11 Python
PyCharm的设置方法和第一个Python程序的建立
2019/01/16 Python
使用pytorch实现可视化中间层的结果
2019/12/30 Python
Anaconda+vscode+pytorch环境搭建过程详解
2020/05/25 Python
Python StringIO及BytesIO包使用方法解析
2020/06/15 Python
Python库安装速度过慢解决方案
2020/07/14 Python
Python中生成ndarray实例讲解
2021/02/22 Python
美国正版电视节目和电影在线观看:Hulu
2018/05/24 全球购物
上海天奕面试题笔试题
2015/04/19 面试题
数控技术应届生求职信
2013/11/13 职场文书
财务会计专业推荐信
2013/11/30 职场文书
物流管理毕业生自荐信范文
2014/03/15 职场文书
《花木兰》教学反思
2014/04/09 职场文书
爱岗敬业演讲稿
2014/05/05 职场文书
敬老模范事迹
2014/05/21 职场文书
八项规定自查自纠报告及整改措施
2014/10/26 职场文书
2014年计生工作总结
2014/11/21 职场文书
2015年教师党员自我评价材料
2015/03/04 职场文书
nginx的zabbix 5.0安装部署的方法步骤
2021/07/16 Servers