第一部分:Linux命令行
《Linux命令行与shell脚本编程大全》 第一章:初识Linux shell
《Linux命令行与shell脚本编程大全》 第二章:走进shell
《Linux命令行与shell脚本编程大全》 第三章:基本的bash shell命令
《Linux命令行与shell脚本编程大全》 第四章:更多的bash shell命令
《Linux命令行与shell脚本编程大全》 第五章:使用Linux环境变量
《Linux命令行与shell脚本编程大全》 第六章:理解Linux文件权限
《Linux命令行与shell脚本编程大全》 第七章:管理文件系统
《Linux命令行与shell脚本编程大全》 第八章:安装软件程序
《Linux命令行与shell脚本编程大全》 第九章:使用编辑器
第二部分:shell脚本编程基础
《Linux命令行与shell脚本编程大全》 第十章:构建基本脚本
《Linux命令行与shell脚本编程大全》 第十一章:使用结构化命令
《Linux命令行与shell脚本编程大全》 第十二章:更多的结构化命令
《Linux命令行与shell脚本编程大全》 第十三章:处理用户输入
《Linux命令行与shell脚本编程大全》 第十四章:呈现数据
《Linux命令行与shell脚本编程大全》 第十五章:控制脚本
第三部分:高级shell编程
《Linux命令行与shell脚本编程大全》 第十六章:创建函数
《Linux命令行与shell脚本编程大全》 第十七章:图形化桌面上的脚本编程
《Linux命令行与shell脚本编程大全》 第十八章:初识sed和gawk
《Linux命令行与shell脚本编程大全》 第十九章:正则表达式
《Linux命令行与shell脚本编程大全》 第二十章:sed进阶
《Linux命令行与shell脚本编程大全》 第二十一章:gawk进阶
《Linux命令行与shell脚本编程大全》 第二十二章:使用其他shell
第四部分:高级shell脚本编程主题
《Linux命令行与shell脚本编程大全》 第二十三章:使用数据库
《Linux命令行与shell脚本编程大全》 第二十四章:使用Web
《Linux命令行与shell脚本编程大全》 第二十五章:使用E-mail
《Linux命令行与shell脚本编程大全》 第二十六章:编写脚本实用工具
《Linux命令行与shell脚本编程大全》 第二十七章:shell脚本编程进阶
第六章:理解Linux文件权限
root账户的UID通常是0
Linux系统会为各种各样的功能创建不同系统账户,这样即使攻占了某个服务,系统也不会沦陷
Linux为系统预留了500以下的UID值,普通用户创建账户时,大多数Linux会将500起始的第一个可用UID分配给这个账户(未必适用所有Linux发行版)
/etc/passwd字段包含如下信息
1)登录用户名
2)用户密码
3)用户账户的UID
4)用户账户的GID
5)用户账户的文本描述(称为备注字段)
6)用户HOME目录的位置
7)用户的默认shell
/etc/shadow每条记录有9个字段,包括
1)与/etc/passwd文件中登录名对应的登录名
2)加密后的密码
3)自1970年1月1日(上次修改密码的日期)到当天的天数
4)多少天后才能更改密码
5)多少天后必须更改密码
6)密码过期前提前多少天提醒用户更改密码
7)密码过期后多少天禁用用户账户
8)用户账户被禁用的日期,用自1970年1月1日到当天的天数表示
9)预留字段,给将来使用
添加新用户
useradd
语法:
参数 | 描述 |
-c cmoment | 给新用户添加备注 |
-d home_dir | 为主目录指定一个名字(如果不想用登录名作为主目录) |
-D | 创建新用户时的默认值 |
-e expire_date | 用YYYY-MM-DD格式指定一个账户过期的日期 |
-f inactive | 指定这个账户密码过期后多少天这个账户被禁用;0表示密码一过期就立即禁用,-1表示禁止这个功能 |
-g initial_group | 指定用户登录组的GID或组名 |
-G group | 指定用户除登录之外所属的一个或多个附加组 |
-k | 必须和-m一起使用,将/etc/skel目录内容复制到用户的HOME目录 |
-m | 创建用户的HOME目录 |
-M | 不创建用户的HOME目录(当默认设置里指定创建时,才用到) |
-n | 创建一个同用户登录名同名的新组 |
-r | 创建系统账户 |
-p passwd | 为用户账户指定默认密码 |
-s shell | 指定默认的登录shell |
-u uid | 为账户指定一个唯一的UID |
$ useradd -D
GROUP=100
HOME=/home
INACTIVE=-1
EXPIRE=
SHELL=/bin/sh
SKEL=/etc/skel
CREATE_MAIL_SPOOL=no
其中的SKEL说明
userad允许用户创建一个默认的HOME目录配置,以SKEL指定的目录下文件作为模板,自动在每个新用户HOME中放置
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
useradd -D加如下参数可以修改默认的系统新用户值
参数 | 描述 |
-b default_home | 更改默认的创建用户HOME目录的位置 |
-e expiration_date | 更改默认的新账户过期的日期 |
-f inactive | 更改默认的新用户从密码过期到账户被禁用的天数 |
-g group | 更改默认的组名称或GID |
-s shell | 更改默认的登录shell |
useradd -D -s /bin/tcsh
删除用户
userdel
默认只会删除/etc/passwd文件中的用户信息,而不会删除用户的任何文件
-r:删除用户的HOME目录及mail目录
修改用户
用户账户修改工具
命令 | 描述 |
usermod | 修改用户账户的字段,并可以指定主要组以及附加组的所属关系 |
passwd | 修改已有用户的密码 |
chpasswd | 从文件中读取登录名密码对,并更新密码 |
chage | 修改密码的过期日期 |
chfn | 修改用户账户的备注信息 |
chsh | 修改用户账户的默认登录shell |
usermod
-c:修改备注字段
-e:修改过期日期
-g:修改默认的登录组
-l:修改用户账户的登录名
-L:锁定账户,用户无法登录
-p:用来修改账户密码
-U:解除锁定
passwd、chpasswd
passwd用来修改密码,-e用来强制用户下次登录的时候再次修改密码
chpasswd可以批量导入用户密码,从标准输入读取数据
chsh、chfn、chage
chsh用来修改默认的用户登录shell
使用时必须是全路径,不能使用shell名
chfn用来修改/etc/passwd备注字段
chfn会将Unix的finger命令用到的信息存入备注字段
chfn不加参数时,会询问你要存进备注字段的值
(出于安全性考虑,很多Linux管理员禁用finger)
chage用来帮助管理用户账户的有效期
参数 | 描述 |
-d | 设置上次修改密码到现在的天数 |
-E | 设置密码过期的日期(可用来创建临时账户,但是过期之后账户信息还在,类似锁定) |
-I | 设置密码过期到锁定账户的天数 |
-m | 设置修改密码之间最少要多少天 |
-W | 设置密码过期前多久开始出现提醒信息 |
chage命令设置日期的格式
1.YYYY-MM-DD
2.从1970年1月1日起到该日期天数的数值
使用Linux组
有些Linux发行版会创建一个组,把所有用户都当成这个组的成员(这种情况要小心)
有些发行版会为每个用户创建一个单独的组,这样更安全(例如Ubuntu)
每个组都有一个唯一的GID和组名
/etc/group格式
组名、组密码、GID、属于改组的用户列表
千万不能直接修改/etc/group来添加用户到一个组,应使用usermod
列表中有些组并没有列出用户,这并不意味着这些组没有成员。
当一个用户在/etc/passwd中指定某个组作为默认组时,用户账户不会作为该组成员出现在/etc/group中
创建新组
groupadd
group shared
默认没有属于该组成员,groupadd命令没有提供将用户添加到组的选项
usermod
usermod -G shared rich
添加rich用户到shared组中
-G:只是添加组到用户中,不影响默认组
-g:添加组到用户中,并且替换默认组
(如果更改了以登录的用户所属的组,用户重新登录后才会生效)
修改组
groupmod
可以修改已有组的GID或组名
-n:修改组名(可以随意更改,而不会影响安全性)
-g:修改已有组的GID
理解文件权限 (参见#1 )
默认文件权限
umask(参见#1 )
改变安全性设置
改变权限
chmod(参见#1 )
符号模式权限
[ugoa][+-=][rwxXstugo...]
第一个选项定义了权限作用的对象
u:代表用户
g:代表组
o:代表其他
a:代码上述所有
最后的选项代表作用到设置上的权限
X:如果对象是目录或者它已有执行权限,赋予执行权限
s:运行时重新设置UID或者GID
t:保留文件或目录
u:将权限设置为跟属主一样
g:将权限设置为跟属组一样
o:将权限设置为跟其他用户一样
改变所属关系
chown
用来改变文件的默认属组
可用登录名或UID来指定属组
语法:
chown options owner [.group ] file
可同时改变文件的属主和属组
共享文件
Linux为每个文件和目录存储了3个额外的信息位
设置用户ID(SUID):当文件被用户使用时,程序会以文件属主的权限运行
设置组ID(SGID):对文件来说,程序会以文件属组的权限运行;对目录来说,目录中创建的新文件会以目录的默认属组作为默认属组
粘着位:进程结束后文件还会在内存中
SGID可通过chmod设置,加到标准3位八进制值之前,或者在符号模式下用符号s
八进制值 | 描述 |
0 | 所有位都清零 |
1 | 粘着位置位 |
2 | SGID位置位 |
3 | SGID位和粘着位都置位 |
4 | SUID位置位 |
5 | SUID位和粘着位都置位 |
6 | SUID位和SGID位都置位 |
7 | 所有位都置位 |
共享目录步骤:
创建目录
改变目录的默认属组
设置SGID
所有组成员都需要把他们的umask值设置成文件对属组成员可写
1.《Unix & Linux 大学教程》 - 第二十五章 文件操作
转贴请保留以下链接
本人blog地址
相关推荐
本文档是一份针对Shell脚本调试的学习笔记,详细介绍了几种常见的调试方法和工具,帮助运维人员快速定位并修复脚本中的问题。 首先,需要了解的是Linux与Windows在文本文件行结束标志上的差异。在Linux系统中,文本...
通过深入学习"Unix Shell编程第三版笔记",你将能够编写出高效的自动化脚本,提高工作效率,解决日常的系统管理和开发问题。同时,对Unix Shell的熟练掌握也是成为高级系统管理员或全栈开发者的必备技能之一。
学习Linux的推荐书籍有《鸟哥的Linux私房菜》、《Linux命令行与shell脚本编程大全》、《Linux系统管理技术手册》等,这些书籍可以帮助读者深入理解Linux系统,并提供丰富的实践指导。 6. Linux视频教程第1讲:基础...
### Shell脚本编程知识点概述 #### 一、预备知识与基本概念 在开始Shell脚本文档的学习之前,首先需要理解Shell脚本的基本概念及其在Linux/Unix环境中的作用。Shell是一种命令行解释器,用于执行用户输入的命令,...
Linux Shell是Linux操作系统中的一种命令解释器,它允许用户通过命令行界面与系统进行交互,执行各种系统操作。本文档《Linux Shell从入门到精通》是作者李振良基于个人经验整理的一份全面教程,旨在帮助读者从零...
Linux 学习笔记是 Linux 学习的详细笔记整理,分九章,涵盖了 vim 和 vi 编辑器、实用指令、组管理和权限管理、crond 任务调度、Linux 磁盘分区挂载、网络配置、进程管理、服务管理、shell 编程等内容。 1. vi 和 ...
4. "ule_06.txt" - 可能介绍了第六单元的Shell脚本编程,包括基本的Shell命令,变量、条件语句、循环结构、函数定义以及如何编写自动化任务脚本。 5. "ule_9.txt" - 可能是第九单元,可能讨论了网络配置和管理,...
八、shell脚本编程 编写shell脚本可以自动化重复任务,例如: - 变量、运算符和条件判断。 - 函数定义。 - 循环结构。 - 输入输出重定向。 九、系统管理 - sysctl:调整系统内核参数。 - logrotate:日志文件轮换。...
* Linux 的 Shell 编程:Shell 是 Linux 的命令行接口,提供了交互式的命令行环境 三、Linux 文件系统 * 文件类型:普通文件、目录文件、链接文件、设备文件等 * 文件权限:所有者、群组、其他用户的读写执行权限 ...
Shell学习笔记 Shell是一种强大的命令行解释器,广泛应用于Linux和Unix系统中。它允许用户通过命令行接口执行系统任务、管理文件和编写自动化脚本。在Shell中,学习和理解变量的使用是基础,因为它们是存储数据和...
6. **Shell脚本编程**:Bash Shell是Linux最常用的Shell,学习编写简单的Shell脚本可以帮助自动化日常任务。了解变量、条件语句、循环结构以及函数的使用。 7. **系统服务与初始化系统**:了解Systemd,它是现代...
这些只是Linux学习笔记的一部分,完整的笔记还包括更多关于文件系统操作、权限管理、进程控制、网络配置、脚本编程等多个方面的内容。掌握这些基础技能是成为Linux运维人员的必备条件,通过不断的实践和学习,可以更...
Shell编程是Linux操作系统中的一种命令解释器,它允许用户通过命令行与系统进行交互,执行各种操作。在《shell编程从入门到精通》一书中,作者张昊详细讲解了shell编程的基础知识。以下是对该书内容的部分总结: 1....
1. **shell编程**:讲解Bash shell和其他Unix shell的基本语法,包括命令行参数、环境变量、重定向、管道和脚本编写等。 2. **进程管理**:介绍进程创建(fork和exec)和进程通信(管道、套接字、信号、共享内存、...
8. **Linux必学的重要命令教程**:Linux命令行是日常操作的核心,这份教程可能包含如ls、cd、mkdir、cp、mv、grep、sed、awk等常用命令的详解和实例,帮助初学者快速掌握Linux基本操作。 通过这些资源的学习,你...
【LINUX学习笔记】 在深入理解Linux操作系统的过程中,掌握Shell编程是至关重要的。Shell作为操作系统与用户交互的接口,能够解析并执行用户输入的命令。通过编写Shell脚本,我们可以定制化系统的行为,实现自动化...
Shell是Linux操作系统中的一个命令解释器,同时也是一种编程语言,它使得用户可以通过命令行与系统进行交互。在Linux课程中,我们学习了shell的不同启动方式、shell脚本的基本元素以及变量和运算符的使用。 1. **...
在Linux系统中,Shell是一种命令解释器,它允许用户通过命令行与操作系统交互。学习Linux Shell编程不仅可以提高日常工作效率,还能让你更好地理解和控制系统的运行。本篇笔记主要总结了Linux Shell编程的一些关键点...
"蛤蟆PYTHON脚本学习笔记二基本命令畅玩"这个压缩包文件,显然是一个关于Python编程初学者的学习资料,旨在帮助读者掌握Python的基础命令。在这个笔记中,我们可以期待涵盖以下关键知识点: 1. **Python安装**:...
而脚本文件则是将代码写入一个以.py结尾的文件中,可以通过命令行直接执行这些文件,类似于Shell脚本。此外,还可以设置脚本文件为可执行文件,通过在文件顶部指定Python解释器路径来实现。 6. Python文件操作和...