저는 명령줄이나 서버에 능숙하지 않습니다. 하지만 작동하려면 LINUX를 사용하여 EC2 AWS AMI를 구성해야 합니다.
그래서 많은 것을 설치하고 많은 것을 옮겼는데 sudo가 제대로 작동하지 않는다는 것을 깨달았습니다. 이전에는 를 입력하면 sudo
즉시 루트가 되었습니다. 이제 를 입력하면 sudo
명령 지침이 표시됩니다(마치 --help를 입력한 것처럼).
[ec2-user@ip-172-31-33-121 ~]$ sudo
usage: sudo [-D level] -h | -K | -k | -V
usage: sudo -v [-AknS] [-D level] [-g groupname|#gid] [-p prompt] [-u username|#uid]
usage: sudo -l[l] [-AknS] [-D level] [-g groupname|#gid] [-p prompt] [-U username] [-u user name|#uid] [-g groupname|#gid] [command]
usage: sudo [-AbEHknPS] [-r role] [-t type] [-C fd] [-D level] [-g groupname|#gid] [-p prompt] [-u user name|#uid] [-g groupname|#gid [VAR=value] [-i|-s] [<command>]
usage: sudo -e [-AknS] [-r role] [-t type] [-C fd] [-D level] [-g groupname|#gid] [-p prompt] [-u user name|#uid] file .
루트 사용자 되기지금내 서버에서는 를 입력해야 합니다 sudo su
. 하지만 입력하자마자 모든 명령이 작동을 멈춥니다.
[root@ip-172-31-33-121 ec2-user]# yum
bash: yum: command not found
내 PATH에 문제가 있을 수 있다는 내용을 어딘가에서 읽었습니다. 일부 설치를 수행할 때 PATH 변수에서 뭔가를 변경한 기억이 나지만 정확히 무엇과 이유가 기억나지 않습니다. 내 PATH에 문제가 있었던 것 같습니다. node.js 또는 npm을 설치하려면 PATH를 복원하는 방법과 이것이 실제로 문제인지 잘 모르겠습니다.
*경로 복원을 해보았으나 예전에는 어땠는지 몰라서 복원했는데 문제가 없었거나, 실제로 복원을 하지 않았거나 둘 중 하나입니다.
출력 echo $PATH
:
[root@ip-172-31-33-121 ~]# echo $PATH
/usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/local/bin:/opt/aws/bin:/root/bin
하지만 저는 이 서버 구성을 처음 접했고 이것이 옳은지... 틀린지 모르겠습니다.
내가 실행할 때 sudo -i
:
[ec2-user@ip-172-31-33-121 ~]$ sudo -i
-bash: id: command not found -bash: tty: command not found
[root@ip-172-31-33-121 ~]# uname -a
Linux ip-172-31-33-121 3.14.44-32.39.amzn1.x86_64 #1 SMP Thu Jun 11 20:33:38 UTC 2015 x86_64 x86_64 x86_64 GNU/Linux
고쳐 쓰다
답변에서 언급했듯이 확인된 /usr/bin이 $PATH에 누락되어 $PATH에 추가했으며 이제 sudo su를 통해 루트를 얻으면 명령이 인식되지만 sudo -i를 통해 루트를 얻으면 여전히 인식하지 못하고 여전히 같은 오류가 발생합니다.
[ec2-user@ip-172-31-33-121 ~]$ sudo -i -bash: id: command not found -bash: tty: command not found –
[root@ip-172-31-33-121 ~]# yum -bash: yum: command not found
업데이트 2
셸을 다시 시작했을 때 뭔가가 내 $PATH를 덮어썼다는 사실을 발견했습니다. 셸을 다시 열었을 때 내 $PATH 변수가 다음 위치에 덮어쓰여졌습니다.
[root@ip-172-31-33-121 ec2-user]# echo $PATH
/sbin:/bin:/usr/sbin:/usr/local/bin:/opt/aws/bin
그래서 /usr/bin을 다시 잃어버렸습니다.
.bashrc를 변경하면 문제가 해결될 것이라고 생각했지만 그렇지 않았습니다. 현재 내 .bashrc는 다음과 같습니다.
# .bashrc
# Source global definitions
if [ -f /etc/bashrc ]; then
. /etc/bashrc
fi
PATH=$PATH:/usr/bin; export PATH
# User specific aliases and functions
env 명령의 결과:
[root@ip-172-31-33-121 ec2-user]# env
LESS_TERMCAP_mb=
HOSTNAME=ip-172-31-33-121
LESS_TERMCAP_md=
LESS_TERMCAP_me=
SHELL=/bin/bash
TERM=xterm
HISTSIZE=1000
EC2_AMITOOL_HOME=/opt/aws/amitools/ec2
PYTHON_INSTALL_LAYOUT=amzn
LESS_TERMCAP_ue=
USER=root
LS_COLORS=rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:mi=01;05;37;41:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arc=01;31:*.arj=01;31:*.taz=01;31:*.lha=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.tzo=01;31:*.t7z=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.lrz=01;31:*.lz=01;31:*.lzo=01;31:*.xz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.alz=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.cab=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.axv=01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=01;36:*.au=01;36:*.flac=01;36:*.mid=01;36:*.midi=01;36:*.mka=01;36:*.mp3=01;36:*.mpc=01;36:*.ogg=01;36:*.ra=01;36:*.wav=01;36:*.axa=01;36:*.oga=01;36:*.spx=01;36:*.xspf=01;36:
SUDO_USER=ec2-user
EC2_HOME=/opt/aws/apitools/ec2
SUDO_UID=500
USERNAME=root
LESS_TERMCAP_us=
PATH=/sbin:/bin:/usr/sbin:/usr/local/bin:/opt/aws/bin:/usr/bin
MAIL=/var/spool/mail/ec2-user
PWD=/home/ec2-user
JAVA_HOME=/usr/lib/jvm/jre
AWS_CLOUDWATCH_HOME=/opt/aws/apitools/mon
LANG=en_US.UTF-8
SHLVL=1
SUDO_COMMAND=/bin/su
HOME=/root
AWS_PATH=/opt/aws
AWS_AUTO_SCALING_HOME=/opt/aws/apitools/as
LOGNAME=root
CVS_RSH=ssh
AWS_ELB_HOME=/opt/aws/apitools/elb
LESSOPEN=||/usr/bin/lesspipe.sh %s
AWS_RDS_HOME=/opt/aws/apitools/rds
SUDO_GID=500
LESS_TERMCAP_se=
_=/bin/env
OLDPWD=/home/ec2-user
최종 업데이트
증가시킴으로써
PATH=$PATH:/usr/bin;
export PATH
/etc/profile 파일에 대해 sudo -i를 수정하여 sudo su가 여전히 작동하지 않도록 할 수 있었지만 그냥 사용할 것 같습니다.sudo -i
다들 감사 해요!
답변1
그래서 마침내 귀하의 질문에 대한 답변을 얻었습니다.
환경 PATH
변수는 에 의해 구성됩니다 /usr/local/sbin:/sbin:/bin:/usr/sbin:/usr/local/bin:/opt/aws/bin:/root/bin
.
그러나 /usr/bin은 포함되어 있지 않습니다.
CentOS에서 which yum
OR 작업을 수행하면 which sudo
이러한 실행 파일이 /usr/bin
.
그래서 제가 생각하는 유일한 방법은 변수
/usr/bin
에 추가하는 것입니다.PATH
PATH=$PATH:/usr/bin;
export PATH
/etc/profile
이를 영구적으로 완화하려면 시스템 에 추가하세요 .
이 마지막 단계를 완료하려면 수퍼유저 권한이 필요합니다.