zoukankan      html  css  js  c++  java
  • (转)linux sudo 重定向,实现只有系统管理员才有权限操作的文件中写入信息

    众所周知,使用 echo 并配合命令重定向是实现向文件中写入信息的快捷方式。
    本文介绍如何将 echo 命令与 sudo 命令配合使用,实现向那些只有系统管理员才有权限操作的文件中写入信息。
     
    比如要向 test.asc 文件中随便写入点内容,可以:
    $ echo "信息" > test.asc
    # 或者
    $ echo "信息" >> test.asc
    下面,如果将 test.asc 权限设置为只有 root 用户才有权限进行写操作:
     
    $ sudo chown root.root test.asc
    然后,我们使用 sudo 并配合 echo 命令再次向修改权限之后的 test.asc 文件中写入信息: 
     
    $ sudo echo "又一行信息" >> test.asc
    -bash: test.asc: Permission denied
    这时,可以看到 bash 拒绝这么做,说是权限不够。这是因为重定向符号 ">" 和 ">>" 也是 bash 的命令。我们使用 sudo 只是让 echo 命令具有了 root 权限,但是没有让 “>” 和 ">>" 命令也具有 root 权限,所以 bash 会认为这两个命令都没有向 test.asc 文件写入信息的权限。
     
    解决这一问题的途径有两种。第一种是利用 "sh -c" 命令,它可以让 bash 将一个字串作为完整的命令来执行,这样就可以将 sudo 的影响范围扩展到整条命令。具体用法如下: 
     
    sudo sh -c "echo '又一行信息' >> test.asc"
    这样sudo执行的是一个shell,在具有root权限的shell中执行前面的命令,就不会再出现权限问题了。
    另一种方法是利用管道和 tee 命令,该命令可以从标准输入中读入信息并将其写入标准输出或文件中,具体用法如下:
     
    $ echo "第三条信息" | sudo tee -a test.asc
    注意,tee 命令的 "-a" 选项的作用等同于 ">>" 命令,如果去除该选项,那么 tee 命令的作用就等同于 ">" 命令。
  • 相关阅读:
    学习linux之用户-文件-权限操作
    Hadoop--Hadoop的机架感知
    redhat 6.3 64位安装中文输入法全过程记录
    hdu 4619 Warm up 2(并查集)
    openGL 初试 绘制三角形 和添加鼠标键盘事件
    MySQL 启动服务报错解决方案
    20亿与20亿表关联优化方法(超级大表与超级大表join优化方法)
    50行python代码实现个代理server(你懂的)
    nginx+tomcat反复请求
    慢慢过渡到个人博客
  • 原文地址:https://www.cnblogs.com/goyier/p/7497528.html
Copyright © 2011-2022 走看看