Unix中不小心就会做错的事情

发表于:2012-7-12 10:07

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:kkdelta    来源:51Testing软件测试网采编

  1、rm命令不会等待你做确认就会把文件删掉,所以最好在rm之前都仔细思考,尤其是rm 带正则表达式的删除,如rm t*,最好是ls t*先看一下。

  最恐怖的事情是你不小心在t和*中间不小心留下了空格, rm t *,结果是把所有的文件删除了。

  rm -i 会给你一次确认的机会。

  2、cat file1,file2,file3 >file1,file1的文件会丢失。

  3、用WinSCP客户端连接到unix时候,如果磁盘空间不够用了,而你正好打开了一个文件编辑,再保存,这个被编辑的文件会被存为0字节。(应该是WinSCP的一个bug,直接用vi编辑保存会提示不能保存)

  4、不是用户有访问文件的权限就一定能对该文件进行访问,还受到该文件所在目录的限制,先讲一下目录的访问权限:目录的权限位和文件有所不同,目录的读权限位意味着可以列出其中的内容(不能ls),写权限位意味着可以在该目录中创建文件,执行权限位则意味着搜索和访问该目录(cd)。如果要使目录的w权限起作用,目录必须同时有x权限。

  假设dir下有一个文件file,某用户对file的文件的权限为rwx,而dir为--x,那么用户可以通过路径的方式  ...../dir/file执行该file文件,通过vi编辑该文件,因为该目录是可以访问的。

  但是该用户cd该目录后不能ls。

  假设dir下有一个文件file,某用户对file的文件的权限为rwx,而dir为rw-,那么该用户无法通过路径的方式  ...../dir/file执行该file文件,无法通过vi编辑该文件,因为该目录是不可以访问的(无法cd进入该目录)。同时也不能在该目录下建立新文件,虽然看起来已经有w的权限。

  如果某个用户对文件夹/AA/BB/CC 有rwx的权限,如果想正常操作CC文件夹,对AA和BB都必须有x权限。

  所以目录对组合其他用户一般都设为r-x。

  对于文件来说,如果要想一个文件的x权限起作用,同时必须有r权限。

  对于目录设w权限给别的用户的危险性:在用户Locke拥有的目录.../treaties下有一个文件叫twotreatiesOnGrv,然后Locke给这个文件限制为别的用户不能写,但是别的用户对treaties目录却有写权限,那么别人,比如说,Plato还能不能写twotreatiesOnGrv这个文件呢,答案是,不能但又能,Plato不能直接,比如vi来改这个文件(但是w! twotreatiesOnGrv 也可以覆盖这个文件),但是他可以通过mv 将一个别的文件到treaties目录下覆盖这个twotreatiesOnGrv。

  对于没有写权限的文件同时,如果对所在目录有写权限,也可以被删除。

  5、文件在创建的时候是没有x权限的(就算umask 是000),要用chmod来改变权限。

  6、通过mv aa bb将aa文件改为bb,不巧的是如果在当前目录下有一个bb目录,结果就会是将aa移动到了bb目录下,而不是改名。

  7、bash 中,写在if 中的 [ condition ]要注意在[后,和 ]前都要留一个空格。

  if [ "$1" = "ok " ]; then

  echo "\$1 is ok,evaluated as true"

  else

  echo "\$1 is $1,evaluated as false"

  fi

  8、bash中的until循环是在条件为false的时候执行loop,在条件为true时停止。

《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号