오늘은 Linux에서 유저 권한설정 방법에 대해서 정리해 보도록 하겠습니다.
1. Linux의 유저시스템
Linux는 여러 사용자가 접속할 수 있는 OS시스템입니다.
모든 권한을 가진 root가 존재하구요.
나머지 사용자들에 대해서는, 그룹에 포함시켜서 관리를 하게 됩니다.
2. group
group에 관한 정보들은
"/etc/group"에서 볼 수 있습니다.
아래 명령어로 쉽게 확인할 수 있습니다.
- cat /etc/group
나오는 정보는 다음과 같은 순서로 나오는 것을 볼 수 있습니다.
비밀번호는 "x"로 나와서 가려지구요. 그룹에 속한 사용자 이름도 가려지는 경우가 많습니다.
그룹명: 비밀번호: 그룹ID: 그룹에 속한 사용자 리스트(","로 구분)
/etc/passwd에서 사용자에 대한 정보가 기술되어 있습니다.
가장 처음에 나오는 사용자는 root이구요. ID도 0입니다.
사용자명: 비밀번호: 유저ID: 소속된 그룹의 ID: 전체이름: 홈디렉토리명: 기본Shell의 이름<bash>
2. 유저 권한 설정
2. sticky bit
sticky bit를 실제로 설정한 명령어를 보겠습니다.
- chmod -R 1777 /srv/http/my-project
위의 명령어와 옵션들은 각각 다음과 같은 의미를 가집니다.
- chmod: 파일 권한을 변경하는 명령어
- -R: 리커시브(재귀적) 옵션
- 지정한 디렉토리 내 모든 파일과 서브디렉토리에 대해 작업을 수행합니다.
- 1777: 권한을 나타내는 숫자로, 여기서는 특정한 권한 패턴을 나타냅니다.
- 이 패턴은 SUID와 sticky bit을 설정한 것입니다.
- 이 패턴은 SUID와 sticky bit을 설정한 것입니다.
위에서 1777이라는 숫자에 대해서 더 알아보겠습니다.
이는 다음과 같이 다시 구성되어 집니다.
- 1은 sticky bit
- Sticky bit은 디렉토리 내의 파일을 해당 파일의 소유자만이 삭제할 수 있도록 하는 보안 기능 중 하나입니다.
- 7은 소유자에게 읽기, 쓰기 및 실행 권한을 부여,
- 2는 그룹에게 읽기와 실행 권한을, 나머지
- 7은 다른 사용자에게 읽기, 쓰기 및 실행 권한을 부여합니다.
위에서 언급한, Sticky bit(스티키 비트)는 UNIX 및 유닉스 계열 운영 체제에서 사용되는 파일 및 디렉토리 권한의 일부로서, 특정 디렉토리 내에서 파일을 삭제하는 권한을 제한하는 보안 기능입니다.
일반적으로, 디렉토리 내의 파일은 해당 디렉토리에 쓰기 권한이 있는 사용자라면 누구나 삭제할 수 있습니다. 하지만 디렉토리에 sticky bit이 설정되어 있으면, 해당 디렉토리 내의 파일은 그 파일의 소유자만이 삭제할 수 있습니다. 다른 사용자는 자신이 만든 파일 외에는 삭제할 수 없습니다.
스티키 비트는 주로 /tmp 디렉토리와 같은 공유 디렉토리에서 여러 사용자가 파일을 생성하고 삭제할 때의 보안 이슈를 해결하기 위해 사용됩니다. 이렇게 하면 다양한 사용자가 서로의 파일을 보호할 수 있습니다.
4. 유저권한 읽기
ls -la를 해보면 아래와 같은 파일 권한이 왼쪽에 표시가 됩니다.
- drwxr-xr-x
위와 같은 권한이 있다고 하겠습니다.
무슨 의미일지 하나씩 보도록 하기전에,
아래 3가지 문자에 대해 이해하고 있어야 합니다.
구분 | 내용 |
r | 읽기(read) 권한 |
w | 쓰기(write) 권한 |
x | 실행(execute) 권한 |
이제 하나씩 보도록 하겠습니다.
- d: 디렉토리를 의미, 파일의 경우는 '-'로 표시
- rwx: 처음 세문자는 소유자의 권한을 의미
- read, write, execute 권한을 모두 소유
- r-x: 다음 세문자는 그룹의 권한을 의미(파일을 만든 사용자의 기본 그룹)
- read, execute 권한만 소유
- r-x: 다음 세문자는 기타 모든 사용자의 권한을 의미
- read, execute 권한만 소유
정리해 보면, 이 파일을 생성한 소유자만 쓰기 권한을 가지고,
나머지 사용자들은 모두 읽기와 실행권한만 가지고 있습니다.
4. 실행권한 추가하기
리눅스에서 스크립트 파일을 생성했는데,
실행권한이 없으면,
당연히 실행이 되지 않습니다.
'ls -la' 명령어를 실행해 보면,
아래와 같이 되어 있는 것을 볼 수 있습니다.
-rw-r--r-- 1 user staff 812 Jan 1 11:51 docker-cleanup.sh
이럴 때는 아래 명령어를 입력해 주기만 하면 됩니다.
이 명령어는,
소유자(u)에게 읽기, 쓰기, 실행 권한을 부여하고,
그룹(g)과 기타 사용자(o)에게 읽기와 실행 권한을 부여해 줍니다.
chmod +x <실행파일>
그럼 아래와 같이 바뀌는 것을 볼 수 있습니다.
그룹과 기타 사용자에게는 쓰기 권한인 w를 부여하지 않은 것을 볼 수 있습니다.
- -rwxr-xr-x 1 user staff 812 Jan 1 13:52 docker-cleanup.sh
만약 소유자에게만 실행권한을 추가하려고 한다면 아래와 같이 명령어를 넣어주면 됩니다.
chmod u+x <실행파일>
당연히 실행권한을 최소화 하는 것이 보안에 도움이 되겠지요.
'Linux > Linux 명령어, 스크립트, 설정' 카테고리의 다른 글
리눅스에서 자주 사용하는 스크립트 사용법 총정리 (0) | 2025.01.14 |
---|---|
실행중인 서버의 IP주소 알아내기: ifconfig (1) | 2024.09.14 |
linux 환경변수 설정 방법 정리: Bash 와 Z Shell PATH 및 기본 에디터 변경(Nano) (0) | 2024.04.09 |
Linux 명령어 및 단축키 중 자주 사용하게 되는 것 정리 # 권한변경 (1) | 2024.02.01 |
SCP로 서버에 파일 전송하기: 리눅스 기반 안전한 파일 전송 방법 (1) | 2024.01.31 |
Script를 실행하는 방법:Linux Bash Shell Script (0) | 2020.04.25 |
댓글