避免’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

时间: 2024-08-29 08:57:12

避免’sudo echo x >’ 时’Permission denied’的相关文章

记录在shell脚本中使用sudo echo x > 时,抛Permission denied错误

1.场景 在一个非root且带有sudo权限的用户,使用shell脚本(单独手工执行命令不会抛错,是成功的):会抛错 #!/bin/bash -x DNS_SERVER=10.xx.xx.xx; echo "Add DNS Server"; sudo chattr -i /etc/resolv.conf; sudo echo "nameserver $DNS_SERVER" > /etc/resolv.conf; sudo chattr +i /etc/res

sudo echo 命令报错:Permission denied

转发:http://blog.csdn.net/hejinjing_tom_com/article/details/7767127 避免'sudo echo x >' 时'Permission denied' 甲: 示例sudo echo a > 1.txt-bash: 1.txt: Permission denied乙: 分析:bash 拒绝这么做,说是权限不够.这是因为重定向符号 ">" 也是 bash 的命令.sudo 只是让 echo 命令具有了 root 权

避免 ‘sudo echo xxxx >’ 时候 出现 “permission denied”

?  ~ echo "/opt/nfs 10.10.10.*(rw,all_squash,sync)">>/etc/exports zsh: permission denied: /etc/exports 解决办法: 1)sudo sh -c ' echo "/opt/nfs 10.10.10.*(rw,all_squash,sync)" >> /etc/exports' 2)echo "/opt/nfs 10.10.10.*(rw

串口编程时,出现Cannot open /dev/ttyS0 Permission denied解决

在ubuntu14.04上,通过qt creator进行串口编程时出现: trying to open file "/dev/ttyS0" could not open file: 权限不够 port open is false jgc> ls -al /dev/ttyS0 crw-rw---- 1 root dialout 4, 64 Mar 23 21:00 /dev/ttyS0 jgc> echo xyzzy >/dev/ttyS0 bash: /dev/tty

tiny210 NFS挂载时出现/init: line 109: can't open /r/dev/console: Permission denied,解决办法

在主机文件系统下,修改/dev/console 的权限,sudo chmod 777 /dev/console,执行#ls -l后打印: crwxrwxrwx 1 root root 5, 1 2015-04-19 10:43 console tiny210 NFS挂载时出现/init: line 109: can't open /r/dev/console: Permission denied,解决办法

Docker启动时提示Get Permission Denied while trying to connect解决方法

环境描述 vmware15虚拟机安装centos7.4 64位系统,docker版本19.03.2 问题描述 安装完docker后,执行docker相关命令 docker run ubuntu:15.10 /bin/echo "Hello world" 出现如下提示: docker: Got permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.so

Linux下-bash: Permission denied 或者 sudo: command not found 错误

有时候执行一个脚本或者运行一个可执行文件时,如执行脚本./foo.sh,会报错-bash: ./foo.sh: Permission denied,你会再试sudo ./foo.sh,发现继续报错sudo: foo.sh: command not found,这时候可能是因为该文件没有执行权限,可以通过ls -l foo.sh查看文件信息,如果确实没有,可以为文件增加执行权限 chmod +x foo.sh 这个时候就可以运行了. 参考Command not found when using s

Ubuntu vsftp复制文件到远端时错误,Permission denied

Ubuntu 下复制文件到远端时错误,Permission denied 失败原因如下: (1)vsftp默认配置不允许上传文件 解决办法:修改配置文件 vi /etc/vsftpd.conf. 将"write_enable=YES"前面的#去掉,然后保存. 最后重启vsftp服务器  : service vsftpd restart (2)权限不够 切换到root用户,使用chmod -R 777 filename ,这里filename是你的目录或者文件.-R是指递归设置权限,77

http启动时提示如下错误Permission denied

apache配置了多端口,启动时提示如下错误,原因是selinux开启导致 [[email protected] conf]# /etc/init.d/httpd start Starting httpd: [Tue Dec 20 11:34:44 2016] [warn] NameVirtualHost *:80 has no VirtualHosts (13)Permission denied: make_sock: could not bind to address [::]:8001 (