Создание пользователя в Unix, Linux

Типы пользователей в Unix

Пользователи хранятся в файле /etc/passwd

more /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/shutdown
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:997:User for polkitd:/:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
chrony:x:998:996::/var/lib/chrony:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
apache:x:48:48:Apache:/usr/share/httpd:/sbin/nologin
ntp:x:38:38::/etc/ntp:/sbin/nologin

Как видно файл /etc/passwd имеет следующую структуру: login : password : UID : GID : GECOS : home : shell.
Пароль хранится в шифрованном виде в файле /etc/shadow
UID - user id. GID - group id. Обычно они совпадают и каждый пользователь состоит в своей собственной группе.
GECOS - любая информация о пользователе, например, телефон.
home - домашний каталог пользователя.
shell - оболочка командной строки.

Добавляем пользователя

Для добавления пользователей используется команда adduser. Пользователя можно добавить и другими командами: useradd, vipw. Но эти способы несколько сложнее.

adduser puzzle
vipw #смотрим что получилось
puzzle:x:1000:1000::/home/puzzle:/bin/bash #всё хорошо, но домашняя директория не та
usermod -md /site/puzzle puzzle #меняем домашнюю директорию
usermod: directory /site/puzzle exists #сообщение, что такая директория уже существует
vipw #смотрим что получилось
puzzle:x:1000:1000::/site/puzzle:/bin/bash #директория изменилась, можно было её и с помощью vipw отредактировать

#но не удалил старую директорию и не перенёс файлы настроек bash

[root@localhost ~]# ls -la /site/puzzle/
total 0
drwxr-xr-x. 4 apache apache 32 Apr  4 19:11 .
drwxr-xr-x. 3 apache apache 20 Apr  4 19:10 ..
drwxr-xr-x. 2 apache apache 41 Apr  4 19:43 logs
drwxr-xr-x. 2 apache apache 24 Apr  8 17:28 public
[root@localhost ~]# ls -la /home/puzzle/
total 12
drwx------. 2 puzzle puzzle  62 Apr 12 11:59 .
drwxr-xr-x. 3 root   root    20 Apr 12 11:59 ..
-rw-r--r--. 1 puzzle puzzle  18 Aug  8  2019 .bash_logout
-rw-r--r--. 1 puzzle puzzle 193 Aug  8  2019 .bash_profile
-rw-r--r--. 1 puzzle puzzle 231 Aug  8  2019 .bashrc

chown puzzle. /site/puzzle/ #меняем права доступа
chown puzzle. /site/puzzle/public/
# обратите внимание, что права logs остаются за веб-сервером, незачем туда писать ничего разработчику сайта и иметь возможность удалить или отредактировать логи

ls -la /site/puzzle/
total 0
drwxr-xr-x. 4 puzzle puzzle 32 Apr  4 19:11 .
drwxr-xr-x. 3 apache apache 20 Apr  4 19:10 ..
drwxr-xr-x. 2 apache apache 41 Apr  4 19:43 logs
drwxr-xr-x. 2 puzzle puzzle 24 Apr  8 17:28 public

mv /home/puzzle/.bash* /site/puzzle/ #переносим настройки shell в новую папку
rmdir /home/puzzle/ #удаляем старую папку


#перенос домашней папки пользователя был показан в ознакомительных целях
#его можно было избежать указав домашнюю папку при создании пользователя
#adduser puzzle -d /home/site

passwd puzzle #задаём пароль

Теперь можно заходить на сервер пользователем puzzle по ssh или редактором, который умеет работать с файлами по sftp.

Телеграмм ITSOFT