百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 优雅编程 > 正文

Linux用户管理详解(linux用户管理的含义)

sinye56 2024-11-17 01:34 3 浏览 0 评论

Linux 用户管理详解

Linux 系统的用户管理涉及创建、删除、修改用户和用户组,以及配置权限和访问控制。以下是对 Linux 用户管理的详细讲解,包括基本操作和常用命令。

1. 用户管理

1.1 创建用户

  • 创建一个新用户
sudo useradd username

这会创建一个新的用户,但不会为其创建主目录,也不会设置密码。

  • 创建用户并创建主目录
sudo useradd -m -s /bin/bash username
    • -m:创建用户的主目录。
    • -s:指定用户的默认 shell(如 /bin/bash)。
  • 设置用户密码
sudo passwd username

1.2 删除用户

  • 删除用户
sudo userdel username
  • 删除用户及其主目录
sudo userdel -r username

1.3 修改用户信息

  • 更改用户的默认 shell
sudo usermod -s /bin/zsh username
  • 将用户添加到用户组
sudo usermod -aG groupname username
    • -aG:将用户追加到指定组。
  • 更改用户的家目录
sudo usermod -d /new/home/directory username

1.4 查看用户信息

  • 查看所有用户
cat /etc/passwd
  • 查看特定用户的信息
id username

2. 用户组管理

2.1 创建用户组

  • 创建一个新用户组
sudo groupadd groupname

2.2 删除用户组

  • 删除一个用户组
sudo groupdel groupname

2.3 修改用户组

  • 更改用户组名称
sudo groupmod -n newgroupname oldgroupname

2.4 将用户添加到用户组

  • 将用户添加到现有组
sudo usermod -aG groupname username

2.5 查看用户组信息

  • 查看所有用户组
cat /etc/group
  • 查看用户所在的组
groups username

3. 权限管理

3.1 修改文件和目录所有者

  • 更改文件或目录的所有者和组
sudo chown owner:group filename
    • owner:新的文件所有者。
    • group:新的文件组。

3.2 设置 SUID 和 SGID 权限

  • SUID(Set User ID):使文件以文件所有者的权限运行。
chmod u+s filename
  • SGID(Set Group ID):使文件以文件所在组的权限运行,或使目录内的文件继承目录的组。
chmod g+s directory

3.3 设置 Sticky Bit

  • Sticky Bit:确保只有文件的所有者可以删除文件。
chmod +t directory

4 修改用户密码

4.1 修改当前用户的密码

如果你需要修改当前用户的密码,可以使用 passwd 命令:

passwd

系统会提示你输入当前密码,然后输入新密码。确认新密码后,密码会被更新。

4.2 修改其他用户的密码

如果你是超级用户(root)或具有适当权限的用户,可以修改其他用户的密码。使用以下命令:

sudo passwd username

将 username 替换为你要修改密码的用户名。系统会提示你输入新密码,并要求确认。

4.3 强制用户在下次登录时更改密码

为了增强安全性,可能需要强制用户在下次登录时更改密码。这可以通过设置密码过期策略来实现:

sudo chage -d 0 username

将 username 替换为目标用户名。这将使得用户在下次登录时被要求更改密码。

4.4 查看用户的密码过期信息

你可以查看用户的密码过期信息,了解密码的状态和过期日期:

sudo chage -l username

4.5 设置密码过期策略

你还可以使用 chage 命令设置密码的过期策略,例如设置密码过期时间:

  • 设置密码有效期(以天为单位)
sudo chage -M 30 username

这将设置密码在 30 天后过期。

  • 设置密码过期前的警告期(以天为单位)
sudo chage -W 7 username

这将设置用户在密码过期前 7 天收到警告。


5 禁止用户登录 SSH

在某些情况下,你可能需要禁止某个用户通过 SSH 登录到系统。下面是几种实现这一目标的方法:

5.1 修改 SSH 配置文件

你可以通过编辑 SSH 配置文件来禁止特定用户登录。以下是步骤:

  1. 编辑 SSH 配置文件
sudo nano /etc/ssh/sshd_config
  1. 添加或修改以下行以禁用特定用户
DenyUsers username

将 username 替换为你要禁止登录的用户名。你可以用空格分隔多个用户名。

  1. 保存更改并重新启动 SSH 服务
sudo systemctl restart ssh

5.2 修改用户的 shell

另一种方法是将用户的默认 shell 更改为一个不可登录的 shell(如 /sbin/nologin 或 /bin/false),这会阻止用户登录系统,包括通过 SSH。

  1. 更改用户的 shell
sudo usermod -s /sbin/nologin username

sudo usermod -s /bin/false username

这会使用户无法通过任何方式登录系统。

5.3 更新 /etc/hosts.deny文件

你可以通过更新 /etc/hosts.deny 文件来阻止用户通过 SSH 登录,但这种方法较为少用。

  1. 编辑 /etc/hosts.deny 文件
sudo nano /etc/hosts.deny
  1. 添加以下行
sshd: username

将 username 替换为你要禁止的用户名。

  1. 保存更改

5.4 禁用用户的 SSH 密钥

如果用户使用的是密钥认证,你可以从用户的 authorized_keys 文件中移除相应的公钥。确保你已经知道如何重新获得或替换密钥。

  1. 编辑用户的 authorized_keys 文件
sudo nano /home/username/.ssh/authorized_keys
  1. 删除相关公钥行
  2. 保存更改

6. 用户账户锁定与解锁

6.1 锁定用户账户

锁定账户将禁止用户登录系统,但不删除用户的文件或账户记录。你可以通过以下命令锁定账户:

sudo usermod -L username

6.2 解锁用户账户

要解锁用户账户,使其可以重新登录:

sudo usermod -U username

7 设置账户到期日期

你可以为用户设置账户的有效期,到期后用户将无法登录。

设置账户到期日期

sudo usermod -e YYYY-MM-DD username

将 YYYY-MM-DD 替换为账户过期的日期。

查看账户到期日期

sudo chage -l username

8 监控用户登录

你可以使用一些工具来监控用户的登录情况和历史记录。

查看用户登录历史

last username

查看用户的当前登录

w 或 who


9 管理用户的文件和目录

设置用户的配额

你可以设置用户的磁盘配额来限制用户可以使用的磁盘空间。

  1. 启用配额:编辑 /etc/fstab 文件,确保文件系统的挂载选项包含 usrquota 或 grpquota。
  2. 创建配额数据库
sudo quotacheck -cug /mountpoint
  1. 设置配额
sudo edquota -u username

编辑用户的配额设置,保存更改后生效。

10 设置用户的环境变量

你可以为用户配置环境变量,影响用户会话中的默认设置。

为用户设置环境变量

  1. 编辑用户的 .bashrc.profile 文件
nano /home/username/.bashrc
  1. 添加环境变量
export VAR_NAME=value
  1. 应用更改
source /home/username/.bashrc

11 配置用户的自定义提示符

你可以为每个用户设置个性化的 shell 提示符,增强用户体验。

11.1 编辑用户的 .bashrc 文件

nano /home/username/.bashrc

11.2 添加自定义提示符设置

PS1='[\u@\h \W]\$ '

说明:

  • \u:表示当前用户名。比如,如果你以 john 用户登录,它会显示 john。
  • @:是一个常量字符,用于分隔用户名和主机名。
  • \h:表示当前主机名的短名称(不包括域名部分)。例如,如果你的计算机名称是 mycomputer.local,它会显示 mycomputer。
  • \W:表示当前工作目录的基本名称(即,当前目录的最后一部分)。如果你在 /home/john/projects 目录下,它会显示 projects。
  • \$:表示提示符符号。如果是普通用户,显示 $;如果是超级用户(root),显示 #。

相关推荐

Linux在线安装JDK1.8

首先在服务器pingwww.baidu.com查看是否可以连网然后就可以在线下载一、下载安装JDK1.81、在下载安装的同时做好一些准备工作...

Linux安装JDK,超详细

1、了解RPMRPM是Red-HatPackageManager(RPM软件包管理器)的缩写,这一文件格式名称虽然打上了RedHat的标志,但是其原始设计理念是开放式的,现在包括OpenLinux...

Linux安装jdk1.8(超级详细)

前言最近刚购买了一台阿里云的服务器准备要搭建一个网站,正好将网站的一个完整搭建过程分享给大家!#一、下载jdk1.8首先我们需要去下载linux版本的jdk1.8安装包,我们有两种方式去下载安装...

Linux系统安装JDK教程

下载jdk-8u151-linux-x64.tar.gz下载地址:https://www.oracle.com/technetwork/java/javase/downloads/index.ht...

干货|JDK下载安装与环境变量配置图文教程「超详细」

1.JDK介绍1.1什么是JDK?SUN公司提供了一套Java开发环境,简称JDK(JavaDevelopmentKit),它是整个Java的核心,其中包括Java编译器、Java运行工具、Jav...

Linux下安装jdk1.8

一、安装环境操作系统:CentOSLinuxrelease7.6.1810(Core)JDK版本:1.8二、安装步骤1.下载安装包...

Linux上安装JDK

以CentOS为例。检查是否已安装过jdk。yumlist--installed|grepjdk或者...

Linux系统的一些常用目录以及介绍

根目录(/):“/”目录也称为根目录,位于Linux文件系统目录结构的顶层。在很多系统中,“/”目录是系统中的唯一分区。如果还有其他分区,必须挂载到“/”目录下某个位置。整个目录结构呈树形结构,因此也...

Linux系统目录结构

一、系统目录结构几乎所有的计算机操作系统都是使用目录结构组织文件。具体来说就是在一个目录中存放子目录和文件,而在子目录中又会进一步存放子目录和文件,以此类推形成一个树状的文件结构,由于其结构很像一棵树...

Linux文件查找

在Linux下通常find不很常用的,因为速度慢(find是直接查找硬盘),通常我们都是先使用whereis或者是locate来检查,如果真的找不到了,才以find来搜寻。为什么...

嵌入式linux基本操作之查找文件

对于很多初学者来说都习惯用windows操作系统,对于这个系统来说查找一个文件简直不在话下。而学习嵌入式开发行业之后,发现所用到的是嵌入式Linux操作系统,本想着跟windows类似,结果在操作的时...

linux系统查看软件安装目录的方法

linux系统下怎么查看软件安装的目录?方法1:whereis软件名以查询nginx为例子...

Linux下如何对目录中的文件进行统计

统计目录中的文件数量...

Linux常见文件目录管理命令

touch用于创建空白文件touch文件名称mkdir用于创建空白目录还可以通过参数-p创建递归的目录...

Linux常用查找文件方法总结

一、前言Linux系统提供了多种查找文件的命令,而且每种查找命令都具有其独特的优势,下面详细总结一下常用的几个Linux查找命令。二、which命令查找类型:二进制文件;...

取消回复欢迎 发表评论: