반응형
01-01-04 사용자 계정 관리
사용자 계정 설명
- 설명
- 일반적인 사용자들은 일반 사용자 계정으로 생성된다. 시스템 파일과 디렉터리에 제한적으로 접근하도록 설정하여 시스템을 보호한다.
- 일반 사용자 계정은 그룹에 속할 수 있고, 리눅스는 그룹 단위로 파일 접근 권한 설정과 프로세스 관리를 수행할 수 있다.
- UID
- 레드햇 또는 CentOS 6 버전 계열의 UID는 500 이상의 값을 갖는다. 그러나 레드햇 또는 CentOS 7 버전과 오픈수세, 데비안의 UID는 1000 이상의 값을 갖는다.
- 일반 사용자 계정의 UID 범위는 /etc/login.defs에 정의되어 있다.
사용자 생성하기
- useradd를 통한 사용자 계정 생성
- 사용자를 생성하기 위해서는 useradd 명령어나 adduser 명령어를 사용한다.
- 형식
- # useradd [options] username
- 옵션
- -d, --home
- 홈 디렉터리를 지정한다.
- 홈 디렉터리의 기본값은 기본 경로에 사용자 이름으로 생성한다.
- 지정한 홈 디렉터리의 상위 경로가 존재해야 한다.
- -D, --defaults: 사용자 생성 시 사용하는 기본값을 보거나 설정할 수 있다.
- -e, --expiredate
- YYYY-MM-DD 형식으로 계정의 만기일을 지정한다.
- 지정한 날짜가 지나면 계정은 비활성화된다.
- 지정되어 있지 않으면 만기일은 없다.
- 만약 지정하지 않으면 /etc/default/useradd의 EXPIRE 필드를 따른다.
- -f, --inactive
- 패스워드 만료일 이후 유효기간을 설정한다.
- 1 이상의 숫자이면 해당 일 수만큼 패스워드가 유효하고, 0이면 패스워드가 만료되자마자 패스워드가 잠기고, -1이면 해당 기능을 사용하지 않는다.
- 설정하지 않는다면 /etc/default/useradd의 INACTIVE 값을 따른다.
- -g, --gid GROUP
- 사용자의 그룹을 설정한다. 그룹은 이미 존재하는 그룹이어야 한다.
- 만약 설정하지 않으면 /etc/login.defs의 USERGROUPS_ENAB 변수를 보고 yes로 설정되어 있으면 사용자 이름과 동일한 그룹에 설정한다. no로 설정되어 있다면 /etc/default/useradd의 GROUP을 지정한다.
- -G, --groups: 기본 그룹 외에 추가로 그룹을 설정할 때 사용하고 [,]를 통해 여러 그룹을 지정할 수 있다.
- -k, --skel SKEL_DIR: -m 옵션을 통해 홈 디렉터리 생성할 때 복사할 기본 파일을 지정할 때 사용한다.
- -m, --create-home
- 홈 디렉터리를 지정할 때 사용하고 디렉터리가 없으면 생성한다.
- -k 옵션과 같이 사용해서 홈 디렉터리 생성 시 복사할 기본 파일 경로도 지정한다.
- 기본적으로 이 옵션을 사용하지 않고 /etc/login.defs에 CREATE_HOME 변수도 지정되어 있지 않으면 홈 디렉터리를 생성하지 않는다.
- -M: CREATE_HOME가 설정되어 있더라도 홈 디렉터리를 생성하지 않는다.
- -N, --no-suer-group
- 사용자와 동일한 이름으로 그룹을 생성하지 않는다.
- 그러나 -g 옵션이나 /etc/default/useradd의 GROUP 변수에 지정된 그룹으로 사용자가 추가될 수 있다.
- -p, --password PASSWORD
- 평문이 아닌 암호화된 패스워드를 설정할 수 있다.
- 이 옵션은 사용자에게 패스워드 노출이 가능하므로 사용을 권장하지 않는다.
- -r, --system
- 시스템 계정을 생성한다.
- -m 옵션을 사용하지 않는 한 홈 디렉터리를 생성하지 않는다.
- -s, --shell SHELL
- 사용자가 사용할 셸을 지정한다.
- 지정하지 않는다면 /etc/default/useradd의 SHELL 변수를 사용한다.
- -u, --uid UID
- 사용자의 유일한 UID 값을 설정한다.
- 값은 음수이면 안 되고 UID_MIN 보다는 크고 UID_MAX 보다는 작은 값이어야 한다.
- -d, --home
- 주요 예제
- # useradd apple
- # useradd -d /home/fruit/apple
- # useradd -u 2000 -g fruit apple
- # useradd -e 2025-12-31 apple
- $ sudo useradd -D
- useradd와 adduser 차이
- CentOS 계열에서는 adduser는 useradd의 링크이기에 차이가 없다.
- Ubuntu 계열에서는 차이가 있다.
- Ubuntu에서 useradd 명령을 사용할 경우 -m 옵션으로 홈 디렉터리를 지정하고 passwd를 통한 패스워드 지정이 필요하다. 그러나 adduser를 사용하면 대화식으로 사용자 정보를 입력하여 생성할 수 있다.
passwd를 통한 패스워드 설정하기
- 설명
- useradd 명령어를 통해 사용자를 생성하면 패스워드를 설정하기 전까지 로그인할 수 없으므로 passwd를 통해 패스워드를 설정해야 한다.
- 패스워드를 입력 후 사용자의 패스워드를 삭제하거나 변경 기간을 설정하는 등의 관리 목적으로 사용할 수 있다.
- 형식
- # passwd [options] [username]
- 옵션
- -d, --delete: 패스워드를 삭제한다. 비밀번호 없이 로그인할 수 있다.
- -e, --expire: 패스워드를 만료한다. 사용자는 다음 로그인할 때 패스워드를 변경해야 한다.
- -i, --inactive: 사용자의 패스워드가 만료된 이후로 사용자 계정을 비활성화할 때까지 유예기간을 일수로 지정한다.
- -l, --lock: 사용자의 패스워드에 LOCK을 걸어 로그인을 막는다.
- -n, --mindays: 비밀번호를 변경할 수 있을 때까지 유지해야 할 일수를 설정한다. 0으로 지정하면 언제든지 패스워드를 변경할 수 있다.
- -q, --quiet: 아무런 화면 출력 없이 명령을 수행한다.
- -S, --status: 사용자의 로그인명, 패스워드 상태, 패스워드 설정 여부, 마지막으로 변경한 날짜, 패스워드 변경까지 남은 기간 등 다양한 정보를 얻을 수 있다.
- -u, --unlock: -l 옵션으로 LOCK 걸린 패스워드를 다시 해제한다.
- -w, -warndays: 패스워드 만료 전 경고 날짜를 지정한다.
- -x, --maxdays: 패스워드 최대 사용기간을 설정한다.
- 주요 예제
- $ sudo passwd apple
- # passwd
- $ sudo passwd -e apple
- $ sudo passwd -S apple
- $ sudo passwd -l apple
- $ sudo passwd -d apple
- $ sudo passwd -n 7 -x 365 -w 5 -i 10 apple
su 명령어로 사용자 전환하기
- 설명
- su는 substitute user 또는 switch user의 약자로서 현재 로그인 세션에서 다른 사용자 권한으로 실행하고자 할 때 사용한다.
- 보통 root 권한이 필요한 경우 일반 사용자로 로그인했다가 su 명령어를 사용하여 root 사용자로 전환하여 필요한 작업을 수행하고 exit 명령으로 원래 사용자로 돌아오는 방법을 많이 사용한다.
- 형식
- su [options] username
- 옵션
- -c, --command: 지정한 사용자로 셸이 실행할 명령어를 지정한다.
- -, -l, -login: 사용자가 직접 로그인했을 때와 동일하게 환경변수 등이 설정되고 홈 디렉터리로 이동한다.
- -s, --shell: 명시된 셸을 사용한다.
- 주요 예제
- $ su
- $ su -
- $ su -l
- $ su --login
- $ su root -c "vi /etc/passwd"
- # su - apple
usermod를 사용하여 사용자 설정 변경하기
- 설명
- 사용자 셸, 홈 디렉터리, 그룹, UID, GID 등 사용자 설정을 변경한다.
- useradd 명령어에서 할 수 있는 설정 대부분을 수정할 수 있으며 동일한 옵션은 간추려 설명한다.
- 형식
- usermod [options] username
- 옵션
- -a, --append: 사용자에게 그룹을 추가하기 위해 -G 옵션과 함께 사용한다.
- -c, --comment: 사용자에 대한 간단한 정보를 입력한다.
- -d, --home: 사용자의 홈 디렉터리를 변경한다. 만일 -m 옵션을 함께 사용한다면 현재의 홈 디렉터리의 내용이 새로운 홈 디렉터리로 복사되고 디렉터리가 존재하지 않는다면 생성도 해준다.
- -e, --expiredate: YYYY-MM-DD 형식으로 지정한 날짜 이후로는 사용자 계정이 비활성화된다.
- -f, --inactive: 패스워드가 만료된 이후 며칠 동안 유효할 것인지 지정한다.
- g, --gid: 존재하는 그룹의 이름이나 GID를 입력하여 변경한다.
- -G, --groups: 현재 지정된 그룹에 추가할 그룹을 지정한다. 복수 개로 지정할 수 있다.
- -l, --login: 사용자의 로그인 이름을 변경한다.
- -L, --lock: 사용자의 패스워드에 LOCK을 걸어 로그인을 막는다.
- -m, --move-home: 사용자의 홈 디렉터리의 내용을 새 홈 디렉터리로 옮긴다. -d 옵션과 함께 사용한다.
- -p, --password: 암호화된 패스워드를 설정한다.
- -s, --shell: 사용자의 새로운 셸을 지정한다.
- -u, uid UID: 사용자의 UID를 지정한다.
- -U, --unlock: 사용자의 패스워드에 걸린 LOCK을 해제한다.
- 주요 예제
- # usermod -d /home/redapple apple
- # usermod -g flower apple
userdel을 사용하여 사용자 계정 삭제하기
- 설명
- 사용자 계정을 삭제한다.
- 형식
- userdel [option] username
- 주요 예제
- # userdel apple
- # userdel -r apple
- # userdel -f apple
chage를 통한 패스워드 관리하기
- 설명
- 사용자의 패스워드 만료 정보를 설정한다.
- 형식
- charge [oprions] username
- 옵션
- -d, --lastday: 패스워드를 변경해야 할 날짜 수를 지정한다.
- -E, --expiredate: 계정이 만료되는 날을 설정한다.
- -I, --inactive: 계정 만료 후 패스워드가 비활성화될 때까지 유예기간을 설정한다.
- -l, --list: 계정의 패스워드 만료 정보를 보여준다.
- -m, --mindays: 패스워드를 변경할 때까지 최소 날짜를 지정한다.
- -M, --maxdays: 패스워드를 변경할 때까지 최대 날짜를 지정한다.
- -W, --warndays: 패스워드 만료에 대한 경고 메시지를 보여줄 날짜를 지정한다.
- 주요 예제
- $ sudo chage -l apple
- $ sudo chage -m 7 -M 365 -W 5 -i 3 apple
- $ sudo chage -E 2025-12-31 apple
- $ sudo chage -d 10000 apple
- 복잡한 패스워드 만료 설정
- 마지막 패스워드 변경일을 기준으로 계산한다. 마지막 패스워드 변경일은 -d 옵션을 통해 강제 지정할 수 있다.
- -m 옵션을 사용하여 적용한 날짜 이후로 패스워드를 변경할 수 있고 -M 옵션으로 지정한 날 수 이후에는 패스워드가 만료된다.
- -W 옵션으로 지정한 날 동안 경고 메시지를 출력하며 -l 옵션을 사용한 기간만큼 패스워드 비활성화를 유예한다.
반응형
'Linux > 리눅스 시스템 관리' 카테고리의 다른 글
01-01-06 사용자 환경설정 파일 (0) | 2022.02.10 |
---|---|
01-01-05 그룹 계정 관리 (0) | 2022.02.09 |
01-01-03 시스템 계정 관리 (0) | 2022.02.07 |
01-01-02 루트(root) 계정 관리 (0) | 2022.02.06 |
01-01-01 사용자의 분류 (0) | 2022.02.05 |