Khi chạy lệnh 'useradd' trong terminal Linux sẽ thực hiện các công việc chính sau đây:
Cú pháp cơ bản của lệnh useradd:
# useradd [options] username
Để thêm/tạo một người dùng mới, bạn cần sử dụng lệnh 'useradd' hoặc 'adduser' kèm theo 'tên_người_dùng'. Tên_người_dùng là tên đăng nhập được sử dụng bởi người dùng để đăng nhập vào hệ thống.
Chỉ có thể thêm một người dùng và tên_người_dùng phải là duy nhất (khác với các tên_người_dùng khác đã tồn tại trên hệ thống).
Ví dụ, để thêm một người dùng mới có tên là 'tecmint', sử dụng lệnh sau:
[root@tecmint ~]# useradd tecmint
Khi chúng ta thêm một người dùng mới trong Linux bằng lệnh 'useradd', tài khoản của người dùng sẽ được tạo ở trạng thái khóa. Để mở khóa tài khoản người dùng đó, chúng ta cần đặt mật khẩu cho tài khoản đó bằng lệnh 'passwd'.
# passwd tecmint Changing password for user tecmint. New UNIX password: Retype new UNIX password: passwd: all authentication tokens updated successfully.
Sau khi tạo một người dùng mới, thông tin của người dùng sẽ tự động được thêm vào tệp '/etc/passwd'. Tệp này được sử dụng để lưu trữ thông tin người dùng và mục nhập nên có dạng như sau:
tecmint:x:1000:1000:tecmint:/home/tecmint:/bin/bash
Mục nhập trên bao gồm bảy trường được phân tách bằng dấu hai chấm (:), mỗi trường có ý nghĩa riêng. Hãy xem các trường này là gì:
Mặc định, lệnh 'useradd' tạo thư mục gốc của người dùng dưới thư mục /home với tên người dùng. Ví dụ, như đã thấy ở trên, thư mục gốc mặc định cho người dùng 'tecmint' là '/home/tecmint'.
Tuy nhiên, hành động này có thể thay đổi bằng cách sử dụng tùy chọn '-d' kèm theo địa chỉ của thư mục gốc mới (ví dụ: /data/projects). Ví dụ, câu lệnh sau sẽ tạo một người dùng có tên là 'anusha' với thư mục gốc là '/data/projects'.
# useradd -d /data/projects anusha # passwd anusha
Bạn có thể xem thư mục gốc của người dùng và các thông tin khác về người dùng như user id, group id, shell và bình luận.
# cat /etc/passwd | grep anusha anusha:x:1001:1001::/data/projects:/bin/bash
Trong Linux, mỗi người dùng có một User ID (UID) riêng biệt. Mặc định, khi chúng ta tạo một tài khoản người dùng mới trong Linux, nó sẽ gán các user id là 500, 501, 502 và tiếp tục như vậy...
Nhưng chúng ta có thể tạo người dùng với User ID tùy chỉnh bằng cách sử dụng tùy chọn ‘-u‘. Ví dụ, câu lệnh sau sẽ tạo một người dùng có tên ‘navin‘ với User ID tùy chỉnh là ‘1002‘.
# useradd -u 1002 navin
Bây giờ, hãy xác nhận rằng người dùng đã được tạo với User ID đã xác định (1002) bằng cách sử dụng câu lệnh sau.
# cat /etc/passwd | grep navin navin:x:1002:1002::/home/navin:/bin/bash
LƯU Ý: Hãy đảm bảo giá trị của User ID là duy nhất so với bất kỳ người dùng nào khác đã được tạo trong hệ thống.
Tương tự, mỗi người dùng có một GID (Group Identifier) riêng của họ. Chúng ta cũng có thể tạo người dùng với các Group ID cụ thể bằng cách sử dụng tùy chọn -g.
Ở ví dụ này, chúng ta sẽ thêm một người dùng có tên ‘tarunika‘ với UID và GID cụ thể đồng thời với sự trợ giúp của các tùy chọn ‘-u‘ và ‘-g‘.
# useradd -u 1005 -g tecmint tarunika Bây giờ, hãy xem User ID và Group ID được gán trong tệp ‘/etc/passwd‘.
# cat /etc/passwd | grep tarunika tarunika:x:1005:1000::/home/tarunika:/bin/bash
Để xác nhận GID của người dùng, sử dụng lệnh id:
# id -gn tarunika
Tùy chọn ‘-G‘ được sử dụng để thêm một người dùng vào các nhóm bổ sung. Mỗi tên nhóm được phân tách bằng dấu phẩy, không có khoảng trống.
Ở ví dụ này, chúng tôi đang thêm người dùng ‘tecmint‘ vào nhiều nhóm như admins, webadmin và developers.
# groupadd admins # groupadd webadmin # groupadd developers # usermod -a -G admins,webadmin,developers tecmint # useradd -G admins,webadmin,developers paddy
Tiếp theo, xác nhận rằng người dùng đã được gán vào nhiều nhóm bằng lệnh id.
# id tecmint uid=1000(tecmint) gid=1000(tecmint) groups=1000(tecmint),1007(admins),1008(webadmin),1009(developers) context=root:system_r:unconfined_t:SystemLow-SystemHigh
Trong một số tình huống, chúng ta không muốn gán thư mục gốc cho một người dùng vì lý do bảo mật, như vậy khi một người dùng đăng nhập vào hệ thống vừa khởi động, thư mục gốc của họ sẽ là /root. Nếu người dùng đó sử dụng lệnh su, thư mục đăng nhập của họ sẽ là thư mục gốc của người dùng trước đó.
Để tạo người dùng mà không có thư mục gốc, được sử dụng tùy chọn ‘-M‘. Ví dụ, câu lệnh sau sẽ tạo một người dùng có tên ‘shilpi‘ mà không có thư mục gốc.
# useradd -M shilpi
Bây giờ, hãy xác nhận rằng người dùng đã được tạo mà không có thư mục gốc, sử dụng lệnh ls.
# ls -l /home/shilpi ls: cannot access /home/shilpi: No such file or directory
Mặc định, khi thêm người dùng với câu lệnh ‘useradd‘, tài khoản người dùng không bao giờ hết hạn, tức là ngày hết hạn được đặt thành 0.
Tuy nhiên, chúng ta có thể đặt ngày hết hạn bằng cách sử dụng tùy chọn ‘-e‘, trong định dạng YYYY-MM-DD. Điều này dùng để tạo tài khoản tạm thời trong một khoảng thời gian nhất định.
Ví dụ tạo một người dùng có tên ‘aparna‘ với ngày hết hạn tài khoản là ngày 27 tháng 8 năm 2021.
# useradd -e 2021-08-27 aparna
Tiếp theo, xác nhận tuổi của tài khoản và mật khẩu bằng lệnh ‘chage‘ cho người dùng ‘aparna‘.
# chage -l aparna Last password change : Jun 25, 2021 Password expires : never Password inactive : never Account expires : Aug 27, 2021 Minimum number of days between password change : 0 Maximum number of days between password change : 99999 Number of days of warning before password expires
Đối số ‘-f‘ được sử dụng để xác định số ngày sau khi mật khẩu hết hạn. Giá trị 0 sẽ vô hiệu hóa tài khoản người dùng ngay sau khi mật khẩu hết hạn. Mặc định, giá trị hết hạn mật khẩu được đặt là -1 là không bao giờ hết hạn.
Ví dụ đặt ngày hết hạn mật khẩu là 45 ngày cho người dùng ‘mansi‘ bằng tùy chọn ‘-e‘ và ‘-f‘.
# useradd -e 2014-04-27 -f 45 mansi
Tùy chọn ‘-c‘ cho phép thêm nhận xét tùy chỉnh, như tên đầy đủ của người dùng, số điện thoại, v.v. vào tệp /etc/passwd. Nhận xét được thêm dưới dạng một dòng duy nhất mà không có khoảng trắng.
Ví dụ, câu lệnh sau sẽ thêm một người dùng ‘mansi‘ và chèn tên đầy đủ của người dùng ( Manis Khurana) vào trường nhận xét.
# useradd -c "Manis Khurana" mansi
Bạn có thể xem nhận xét của mình trong tệp ‘/etc/passwd‘ trong phần nhận xét.
# tail -1 /etc/passwd mansi:x:1010:1013:Manis Khurana:/home/mansi:/bin/sh
Thêm người dùng mà không liên quan đến shell đăng nhập hoặc đôi khi cần gán các shell khác nhau cho người dùng. Chúng ta gán các shell đăng nhập khác nhau cho mỗi người dùng bằng tùy chọn ‘-s‘.
Ở ví dụ này, thêm một người dùng ‘tecmint‘ mà không có shell đăng nhập, tức là shell ‘/sbin/nologin‘.
# useradd -s /sbin/nologin tecmint
Bạn kiểm tra shell đã được gán cho người dùng trong tệp ‘/etc/passwd‘.
# tail -1 /etc/passwd tecmint:x:1011:1014::/home/tecmint:/sbin/nologin
Tạo một người dùng có tên 'ravi' với thư mục chủ '/var/www/tecmint', shell mặc định là '/bin/bash' và thêm thông tin bổ sung về người dùng.
# useradd -m -d /var/www/ravi -s /bin/bash -c "TecMint Owner" -U ravi
Trong lệnh trên, tùy chọn '-m -d' tạo một người dùng với thư mục chủ được chỉ định. Tùy chọn '-s' thiết lập shell mặc định của người dùng là '/bin/bash'. Tùy chọn '-c' thêm thông tin bổ sung về người dùng. Đối số '-U' tạo/thêm một nhóm có cùng tên với người dùng.
Xác định shell là '/bin/zsh' và UID/GID tùy chỉnh cho người dùng 'tarunika'. Trong đó, tùy chọn '-u' xác định UID mới cho người dùng (ví dụ: 100), và tùy chọn '-g' xác định GID (ví dụ: 1000).
# useradd -m -d /var/www/tarunika -s /bin/zsh -c "TecMint Technical Writer" -u 1000 -g 100 tarunika
Chúng ta vô hiệu hóa shell đăng nhập cho người dùng có tên 'avishek' với ID người dùng tùy chỉnh (1019).
Tùy chọn ‘-s’ thêm shell mặc định /bin/bash, nhưng trong trường hợp này, đặt shell đăng nhập là ‘/usr/sbin/nologin’. Có nghĩa là người dùng ‘avishek’ sẽ không thể đăng nhập vào hệ thống.
# useradd -m -d /var/www/avishek -s /usr/sbin/nologin -c "TecMint Sr. Technical Writer" -u 1019 avishek
Sự thay đổi duy nhất trong lệnh này là sử dụng tùy chọn ‘-k‘ để đặt thư mục skeleton tùy chỉnh. Ví dụ: /etc/custom.skell, không phải là thư mục mặc định /etc/skel. Chúng ta sử dụng tùy chọn ‘-s‘ để xác định các shell khác nhau. Ví dụ: /bin/tcsh cho người dùng ‘navin‘.
# useradd -m -d /var/www/navin -k /etc/custom.skell -s /bin/tcsh -c "No Active Member of TecMint" -u 1027 navin
Sử dụng tùy chọn ‘-M‘ để tạo một người dùng mà không có thư mục chủ của người dùng. Đối số ‘-N‘ để hệ thống chỉ tạo một tên người dùng (không kèm nhóm). Đối số ‘-r‘ để tạo một người dùng hệ thống.
# useradd -M -N -r -s /bin/false -c "Disabled TecMint Member" clayton
Để biết thêm thông tin và tùy chọn về lệnh useradd, chạy lệnh ‘useradd‘ trên cửa sổ terminal để xem các tùy chọn có sẵn.
# useradd
Mọi người cũng tìm kiếm: ubuntu useradd, lệnh nào cho phép ta tạo một account user mới trên hệ thống, useradd, lệnh tạo user trong linux, useradd linux.
Tips: Tham gia Channel Telegram KDATA để không bỏ sót khuyến mãi hot nào