Создание пользователя в Unix, Linux
Типы пользователей в Unix
- веб-разработчик;
- сервис (apache, ftp)
- почтовый ящик, уже давно не используется
Пользователи хранятся в файле /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.