Hier soir, je travaillais sur le développement de mes compétences en ligne de commande et j'ai rencontré un problème où, lorsque j'utilisais sudo, j'ai reçu un message d'erreur indiquant `` autorisation refusée ''. Cependant, lorsque j'ai utilisé «sudo su» et que je suis devenu root, la commande a fonctionné.
Pourquoi sudo n'a-t-il pas fonctionné en premier lieu?
C'était:
$ sudo cat > /var/www/info. php
<?php
phpinfo( ) ;
? >
^D
De l'édition Linux Bible 2010 dans la section sur la configuration d'un serveur LAMP.
command-line
wdypdx22
la source
la source
sudo -s
plussudo su
.Réponses:
Les <,> et >> sont utilisés pour la redirection d'entrée / sortie des commandes - qui est une fonctionnalité fournie par le shell (par exemple, bash). Donc, si vous tapez une commande comme celle-ci,
sudo cat > /var/www/info.php
le shell qui le reçoit en entrée essaie d'ouvrir le fichier/var/www/info.php
et fournit ce fichier comme sortie standard de lasudo
commande. Lasudo
commande ne sait même pas si sa sortie va sur une console ou est redirigée vers un fichier, car cela est pris en charge par le shell qui l'invoque.Si le shell dans lequel vous avez tapé votre commande est votre shell de connexion ou un autre shell exécuté dans un terminal avec votre identifiant utilisateur, il a les mêmes privilèges que votre identifiant utilisateur - pas ceux de root.
Donc, dans votre cas, alors que la commande cat est exécutée en tant que root, la copie de sa sortie vers
/var/www/info.php
est tentée par le shell s'exécutant en tant qu'utilisateur normal, ce qui, comme prévu, échoue.Une solution de contournement pour de telles situations consiste à utiliser la
tee
commande:Cela aura pour effet de mettre tout le texte saisi sur la console jusqu'à ^ D dans le fichier spécifié en paramètre.
Un effet secondaire peut-être indésirable est qu'il
tee
fera également écho à la sortie vers la sortie standard, donc après avoir tapé chaque ligne et appuyé sur Entréetee
, une copie en sera renvoyée. Pour éviter cela, vous pouvez utiliser la variante suivante.Les détails
tee
peuvent être obtenus viainfo tee
un terminal.la source
sudo ne fonctionne pas pour les commandes qui ont besoin d'autorisations pour écrire un fichier, telles que:
sudo echo "vm.swappines = 100" >> /etc/sysctl.conf
Il explique dans la page de manuel sudo.
la source
sudo
. Comme indiqué dans la réponse de koushik, le comportement est assez prévisible, cohérent et "correct" pour le modèle d'autorisation unix.Le problème est que la partie "> foo.txt" est interprétée et exécutée par votre interpréteur de commandes (shell) bien avant l'exécution de la commande sudo. La commande sudo n'a aucune idée que vous souhaitez rediriger sa sortie vers un fichier.
Votre interpréteur de commandes n'a pas l'autorité root (mais la commande sudo finira par la suite), il ne peut donc pas rediriger la sortie vers foo.txt.
la source
Une autre façon de résoudre ce problème est de démarrer un sous-shell avec sudo et d'exécuter cette commande dans ce sous-shell:
ici, la commande "has sudo" est bash, et tout ce qui y est exécuté a des droits root.
2c $, * -pique
la source