190 votes

Comment éviter d'utiliser sudo quand on travaille dans /var/www ?

Je veux arrêter de devoir utiliser sudo à chaque fois que je travaille dans /var/www . Comment puis-je m'y prendre ? Je veux simplement mettre tous mes sites dans ce répertoire et travailler avec eux sans trop de peine.

2voto

Tim Meers Points 643

Chmod dans /var sur www pour autoriser l'accès au propriétaire, et chown pour s'assurer que vous le possédez. C'est probablement une idée stupide, mais ça pourrait certainement fonctionner.

1voto

Igor B. Points 365

Vous pouvez démarrer une session www dans un terminal en procédant comme suit

sudo su www-data

Combiné avec un prompt* de couleur différente, pour rendre plus évident qu'il s'agit du Shell d'un utilisateur différent, et une politique visant à toujours mettre l'xterm (et l'éditeur et autres) correspondant sur - par exemple - le bureau virtuel 4, afin que vous vous y habituiez, pour éviter toute confusion.

*) Pour une invite de couleur différente avec un caractère différent, créez un fichier /etc/prompt comme ceci :

# PROMPTING
#       When  executing  interactively, bash displays the primary prompt PS1 when it is ready to read a command, and the sec-
#       ondary prompt PS2 when it needs more input to complete a command.  Bash allows these prompt strings to be  customized
#       by inserting a number of backslash-escaped special characters that are decoded as follows:
#              \a     an ASCII bell character (07)
#              \d     the date in "Weekday Month Date" format (e.g., "Tue May 26")
#              \D{format}
#                     the  format is passed to strftime(3) and the result is inserted into the prompt string; an empty format
#                     results in a locale-specific time representation.  The braces are required
#              \e     an ASCII escape character (033)
#              \h     the hostname up to the first `.'
#              \H     the hostname
#              \j     the number of jobs currently managed by the shell
#              \l     the basename of the shell's terminal device name
#              \n     newline
#              \r     carriage return
#              \s     the name of the shell, the basename of $0 (the portion following the final slash)
#              \t     the current time in 24-hour HH:MM:SS format
#              \T     the current time in 12-hour HH:MM:SS format
#              \@     the current time in 12-hour am/pm format
#              \A     the current time in 24-hour HH:MM format
#              \u     the username of the current user
#              \v     the version of bash (e.g., 2.00)
#              \V     the release of bash, version + patchelvel (e.g., 2.00.0)
#              \w     the current working directory
#              \W     the basename of the current working directory
#              \!     the history number of this command
#              \#     the command number of this command
#              \$     if the effective UID is 0, a #, otherwise a $
#              \nnn   the character corresponding to the octal number nnn
#              \\     a backslash
#              \[     begin a sequence of non-printing characters, which could be used to embed a terminal  control  sequence
#                     into the prompt
#              \]     end a sequence of non-printing characters
#
#       The  command  number and the history number are usually different: the history number of a command is its position in
#       the history list, which may include commands restored from the history file (see HISTORY below),  while  the  command
#       number  is  the  position in the sequence of commands executed during the current shell session.  After the string is
#
# colors:
# \[...\]   wird benötigt, damit die shell weiß, daß hier kein printable output ist, und die Umbrüche richtig plaziert.
#
# ANSI COLORS
CRE="\[
[K\]"
NORMAL="\[[0;39m\]"
# RED: Failure or error message
RED="\[[1;31m\]"
# GREEN: Success message
GREEN="\[[1;32m\]"
# YELLOW: Descriptions
YELLOW="\[[1;33m\]"
# BLUE: System messages
BLUE="\[[1;34m\]"
# MAGENTA: Found devices or drivers
MAGENTA="\[[1;35m\]"
# CYAN: Questions
CYAN="\[[1;36m\]"
# BOLD WHITE: Hint
WHITE="\[[1;37m\]"
#
# default:
# postgres, oracle, www-data
#
# PS1=$BLUE"machine]->"$NORMAL\\w"$BLUE ø $NORMAL"
PS1=$BLUE"machine]:"$NORMAL\\w"$BLUE > $NORMAL"
#
# root, stefan:
#
case "$UID" in
    '0')
        PS1=$RED"machine:"$NORMAL\\w"$RED # $NORMAL"
    ;;
    '1000')
    PS1=$GREEN"machine:"$BLUE\\w$YELLOW" > "$NORMAL
    ;;
#    default)
#    ;;
esac

et la source à partir de /etc/bash.bashrc par exemple.

Comme outil supplémentaire pour aider à la distinction, vous pouvez toujours éditer vos fichiers avec un alias 'edit' ou un lien symbolique, qui pointe, selon votre identité (taylor/www-data) vers gedit ou mousepad, vim ou pico. Ou vous pouvez utiliser différents profils d'éditeur, au moins dans gedit vous pouvez définir vos préférences pour du texte noir sur fond blanc ou du texte blanc sur fond noir par exemple.

Je n'ai une telle politique que pour travailler en tant que root, donc je ne suis pas sûr qu'elle soit adaptée au travail avec www-data. Combiné avec les sessions ssh vers différents hôtes, qui ont leurs propres invites, cela ne m'a pas empêché de me tromper parfois, mais si cela arrive, je réalise rapidement ce qui ne va pas, et cela arrive rarement.

note : Le prompt-script est en partie une copie de la manpage de bash.

SistemesEz.com

SystemesEZ est une communauté de sysadmins où vous pouvez résoudre vos problèmes et vos doutes. Vous pouvez consulter les questions des autres sysadmins, poser vos propres questions ou résoudre celles des autres.

Powered by:

X