Linux命令——用户和权限相关
文章目录
- 1 用户管理
- 1.1 用户标识符
- 1.2 用户添加
- 1.3 用户删除
- 1.4 用户配置文件
- 1.4.1 passwd文件
- 1.4.2 shadow文件
- 1.4.3 group文件
- 2 密码管理
- 3 权限管理
1 用户管理
1.1 用户标识符
用户标识符主要是UID和GID,UID表示用户id,GID表示用户组id。在登录的时候,我们输入的是用户名,但是系统实际并不识别用户名,而是根据用户名查表,查询到UID,作为用户的唯一标识。
在用户登录的时候,每个登录用户最少都会获取到两个ID,一个是UID,一个就是GID。
与UID和GID相关的是权限的管控,每一个文件都有所属的用户和用户组用以控制文件的访问权限,当我们ls -l需要显示用户和用户组的时候,实际是会根据/etc/passwd与/etc/group的内容找到对应的UID和GID对应的名称,再完成显示。
1.2 用户添加
用户添加使用命令useradd
sudo useradd -m tom
ubuntu上添加用户后不会弹出直接添加密码,需要添加用户后再添加密码
sudo passwd tom
至此,添加用户成功,这里的-m是创建用户主目录,如果不加,则没有用户主目录,会进入根目录
su tom
$
切换到新用户,这里可以看到没有前面的主机名,用户名和目录的显示,这是因为在创建用户的使用没有指定shell,默认使用的是/bin/sh,一般指定为bash
sudo useradd -m -s /bin/bash Bob
一般使用这条命令就可以了
其他useradd的一些参数
用法:useradd [选项] 登录名useradd -Duseradd -D [选项]选项:--badnames do not check for bad names-b, --base-dir BASE_DIR 新账户的主目录的基目录--btrfs-subvolume-home use BTRFS subvolume for home directory-c, --comment COMMENT 新账户的 GECOS 字段-d, --home-dir HOME_DIR 新账户的主目录-D, --defaults 显示或更改默认的 useradd 配置-e, --expiredate EXPIRE_DATE 新账户的过期日期-f, --inactive INACTIVE 新账户的密码不活动期-g, --gid GROUP 新账户主组的名称或 ID-G, --groups GROUPS 新账户的附加组列表-h, --help 显示此帮助信息并退出-k, --skel SKEL_DIR 使用此目录作为骨架目录-K, --key KEY=VALUE 不使用 /etc/login.defs 中的默认值-l, --no-log-init 不要将此用户添加到最近登录和登录失败数据库-m, --create-home 创建用户的主目录-M, --no-create-home 不创建用户的主目录-N, --no-user-group 不创建同名的组-o, --non-unique 允许使用重复的 UID 创建用户-p, --password PASSWORD 加密后的新账户密码-r, --system 创建一个系统账户-R, --root CHROOT_DIR chroot 到的目录-P, --prefix PREFIX_DIR prefix directory where are located the /etc/* files-s, --shell SHELL 新账户的登录 shell-u, --uid UID 新账户的用户 ID-U, --user-group 创建与用户同名的组-Z, --selinux-user SEUSER 为 SELinux 用户映射使用指定 SEUSER--extrausers Use the extra users database
1.3 用户删除
sudo userdel tom
这条命令删除用户,保留用户主目录
sudo userdel -r tom
这条命令删除用户,并删除用户主目录和信箱
userdel的其他参数
用法:userdel [选项] 登录名选项:-f, --force 即使不属于此用户,也强制删除文件-h, --help 显示此帮助信息并退出-r, --remove 删除主目录和信件池-R, --root CHROOT_DIR chroot 到的目录-P, --prefix PREFIX_DIR prefix directory where are located the /etc/* files--extrausers Use the extra users database-Z, --selinux-user 为用户删除所有的 SELinux 用户映射
1.4 用户配置文件
1.4.1 passwd文件
用户添加后会在/etc/passwd中添加一条用户记录
Bob:x:1002:1002::/home/Bob:/bin/bash
Bob:账号名称
x:密码,保存到了/etc/shadow文件中
1002:UID
1002:GID
:这里有一个空的,是用户信息说明栏
/home/Bob:用户主目录
/bin/bash:shell
1.4.2 shadow文件
Bob:$y$j9T$6YPTqUQb3XlMTD0zcGWFY/$rXyBQ2mQndvEBvOcEUllsyxF1sdOcJxi7Mq2GzBxPB6:19729:0:99999:7:::
Bob:用户名
$y$j9T$6YPTqUQb3XlMTD0zcGWFY/$rXyBQ2mQndvEBvOcEUllsyxF1sdOcJxi7Mq2GzBxPB6:加密后的密码
19729:最近修改密码的日期,从1970年1月1日起的天数
0:密码不可被修改的天数
99999:密码需要重新修改的天数
7:密码需要修改期限前的警告天数
:空的,密码过期后的宽限天数
:空的,账号失效日子
:空的,保留
1.4.3 group文件
该文件中保存了用户组相关信息
Bob:x:1002:
Bob:用户组名称
x:用户组密码
1002:GID
:空的,此用户组支持的账号名称
2 密码管理
密码修改和添加
passwd username
第一次添加就是初始化密码,后续就是修改密码
passwd其他参数
用法:passwd [选项] [登录名]选项:-a, --all 报告所有帐户的密码状态-d, --delete 删除指定帐户的密码-e, --expire 强制使指定帐户的密码过期-h, --help 显示此帮助信息并退出-k, --keep-tokens 仅在过期后修改密码-i, --inactive INACTIVE 密码过期后设置密码不活动为 INACTIVE-l, --lock 锁定指定的帐户-n, --mindays MIN_DAYS 设置到下次修改密码所须等待的最短天数为 MIN_DAYS-q, --quiet 安静模式-r, --repository REPOSITORY 在 REPOSITORY 库中改变密码-R, --root CHROOT_DIR chroot 到的目录-S, --status 报告指定帐户密码的状态-u, --unlock 解锁被指定帐户-w, --warndays WARN_DAYS 设置过期警告天数为 WARN_DAYS-x, --maxdays MAX_DAYS 设置到下次修改密码所须等待的最多天数为 MAX_DAYS
3 权限管理
通常都是通过chmod命令来修改用户和用户组权限
语法
chmod [-cfvR] [--help] [--version] mode file...
mode可以有以下参数
[ugoa...][[+-=][rwxX]...][,...]
u:用户
g:用户组
o:其他用户
a:以上的都包含
+:添加
-:删除
=:赋值
r:读权限
w:写权限
x:可执行权限
X:特殊执行权限
实例:
chmod a+x file
给文件的所有用户添加可执行权限
chmod 777 file
file权限为rwxrwxrwx
chmod -R a+x folder
递归修改文件夹权限
chmod user:group file
修改文件的用户和用户组
chmod其他参数
用法:chmod [选项]... 模式[,模式]... 文件...或:chmod [选项]... 八进制模式 文件...或:chmod [选项]... --reference=参考文件 文件...
将每个 <文件> 的模式变更为指定 <模式>。
使用 --reference 时,把每个 <文件> 的模式设置为与 <参考文件> 相同。-c, --changes 类似 verbose 选项,但仅在做出修改时进行报告-f, --silent, --quiet 不显示大多数错误消息-v, --verbose 为每个处理的文件输出一条诊断信息--no-preserve-root 不特殊对待 "/"(默认行为)--preserve-root 不允许在 "/" 上递归操作--reference=参考文件 使用 <参考文件> 的模式而非给定 <模式> 的值-R, --recursive 递归修改文件和目录--help 显示此帮助信息并退出--version 显示版本信息并退出相关文章:
Linux命令——用户和权限相关
文章目录 1 用户管理1.1 用户标识符1.2 用户添加1.3 用户删除1.4 用户配置文件1.4.1 passwd文件1.4.2 shadow文件1.4.3 group文件 2 密码管理3 权限管理 1 用户管理 1.1 用户标识符 用户标识符主要是UID和GID,UID表示用户id,GID表示用户组id。在登录的…...
linux反汇编工具: ida pro、rizinorg/cutter; ubuntu 22 flameshot延迟截图 以应对下拉菜单
rizinorg/cutter rizinorg/cutter 是 命令行反汇编工具 rizinorg/rizin 的图形化界面, 这比 ida pro跑在kvm虚拟机中方便多了, ubuntu22.04下直接下载Cutter-v2.3.2-Linux-x86_64.AppImage后即可运行,如下图: 注意 有个同名的报废品: radare2/Cutter 即 radare2的图形化界…...
【INTEL(ALTERA)】使用NiosV/m 处理器,niosv-download 为什么会失败?
说明 在英特尔 Quartus Prime Pro Edition 软件 23.3 版及更高版本中将 Nios V 处理器软件下载到非流水线Nios V/m 处理器时,可能会出现此问题。 这是由于处理器限制,仅影响非流水线Nios V/m 处理器。 以下其他处理器不受此限制的影响: 管道…...
【无线通信专题】NFC通信模式及可能的应用方式
在文章【无线通信专题】NFC基本原理中我们讲到了NFC工作模式。其中NFC工作模式主要有三种,读写模式、卡模拟模式、点对点模式。 NFC通信模式丰富,NFC Forum定义了三种NFC设备:通用NFCForum设备、读写器设备和标签设备。这些NFC设备可以在三种通信模式下运行,并对应用案例进…...
pyinstaller生成的exe文件启动时间漫长的原因
加-F慢的原因是,pyinstaller把所有资源文件包括python解释器的依赖文件和库都打包到exe一个文件中,用户打开时,pyinstaller需要先执行一边解压操作,把依赖文件全部解压出来。慢就慢在这里。 如果不加-F,你会发现那些文…...
C语言基本语句介绍
c程序的执行部分是由语句组成的。程序的功能也是由执行语句来实现的,c语句分为6类 1表达式语句 表达式语句由表达式加上分号“;”组成 一般形式:表达式; 2函数调用语句 由函数名,实际参数加上分号“;”…...
【QT】QString类型中,Empty和NULL有什么区别在qt里,对比C#
在 Qt 中,QString 类型的字符串使用 isEmpty() 方法来检查字符串是否为空,而不是使用 null。这与 C# 中的 string.IsNullOrEmpty 方法略有不同。 QString::isEmpty(): 用于检查字符串是否为空。一个 QString 对象可能是空字符串,即…...
破壳而出:运维工程师在新科技热潮下的崛起与转型
运维工程师的出路到底在哪里? 在这个飞速发展的数字世界里,运维工程师无疑是IT界冲在最前线的勇士。他们曾是服务器的守护者,他们曾是故障的消灭者,他们曾是性能的推手。然而,随着科技的发展和市场需求的变化…...
静态网页设计——贵州美食(HTML+CSS+JavaScript)
前言 声明:该文章只是做技术分享,若侵权请联系我删除。!! 感谢大佬的视频: https://www.bilibili.com/video/BV1vC4y1K7de/?vd_source5f425e0074a7f92921f53ab87712357b 使用技术:HTMLCSSJS(…...
imgaug库指南(六):从入门到精通的【图像增强】之旅
引言 在深度学习和计算机视觉的世界里,数据是模型训练的基石,其质量与数量直接影响着模型的性能。然而,获取大量高质量的标注数据往往需要耗费大量的时间和资源。正因如此,数据增强技术应运而生,成为了解决这一问题的…...
stable diffusion 人物高级提示词(五)场景、特效、拍摄手法、风格
一、场景 场景Promptindoor室内outdoor室外cityscape城市景色countryside乡村beach海滩forest森林mountain山脉snowfield雪原skyscraper摩天大楼ancient monument古代遗迹cathedral大教堂library图书馆museum博物馆office building办公大楼restaurant餐厅street market街头市场…...
智能分析网关V4智慧港口码头可视化视频智能监管方案
一、需求背景 近年来,水利港口码头正在进行智能化建设,现场管理已经是重中之重。港口作为货物、集装箱堆放及中转机构,具有昼夜不歇、天气多变、环境恶劣等特性,安全保卫工作显得更加重要。港口码头的巡检现场如何高效、快捷地对…...
docker部署kibana
1,简介 官网 kibana 2,安装docker 参考 linux安装docker 3,准备 Kibana 配置文件 # 进入主节点配置文件目录 cd /export/server/docker/kibana/config # 编辑单机版配置文件 vi kibana.ymlkibana.yml内容 # 主机地址,可以是…...
【AI视野·今日CV 计算机视觉论文速览 第283期】Thu, 4 Jan 2024
AI视野今日CS.CV 计算机视觉论文速览 Thu, 4 Jan 2024 Totally 85 papers 👉上期速览✈更多精彩请移步主页 Daily Computer Vision Papers LEAP-VO: Long-term Effective Any Point Tracking for Visual Odometry Authors Weirong Chen, Le Chen, Rui Wang, Marc P…...
sort实现自定义排序方法详解
使用 sort 实现自定义排序 目录 使用 sort 实现自定义排序1.sort 的基本用法2.sort 实现自定义排序3.结构体重载进行比较 1.sort 的基本用法 sort 库函数需要引入头文件algorithm,是一种排序算法,使用的排序逻辑可以看成是效率很高的快速排序或其的改进版本。平均时…...
【攻防世界】Reverse——secret-galaxy-300 writeup
由main函数查看相关代码,但是代码中并没有直接的关于flag的信息: int __cdecl main(int argc, const char **argv, const char **envp) {__main();fill_starbase(&starbase);print_starbase((int)&starbase);return 0; } void __cdecl fill_sta…...
Github Copilot 快速入门
GitHub Copilot 是一个由 GitHub 推出的人工智能编程助手,旨在帮助开发者通过自动代码建议和补全来提高编程效率和质量。作为一个人工智能配对程序员,它能够理解你的代码意图,并提供相关的代码片段,以帮助你更快地编写代码。这种技…...
c# wpf 的触发器,触发器Trigger种类,每个触发器的使用说明
触发器是一种强大的声明性机制,用于根据指定条件更改控件的外观或行为。触发器主要分为以下几种类型: Property Trigger 说明:当绑定到控件某个依赖属性的值发生改变时,Property Trigger会执行预定义的一组设置。例如,…...
计算机毕业设计 SpringBoot的乡村养老服务管理系统 Javaweb项目 Java实战项目 前后端分离 文档报告 代码讲解 安装调试
🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点…...
AMP 通讯RPMsg
参考 RPMsg:协议简介_rpmsg协议-CSDN博客 【软件架构】【通信】S32G IPCF - 知乎 openamp https://www.cnblogs.com/sky-heaven/p/14085800.html virtualIO 虚拟化技术 — VirtIO 虚拟设备接口标准 - 知乎 Virtio-fs介绍与性能优化_guest docker Docker Docs 扫…...
AXI协议实战:如何用写选通优化你的FPGA数据传输(附代码示例)
AXI协议实战:如何用写选通优化你的FPGA数据传输(附代码示例) 在FPGA开发中,AXI协议作为高性能片上总线标准,其写选通(WSTRB)机制常被开发者忽视。实际上,合理运用这一特性可以显著提升数据传输效率…...
手把手教你用Bat_To_ExeConverter制作伪装成jpg的钓鱼exe(红队必备)
红队实战:高级社工钓鱼中的文件伪装技术解析 在网络安全攻防演练中,社会工程学攻击往往是最难防御的一环。作为红队成员,掌握有效的社工钓鱼技巧不仅能提升演练的真实性,更能帮助企业发现安全体系中的薄弱环节。本文将深入探讨一种…...
LAMEJS:革新性浏览器端MP3编码全链路解决方案
LAMEJS:革新性浏览器端MP3编码全链路解决方案 【免费下载链接】lamejs mp3 encoder in javascript 项目地址: https://gitcode.com/gh_mirrors/la/lamejs 在实时音视频通信、在线教育录播、移动端音频创作等场景中,传统音频处理依赖服务器端转码导…...
半导体工程师的生存指南:如何用5分钟搞定跨部门沟通?(含高频术语速查表)
半导体工程师的生存指南:如何用5分钟搞定跨部门沟通?(含高频术语速查表) 在晶圆厂里,最贵的成本不是光刻机折旧费,而是工程师们因为沟通不畅浪费的时间。当PIE工程师说"这个lot需要hold"…...
MinerU效果展示:1.2B小模型如何实现高精度文档语义理解
MinerU效果展示:1.2B小模型如何实现高精度文档语义理解 1. 引言:小模型的大智慧 在AI领域,我们常常被千亿参数的大模型所震撼,但今天要介绍的MinerU却反其道而行——这个仅有1.2B参数的轻量级模型,在文档理解任务上展…...
如何用GDRE Tools解决Godot游戏逆向工程难题?
如何用GDRE Tools解决Godot游戏逆向工程难题? 【免费下载链接】gdsdecomp Godot reverse engineering tools 项目地址: https://gitcode.com/GitHub_Trending/gd/gdsdecomp 场景引入:当你面对已编译的Godot游戏文件 想象这样一个场景:…...
PostgreSQL MCP Server:让 AI 直接读懂你的数据库
PostgreSQL MCP Server:让 AI 直接读懂你的数据库 当 AI 能够用自然语言直接查询数据库,传统开发模式将迎来革命性改变 引言:数据访问的"最后一公里" 在软件开发的世界里,数据库访问一直是技术门槛较高的环节。开发者需…...
解决Seurat Error in FeaturePlot(object = seurat_object, features.plot = id, cols.use = c(“grey“,
背景说明 粉丝的问题如下: FeaturePlot 是 Seurat 包中的一个函数。 在小品文中提到,如果指定参数 do.return = TRUE,它应该返回一个 ggplot2 对象。但这并没有生效。我的目标只是更改图形的标题。对于小提琴图,我可以这样做: VlnPlot(object = seurat_object, featur…...
HUNYUAN-MT 7B在智能客服场景的应用:跨语言客户问询实时解答
HUNYUAN-MT 7B在智能客服场景的应用:跨语言客户问询实时解答 你有没有遇到过这样的情况?公司业务拓展到了海外,客服团队却犯了难。用户用英语、日语、西班牙语发来咨询,客服人员要么看不懂,要么回复得磕磕绊绊&#x…...
模型服务治理:实时口罩检测-通用OpenTelemetry链路追踪接入
模型服务治理:实时口罩检测-通用OpenTelemetry链路追踪接入 1. 项目背景与价值 在当今的AI应用场景中,实时口罩检测已经成为许多公共场所和企业的必备功能。无论是商场入口、办公大楼还是公共交通场所,都需要快速准确地检测人员是否佩戴口罩…...
