Linux /tmp目录下执行脚本失败提示Permission denied

https://www.cnblogs.com/linyfeng/p/11087655.html

国产化的环境上 就有一个 data 目录 提示没有 权限  解决oracle问题时  顺便扫了一眼 原作者的blog 发现有这个问题..

非常感谢. 

我这边的原始的fstab 的文件信息

# /etc/fstab: static file system information.
#
# Use 'blkid' to print the universally unique identifier for a
# device; this may be used with UUID= as a more robust way to name devices
# that works even ).
#
# <file system> <mount point>   <type>  <options>       <dump>  <pass>
# / was on /dev/sda2 during installation
UUID=262956d8-d76b-412a-bcac-d96294f67a87 /               ext4    errors=remount-ro
# /boot was on /dev/sda1 during installation
UUID=fd46c1aa-9cb8-4ea4-8a90-54285c194b63 /boot           ext4    defaults
# /data was on /dev/sda5 during installation
UUID=ca54de8a--4a33--780a36c20b07 /data           ext4    rw,user,x-gvfs-show,nosuid,nofail
# swap was on /dev/sda6 during installation
UUID=637aab78-5eeb--8d9b-c50128f2f166 none            swap    sw                     

Linux上执行Shell脚本运行失败提示Permission denied一个问题,挺好的问题,切中了知识盲点。

问题现象

Shell脚本在/tmp目录下,执行./test.sh运行失败,提示Permission denied。

问题分析

1、检查ls -al test.sh脚本是否有可执行权限。权限为777。看来套路不行啊。。以前通常90%都是这个原因引起的。

2、尝试使用sh test.sh运行,可以执行。为啥。。

3、是/tmp目录没有执行权限?执行stat / 和stat /tmp发现权限都满足。。有点慌。。解决不了了。下图stat命令执行结果供参考。

4、借助搜索。发现是/tmp文件系统的属性被设置了noexec。noexec表示对应文件系统不允许执行可执行程序,即使文件具有可执行过权限。通常是考虑安全原因会这么设置。

问题解决

1、将脚本放到其他不具有noexec文件系统目录执行或者使用sh test.sh运行。

2、如果可以将/tmp文件系统中noexec属性去掉,可以使用如下操作步骤(说明:仅限测试环境操作)

(1)在/etc/fstab文件中将/tmp文件系统的noexec属性删掉。

(2)重新挂载/tmp文件系统。执行umount /tmp; mount /tmp将/tmp文件重新挂载。

知识拓展

这里主要是因为不了解文件系统挂载参数的约束导致问题无法及时解决。学习下/etc/fstab文件及挂载参数内容。

/etc/fstab文件内容总共包含6列。

第一列:Device:磁盘设备文件或者该设备的Label、UUID

第二列:Mount point:设备的挂载点,就是你要挂载到哪个目录下。

第三列:filesystem:磁盘文件系统的格式,包括ext2、ext3、reiserfs、nfs、vfat等。可以使用df -T查看

第四列:parameters:文件系统的参数

Async/sync 设置是否为同步方式运行,默认为async(性能较佳)

auto/noauto  当执行mount -a 的命令时,此文件系统是否被主动挂载。默认为auto

rw/ro   是否以只读或者读写模式挂载

exec/noexec   限制此文件系统内是否能够运行可执行文件。

user/nouser是否允许用户使用mount命令挂载

suid/nosuid 是否允许SUID的存在

Usrquota 启动文件系统支持磁盘配额模式。这个涉及到磁盘配额的知识。有兴趣可以扩展看看

Grpquota 启动文件系统对群组磁盘配额模式的支持

Defaults  同时具有rw,suid,dev,exec,auto,nouser,async等参数。基本上,默认使用Defaults设置即可。

第五列:能否被dump备份命令作用:dump是一个用来作为备份的命令。通常值为0或者1。测试环境很少用。

第六列:是否检验扇区:开机的过程中,系统默认会以fsck检验我们系统是否为完整(clean)。一般来说,根目录设置为1,其他的文件系统设置为2。以前经常会在IBM的AIX系统遇到该问题。

总结

看了这个案例,相信如果你以后再遇到Shell脚本运行失败提示Permission denied的问题,解决它的概率就比别人大很多了。。

最新文章

  1. APP开发:一个APP开发需要哪些技术人员?
  2. UIkit框架之UIwebview
  3. server application error应用错误
  4. Spring container vs SpringMVC container(webmvc container)
  5. pro10
  6. PAT 解题报告 1010. Radix (25)
  7. Mysql时间戳函数
  8. UML类图关系大全-转
  9. PagerSlidingTabStrip 高亮选中标题
  10. eclipse提交本地项目到github
  11. XML.ObjTree -- XML source code from/to JavaScript object like E4X
  12. AWS要进入中国了
  13. 第19讲 不带参数功能FC的编程与应用
  14. android自定义View-继承
  15. 磊哥测评之数据库SaaS篇:腾讯云控制台、DMC和小程序
  16. CCF CSP 201712-1 最小差值
  17. 云服务器搭建在线ssh终端GateOne
  18. Redis无法启动
  19. CentOS6.8单用户模式下修改密码
  20. CruiseControl 安装配置

热门文章

  1. BZOJ 5418: [Noi2018]屠龙勇士 EXCRT+multiset
  2. HGOI 20190830 题解
  3. k8s集群节点更换ip 或者 k8s集群添加新节点
  4. Java当中的集合框架
  5. 搭建Kubernetes的web管理界面
  6. centos调整屏幕亮度
  7. 当 springboot 部署war包,tomcat报一堆无法解决的问题时
  8. TCP输入 之 tcp_v4_rcv
  9. Fastadmin 写关联命名时,最好前后台用同一个model,方便管理(会出现命名空间问题)
  10. 《视觉SLAM十四讲》第2讲