Knowledge Map
리눅스 netstat 본문
출처:
http://slayer95.tistory.com/entry/Tip%EB%A6%AC%EB%88%85%EC%8A%A4-%ED%84%B0%EB%AF%B8%EB%84%90-%EB%AA%85%EB%A0%B9%EC%96%B4-%EB%AA%A8%EC%9D%8C
http://www.mireene.com/webimg/linux_tip1.htm
Permission
Owner | Group | Other | Owner와 Group은 파일소유자자신과 자신이 속한그룹. Other은 제3자, 웹사이트 방문객은 제3자로 nobody로 취급. | ||||||
r | w | x | r | w | x | r | w | x | r은 파일 읽기(4), w는 파일 쓰기(2), x는 파일 실행(1) |
7 | 5 | 5 | 파일소유자는 그것을 읽고 쓰고 실행시킬 수 있지만, 제3자는 읽고 실행만 시킬 수 있다. | ||||||
7 | 7 | 7 | 제3자도 쓰기 권한이 주어진다. |
*.html *.cgi, *.pl *.txt등의 파일은 업로드시 반드시 ascii로 하고 나머지 그림(*.gif *.jpg)이나 자바 애플릿(*.class), 실행파일(*.exe *.zip *.rar)등은 binary mode로 업로드 할 것.
리눅스 터미널 명령어
rpm [옵션] [파일명] <-- rpm명령어는 redhat 배포본 관련 패키지 명령어입니다.
설명 : 패키지를 설치 및 업그레이드
옵션
-i, -U 설치 및 업그레이드 옵션
-e 패키지의 제거
-q 패키지 질의
-V 패키지 검증
만약 시스템에 설치되어 있는 패키지를 설치하려 한다면 -i 옵션을 -U 옵션을 써야한다.
만약 rpm -e rpm 명령을 실해하면 rpm 은 사라지기 때문에 절대로 하지 말아야 한다.
만약 지웠다면 www.rpm.org 에 가서 rpm 소스를 가져다 설치하는 수밖에 없다.
grep [옵션] [패턴] [파일명]
설명 : grep 명령을 사용하면 파일 내부에 있는 텍스트의 내용으로 파일을 찾을 수 있다. 지정한 문자들을 포함하는 행을 찾을 때마다 그 행을 화면에 표시한다. 만약 grep 하나 이상의 파일을 검색중이라면 그 문자들이 있는 파일의 이름을 표시한다.
옵션
-c 파일 내에서 패턴과 일치하는 줄의 총수를 구한다.
-h 여러 개의 파일을 검색할 때, 출력에 파일명이 나타나는 것을 방지한다.
-i 대, 소문자를 구별하지 않는다
-n 일치하는 줄의 줄 번호도 같이 출력한다
-v 패턴과 일치하지 않는 줄만 출력한다
fdisk [-l] [-v] [-s partition] [device]
설명 : 디스크의 파티션을 변경한다.
옵션
-l 파티션 테이블의 목록을 출력
-v fdisk 버전 출력
-s partition DOS 파티션이 아니라면 해당 파티션의 크기를 출력
device device 에는 몇번째 하드디스크를 파티션 할것인지 알려주어야 한다. 아래는 리눅스에서 각각의 디바이스들에 대한 이름이다.
첫번째 설치된 하드 드라이브 : fdisk /dev/hda
두번째 설치된 하드 드라이브 : fdisk /dev/hdb
SCSI의 첫번째 하드 드라이브 : fdisk /dev/sda
SCSI의 두번째 하드 드라이브 : fdisk /dev/sdb
'm' 명령어로 도움말을 볼수 있다.
chgrp [옵션]
설명 : 파일의 그룹을 바꾸는 명령어
옵션
-R 서브디렉토리까지 모든 파일의 그룹을 바꾼다.
chown [옵션] [파일명]
설명 : 파일의 소유자를 바꾸는 명령어
옵션
-R 서브디렉토리까지 모든 파일의 소유자를 바꾼다.
jobs
설명 : 현재 진행중인 작업들을 출력
옵션
-l 현재 작업하고 있는 디렉토리와 프로세스 그룹 ID를 출력
fg
설명 : 작업을 전명 작업으로 변환하는 것으로 전면 작업이란 모니터에 실행되는 모습을 사용자에 직접 보이며 작업하는 것을 말한다.
bg
설명 : 작업을 후면 작업으로 전화하는 것으로, 후면 작업이란 전면 작업과는 반대로 사용자의 눈에는 실행되는 모습을 보이지 않으면서도 실제로는 일을 하는 것을 말한다. 백그라운드 작업은 "명령어 &"로 명령어 다음에 "&" 표시를 붙여서 후면 작업으로 전환할 수 있도록 되어 있다.
date [yymmddhhmm [ss] ]
설명 : date는 위아 같이 주어진 인수가 없다면 현재 시스템의 시간과 날짜를 출력한다. 만약 주어지는 인자가 있다면 그에 따라서 시스템의 시간과 날짜를 변경한다.
yy는 연도를 나타내는 두 숫자이며, mm은 월을 나타낸다. 그리고 dd는 날짜, hh는 24시간 단위로 표현되는 시견이며, mm은 분을 의미한다. 끝의 ss는 초를 의마하는 부분으로 명시하지 않아도 상관없는 부분이다.
cal [-jy] [ [달] 연도]
설명 : 서기 원년부터 9999년까지의 달력을 볼 수 있다.
인수를 하나만 준다면 그 숫자는 연도를 의미하는 것으로 간주된다. 두 개의 숫자를 준다면 앞의 것을 월, 그 다음은 연도를 의미한다.
옵션
-j 1월 1일 부터 날짜 수를 계산하는 julian 날짜를 표시
-y 올해의 달력을 표시
finger [-slpm] [사용자]
설명 : 시스템 상의 사용자들에 대한 정보를 보여준다.
인수로 아무 것도 주어지지 않으면, finger는 현재 시스템에 로그인되어 있는 사용자들을 보여준다.
옵션
-s 사용자의 로그온 이름, 실제 이름, 터미널 이름, 로그온 시간 등등을 보여줌
-l -s 옵션 정보에 몇 가지를 추가하여, 여러 줄에 걸쳐서 보여줌
-p -l 옵션 정보에서 .plan과 .project 파일을 보이지 않는다.
su [-] [사용자ID][인수]
설명 : 다른 사용자 계정으로 서브 쉘을 생성하는 것으로, 잠시동안 다른 사용자 계정으로 작업할 필요가 있을때 사용한다.
많은 사람들이 su가 'super user'를 의미하는 말로 생각하지만, 사실은 'substitute user'를 의미하는 말이다.
옵션
- 하이픈(-)을 사용하면 새로운 쉘로 로그인할 때 자신의 로그인 과정을 수행한다. 옵션이 주어지지 않으면 새로운 쉘은 단지 쉘 역할을 수행할 뿐이다.
shutdown [옵션] 시간 [메세지]
설명 : 시스템을 종료할 때 일반적으로 사용되는 명령어
옵션
-t n t 옵션 뒤에 n초를 명시해서, 경고 메시지를 보낸후 n초 후에 kill 시그널을 보냄
-h shutdown시 halt를 실행
-r 시스템 종료를 완료하고 나서 다시 부팅 과정을 수행(리부팅)
-c 이미 예약되어 있는 shutdown을 취소
-k 모든 동작을 제대로 수행하지만 시스템을 종료할 시간이 되면 아무것도 하지 않음. ksms 'just kidding'의 의미
명령어 | 사 용 법 |
login | 사용자 인증과정 리눅스 시스템은 기본적으로 multi-user 개념에서 시작하였기 때문에 시스템을 이용하기 위해서는 반드시 로그인을 하여야 합니다. 흔히 말하는 ID를 입력하는 과정입니다. |
passwd | 패스워드 변경 리눅스, 특히 인터넷의 세계에서는 일반 컴퓨팅 상황에 비하여 훨씬 해킹에 대한 위험이 높습니다. 패스 워드는 완성된 단어 보다는 단어 중간에 숫자나 키보드의 ^, #, ' 등과 같은 쉽게 연상 할 수 없는 기호를 삽입하여 만들어 주는 것이 좋습니다 설명 : 사용자 계정의 패스워드를 등록하거나 변경시키는 경우 이용되는 명령어이며 특히 슈퍼유저는 다른 유저의 패스워드도 변경할수 있다. |
du | 하드사용량 체크(chkdsk) 사용자 자신의 디스크 사용 상황을 보고해 준다. (단위 Block) 자신의 하드공간을 알려면 # du |
ls [옵션] [파일명] | 파일 리스트 보기(dir) F : 파일 유형을 나타내는 기호를 파일명 끝에 표시 (예) |
cd [디렉토리명] | 디렉토리를 변경 # cd cgi-bin : 하부 디렉토리인 cgi-bin으로 들어감. # cd _userid : userid의 홈디렉터리 이동 # cd ~/path/path2 홈디렉토리 아래 path/path2로 이동 # cd - : 바로 앞에 작업한 디렉토리로 이동 # cd / : 루트 디렉토리로 옮겨진다. |
cp | 화일 복사(copy) --> cp [옵션] [원본파일명] [목적파일명 / 디렉토리명] : 하나 이상의 원본 파일을 목적 파일이나 디렉토리로 복사. [원본파일명]에는 하나 이상의 파일명 지정가능, [목적 파일명/ 디렉토리명] 에는 복사될 목적 파일명, 복사된 파일이 위치할 목적 디렉토리 지정 옵션 # cp index.html index.old |
mv [옵션][파일명] | 파일이름(rename) / 위치(move)변경 설명 : mv 명령은 파일의 위치를 바꾸거나 이름을 바꾸는데 사용을 한다. mv 명령은 이미 존재하는 파일을 덮어쓰기를 한다. 'mv file1 file2'라고 입력을 하는 것은 file1의 이름을 file2라고 바꾼다. 만약 file2 라는 파일이 이미 존재한다면 file1의 내용물로 교체가 된다. 파일을 한 디렉토리에서 다른 디렉토리로 옮기기 위하여서는 경로를 함께 입력하여 주면 된다. 같은 이름의 파일이 이미 존재하여서 그것을 덮어쓰기를 하지 않으려면 -i 옵션을 사용하면 된다. 한번에 여러 개의 파이을 옮길수도 있다. 마지막이 파일들을 옮겨 넣고자 하는 디렉토리이기만 하면 되는 것이다. 예를 들면 'mv profit sales.txt wrksht repotrs'라고 하면 profit sales.txt wrksht를 모두 reports 디렉토리로 이동시킨다. 옵션 # mv index.htm index.html $ mv file ../main/new_file |
mkdir | 디렉토리 생성 write permission이 허용되어야만 directory를 만들 수 있다. 옵션 # mkdir download : download 디렉토리 생성 |
rm | 화일삭제 설명 : rm(remove) 파일(디렉토리)을 삭제한다. 삭제하고자 하는 디렉토리에 파일이나 부 디렉토리가 없어야만 삭제가 가능하다. -f 디렉토리 안의 파일을 삭제할 때 사용자에게 확인을 요구하지 않음 # rm test.html : test.html 화일 삭제 |
rmdir | 디렉토리 삭제 whrite permission이 허용되어야만 directory를 제거할수 있다. -p 제거된 디렉토리에 대한 메시지가 표시됨 |
pwd | 현재의 디렉토리 경로를 보여주기 |
pico | 리눅스용 에디터 |
put | ftp 상태에서 화일 업로드 > put guestbook.tar.gz |
get | ftp 상태에서 화일 다운로드 > get guestbook.tar.gz |
mput 또는 mget | 여러개의 화일을 올리고 내릴때 (put,get과 사용법동일) |
chmod | 화일 permission 변경 리눅스에서는 각 화일과 디렉토리에 사용권한을 부여. 예) -rwxr-xr-x guestbookt.html 읽기(read)---------- 화일 읽기 권한 명령어 사용법 # chmod 666 guestbook.html # chmod 766 guestbook.html |
alias | " doskey alias" 와 비슷하게 이용할 수 있는 쉘 명령어 alias는 말그대로 별명입니다. 사용자는 alias를 이용하여 긴 유 닉스 명령어를 간단하게 줄여서 사용할 수도 있습니다. |
cat [파일명] | 파일의 내용을 화면에 출력하거나 파일을 만드는 명령( 도스의 TYPE명령) |
more | more [-ncdflspu] [+줄번호] [파일이름(들)] cat 명령어는 실행을 시키면 한 화면을 넘기는 파일일 경우 그 내용을 모두 볼수가 없다. 하지만 more 명령어를 사용하면 한 화면 단위로 보여줄 수 있어 유용. 한 화면씩 보기. 유닉스에서 커다란 텍스트 파일을 보는 것이나 많은 수의 파일과 서브디렉토리를 포함하는 디렉토리의 리스트를 보이게 하는 것은 아주 빠른 속도로 화면이 넘어가게 한다. 이럴 경우에 more나 pg 명령을 사용하여서 한 하면씩 보이게 할 수 있다. more filename을 입력하면 filename으로 지정한 파일을 한번에 한 화면에 해당하는 양 만큼씩 보여준다. 또한 출력을 more 명령으로 파이프(redirect) 시킬 수도 있다. 예를 들면 ls -al |more 는 ls 명령의 출력을 more로 보내어서 리스팅을 한 페이지씩 보이게 한다. more를 사용해서 파일을 살펴보는 일반적인 방법은 다음과 같다. # more <옵션>
|
who | 현재 시스템에 login 하고 있는 사용자의 리스트를 보여줍니다. # who |
whereis | 소스, 실행파일, 메뉴얼 등의 위치를 알려줍니다 # whereis perl : perl의 위치를 알려준다 |
vi, | 새로운 파일을 만드는 방법 # vi newfile : vi 편집기 상태로 들어감 설명 : 파일의 액세스 시간이나 갱신 시간을 수정
|
cat, | 파일 내용만 보기 # cat filename : 파일의 내용을 모두 보여줌 |
압축명령어 사용법
압축 명령어 | 사 용 법 |
tar | .tar, _tar로 된 파일을 묶거나 풀때 사용하는 명령어 (압축파일이 아님) # tar cvf [파일명(.tar, _tar)] 압축할 파일(또는 디렉토리): 묶을때 # tar xvf [파일명(.tar, _tar)] : 풀 때 (cf) cvfp/xvfp 로 하면 퍼미션 부동 |
compress | 확장자 .Z 형태의 압축파일 생성 # compress [파일명] : 압축시 # uncompress [파일명] : 해제시 |
gzip | 확장자 .gz, .z 형태의 압축파일 생성 설명 : 리눅스에서 사용하는 압축 프로그램으로 속도 면에서나 압축률 면에서나 상당히 좋은 프로그램이다. 옵션 -d 압축을 해제하는 옵션 -f 압축을 하거나 해제할 때 같은 이름의 파일이 존재할 경우 덮어쓰기를 한다. -l 압축파일의 정보를 보여 준다. -r 압축 대상의 디렉토리까지 압축을 수행한다. # gzip [파일명] : 압축시 # gzip -d [파일명] : 해제시 |
기타 | tar [옵션] [파일명] 설명 : tar 명령어는 여러 파일을 하나로 묶는데 사용한다. tar는 파일을 압축하지 않지만 gzip와 같이 쓰면 매우 효과적이다. 옵션 c 새로운 tar파일의 생성 x 기존의 tar파일을 푸는데 사용 u 업데이트를 위한 옵션 t tar파일을 푸는 것이 아니라 내용을 보는 옵션 v 파일을 묶거나 풀때의 작업을 보여주는 옵션 z gzip를 이용해 tar.gz 혹은 .tgz로 묶인 파일을 풀 때 사용하는 옵션 .tar.Z 이것은 tar로 묶은 후에 compress를 사용하여 압축한 것으로 uncompress를 사용해서 압축을 푼 다음, 다시 tar를 사용해서 원래의 파일들을 만들어내면 됩니다. 아니면 다음과 같이 한 번에 풀 수도 있다. # zcat [파일명].tar.Z : 해제시 .tar.gz또는 .tar.z # gzip -cd [파일명] : 해제시 .tar.gz 또는 .tar.z .tgz gzip을 사용해서 푼 다음 다시 tar를 사용해서 원래 파일을 만들어 낼 수 있으나, 하지만 다음과 같이 하면 한 번에 처리를 할 수 있다. # gzip -cd 파일.tar.gz | tar xvf - 또는 # tar xvzf 파일.tar.gz # tar xvzf 파일.tgz |
리눅스 필수명령어
Linux/Unix 명령어 | 설 명 | MS-DOS 비교 |
./x | x 프로그램 실행 | x |
↑/ ↓ | 이전에(↑) / 다음에(↓) 입력했던 명령어 | doskey |
cd x (또는 cd /x) | 디렉토리 X로 가기 | cd |
cd .. (또는 cd ../ 또는 cd /..) | 한 디렉토리 위로 가기 | cd.. |
x 다음 [tab] [tab] | x 로 시작하는 모든 명령어 보기 | - |
adduser | 시스템에 사용자 추가 | / |
ls (또는 dir) | 디렉토리 내부 보여주기 | dir |
cat | 터미널 상의 텍스트 파일 보기 | type |
mv x y | 파일 x를 파일 y로 바꾸거나 옮기기 | move |
cp x y | 파일 x를 파일 y로 복사하기 | copy |
rm x | 파일 지우기 | del |
mkdir x | 디렉토리 만들기 | md |
rmdir x | 디렉토리 지우기 | rd |
rm -r x | 디렉토리 x를 지우고 하위도 다 지우기 | deltree |
rm p | 패키지 지우기 | - |
df (또는 df x) | 장치 x의 남은 공간 보여주기 | chkdsk ? |
top | 메모리 상태 보여주기(q는 종료) | mem |
man x | 명령어 x에 관한 매뉴얼 페이지 얻기 | / |
less x | 텍스트 파일 x 보기 | type x | more |
echo | 어떤 것을 echo 화면에 인쇄한다. | echo |
mc | UNIX를 위한 노턴 커맨더 | nc |
mount | mount [-t 파일시스템] [장치명] [마운트디렉토리] 장치 연결(예: CD-ROM, 연결을 해제하려면 umount) | - |
halt | 시스템 종료 | - |
reboot ([ctrl] + [alt] +[del]) | 시스템 다시 시작하기 | [ctrl] + [del] + [del] |
고급명령어
고급 명령어 |
|
chmod <권한> <파일> | 파일 권한(permissions) 변경 |
ls -l x | 파일 x의 자세한 상황을 보여줌 |
ln -s x y | x에서 y로 심볼릭 링크를 만들어 줌 |
find x -name y -print | 디렉토리 x안에서 파일 y를 찾아서 화면에 그 결과를 보여줌 |
ps | 지금 작동중인 모든 프로세스들을 보여줌 설명 : 현재 자신의 리눅스 서버에서 어떤 프로세스들이 활동하고 있는지 살펴보고자 할떄 'ps' 명령을 사용하는 것이 일반적이다. ps 명령을 사용하면 현재 자신이 실행한 프로세스의 목록을 살펴볼수 있으며, '-aux' 옵션을 사용하면 시스템에서 동작중인 모든 프로세스를 살필수 있다. 사용키 |
kill x | 프로세스 x를 종료 (x는 ps 명령으로 알 게 된 PID) kill [-signalID] PID |
[alt] + F1 - F7 | 터미널 1-7까지 바꾸기 (텍스트 터미널에서; F7은 X-윈도우(시작될때)) |
lilo | 부트 디스크를 만듦 |
용어 |
|
symlink | 다른 파일이나 디렉토리로 심볼릭 링크. 윈도유98의 바로가기 같은 것 |
shell script | 여러 명령어들을 차례로 수행하게 한 것. MS-DOS의 배치 파일 같은 것 |
팁!!
- 웹에서 생성한 노바디파일 삭제 하는방법..
기본적으로 웹서버는 nobody 권한으로 동작이 되게 됩니다.
고객님께서 FTP 로 접속하여 전송한 파일이 아니라 웹상에서 사용자들이 파일을 업로드 한 경우나 웹상에서 생성된 파일의 경우 삭제가 되지 않는 경우가 있을 수 있습니다.
웹서버의 동작 권한은 nobody 이고 웹상에서 생성된 파일이므로 해당 파일이 nobody 소유권으로 시스템에 생성이 되게 됩니다.
아래와 같이 웹상에서 실행시키면 됩니다.
1. 메모장을 열어 아래 소스를 붙여넣기 하신후..
<?
//폴더/파일 삭제시
$cmd = `rm -rf 노버디로된파일혹은폴더명`;
echo "$cmd";
echo "폴더가 삭제 되었습니다.";
?>
-- 위에까지..
-- **위에서 수정할 사항은 "노버디로된파일혹은폴더명"을 삭제하시고자 하는 파일명으로 바꿔주세요..
2. 파일 -> 다른이름으로저장 -> 아래 탭에서 파일형식을 "모든파일"로 선택후
-> "원하는파일명.php" 로 저장 (ex: del.php)
3. ftp를 통해 고객계정에 파일업로드를 하시고 웹에서 파일을 불러주시면 됩니다
ex: html폴더안에/temp 안에 삭제하고자하는 파일이 있을경우 / html폴더/temp안에 del.php를 업로드하고..
브라우저에서 http://고객도메인/temp/del.php 를 하면 됩니다
4. 실행하시면 삭제되고 nobody 권한의 폴더만 남습니다.(폴더안의화일들만 지워짐)
그후 ftp 접속후 폴더를 삭제하시면 됩니다.
ex)
<?
퍼미션 변경시
$cmd = `chmod -R 777 노버디로된파일혹은폴더명`;
echo "$cmd";
echo "퍼미션 변경되었습니다.";
?>
'기타' 카테고리의 다른 글
프로그래밍 종류 (0) | 2016.06.19 |
---|---|
폴더 권한 관련 (0) | 2016.06.17 |
클린코드 - 3장 함수 (0) | 2016.06.15 |
[VirtualBox] 시스템에서 VT-x/AMD-V 하드웨어 가속을 사용할 수 없습니다 (0) | 2016.04.21 |
티스토리에 코드 입력하기 (1) | 2016.02.28 |