• 避免’sudo echo x >’ 时’Permission denied’


    sudo echo permission denied

    Q:

    $ sudo echo 'some' > test
    -bash: test: Permission denied

    A:

    $ sudo sh -c "echo 'some' > test"

    Or

    $ echo 'some' | sudo tee [-a] test

    tee -a = append

    --------------------------------------------------------------------

    避免’sudo echo x >’ 时’Permission denied’

    避免’sudo echo x >’ 时’Permission denied’

    甲: 示例
    sudo echo a > 1.txt
    -bash: 1.txt: Permission denied
    乙: 分析:
    bash 拒绝这么做,说是权限不够.
    这是因为重定向符号 “>” 也是 bash 的命令。sudo 只是让 echo 命令具有了 root 权限,
    但是没有让 “>” 命令也具有root 权限,所以 bash 会认为这个命令没有写入信息的权限。
    丙: 解决办法。三种:
    1. 利用 “sh -c” 命令,它可以让 bash 将一个字串作为完整的命令来执行,这样就可以将 sudo 的影响范围扩展到整条命令。
    具体用法如下:

    sudo sh -c "echo a > 1.txt"

    利用bash -c 也是一样的,现在bash shell 流行。


    2.  利用管道和 tee 命令,该命令可以从标准输入中读入信息并将其写入标准输出或文件中,
    具体用法如下:
    echo a |sudo tee 1.txt

    echo a |sudo tee -a 1.txt   // -a 是追加的意思,等同于 >>

    tee 命令很好用,它从管道接受信息,一边向屏幕输出,一边向文件写入。

    linux 总是有一些小工具为我们考虑的很贴切!


    3. 提升shell 权限。
    sudo -s        //提到root 权限。提示符为#
    当你觉得该退回到普通权限时,
    sudo su username //退回到username 权限,提示符为$

    exit 退出当前用户,回到上一层目录.

    centos 提升权限: su  -

    ubuntu 提升权限: sudu -s, sudo su

    https://www.cnblogs.com/eshizhan/archive/2012/05/30/2525755.html

    https://blog.csdn.net/bytxl/article/details/44753241

  • 相关阅读:
    __slots__魔法,减少实例属性消耗的内存
    在函数中最好不要用可变类型当参数
    Python的容器模块
    实例和类变量以及类的魔术方法
    推导式
    Python内置函数
    常用的git操作(持续更新)
    h开头的
    e开头的
    如何迁移测试的MAGENTO到正式运行的MAGENTO
  • 原文地址:https://www.cnblogs.com/okgogo2000/p/9140197.html
Copyright © 2020-2023  润新知