时间函数:
Linux 两个时钟,一个是系统中的,一个是硬件的
date
clock
hwclock 硬件时间
-s 以硬件时间为准
-w 以系统时间为准
cal 日历命令
目录相关的命令
cd 改变工作目录的命令
用户的家目录
普通用户的家目录是 /home/用户名
cd ~ 或者 cd 进入家目录
cd ~ 在家目录个当前目录之间进行切换
cd ~USERNAME 进入到次用户的目录
相关的环境变量
pwd
OLDPWD 上一次所在的目录
ls 查看目录
用户登陆信息查看命令
whoami 显示当前登陆的有效用户
who 显示当前登陆的所有回话
w 当前用户回话以及所有的操作
bash基础特征
命令历史
history
环境变量
HISTSIZE 命令历史记录的条数
history -d OFFSET
显示历史命令多少条
history -c
显示所有的历史命令
history + 数字
:显示最近的操作的几条命令
调用历史里的命令
!#
第几条执行的历史命令
!!
上一条命令
!string
最近一条以自定字符串显示的命令
调用上一条命令的最后一个参数: !$
,esc
,.alt+.
不想让别人知道我们运行的命令
控制命令的记录方式
环境变量 HISTCONTROL
ignordups
忽略重复的命令,连续切完全相同
ignorspace
忽略所有以空格开头的命令
ignoreboth
修改环境变量的方式
export HISTCONTROL="ignorspace"//设置变量
注意手动修改的值,只在当前的界面或者链接可以用。
命令补全
bash执行命令
内部命令
外部命令:bash根据PATH环境变量自定义的路径,切自左往右在每个路径搜索自定的文件名。
路径补全
把用户给的字符当作路径的开头,并在指定的上级目录下搜索给定的路径名
命令行展开
~:展开味用户的主目录
{}:可承载一个以逗号分割的列表,并且将其分割成多个路径
/tmp/{a,b}
其实就相当于 /tmp/a
和 /tmp/b
命令的执行结果状态
成功
失败
bash使用特殊变量$?来保存最近一条命令的执行结果:
0表示执行成功
2~255表示执行失败
程序执行有两类结果。
程序的返回值:
程序的运行状态结果:
目录管理类命令
cd pwd ls
mkdir 创建目录是必须存在的,被创建的目录如果存在了,是会报错了!就算是文件会报错
mkdir [opthis] /path/to/somewhere
-p 目录存在也不会报错,如果父目录不存在的话,
-v 显示详细信息
-m 创建目录时候,直接指定权限
rmdir 删除目录
rmdir [options] DIRECTORY
-v 显示删除过程
如果目录不是空的,是不能删除目录的。
tree
:列出目录的结构。
-d 只显示目录
-L level 指定显示的目录层
-P pattern 只显示有指定pattern匹配到的路径
文件查看命令
cat,tac
more,less,tail,head
cat
more
more [OPTION...] FILE
-d 显示命令提升功能
less
less [OPTION] FILE
head
-c # :指定获取钱多少个字节
-n #:指定获取前多少行
-f :查看到文件最后不退出,而是会继续跟踪以后的信息
tail
-c #:指定获取后多少个字节
-n:指定获取后多少行
-f :查看到文件最后不退出,而是会继续跟踪以后的信息
文件时间管理工具
touch
文件:matadata,data
查看文件状态:stat
每一个文件都有三种状态
- access 访问时间,atime
- modify 修改时间,mtime
- change 改变时间 ,ctime
touch [OPTION...] FILE....
touch index.php
-a 只改访问时间
-m只该修改时间
-t 指明改变指定的时间
-c 如果文件不存在,将不会创建文件
touch -m -t 201811131213 index.php
文件管理
cp
cp mv rm
cp [OPTION]... SOURCE DEST
cp [OPTION]... SCOURCE ... DIRECTORY
cp [OPTION]... DIRECTORY SOURCE...
cp SRC DEST
SRC 是被复制的文件
如果 目标不存在
- 新建DEST,并且将SRC的内容填充到DEST
如果存在
- DEST是文件,就会覆盖原来的DEST文件,所以建议用
cp -i
- 如果DEST是目录,就在DEST下面建立一个和SRC同样的文件,并且将内容填写到里面。
cp SRC... DESC
复制多个文件!
如果DESC不存在,目标必须存在,而且还必须是目录才可以,否则一定会报错。
常用选项
- -i:交互式
- -r:递归复制文档里的所有内容
- -a:归档,相当于-dR
mv:移动文件
常用选项
- -i:交互式
- -f:强制
rm 删除
常用选项
- -i:交互
- -f:强制
- -r:递归删除
文本编辑器
nano
全屏编辑器
base的特性(2)
别名(alias)
alias
显示当前所有的别名
alias NAME=‘VALUE’
定义别名NAME,其相当于执行了VALUE命令
值的注意的是,我们用命令定义的别名只是暂时的,如果你想你的别名永久有效的话,是需要在文件的配置文件里改配置文件的。
仅仅对当前用户有效,需要在这里改配置文件~/.bashrc
对所有的用户都有效 /etc/bashrc
撤销别名
unalias [-a] name [name ,....]
glob
bash中用于实现文件名的通配
所谓的统配,你可以理解为正则
ls a*b
查看文件中所有a开头b结尾的文件
3 bash的快捷键
- Ctrl+l:清屏
- Ctrl+a:跳转到文件的开始出
- Ctrl+e:跳转到文件的结尾处
- Ctrl+c:取消命令的执行
- Ctrl+u:删除光标之前的所有内容
- Ctrl+k:删除光标之后的所有内容
4 bash的输入I/O重定向以及管道
读入数据:input
输出数据:output
标准输入:keyborad
标准输出:monitor,1
标准错误输出montor,2
IO重定向:改变标准位置
输出重定向
输出重定向:COMMAND>NEW_POS
,COMMAND>>NEW_POS
- / >:覆盖重定向
- />|:强制覆盖重定向
- / >>:追加重定向
- set -C:禁止将内容 覆盖输出至已有文件中
- set +C:去掉set -C定义的内容
set -C
cat /etc/fstab > /tmp/etc,out
- 2>:覆盖重定向错误的信息流
- 2>>:追加重定向错误信息流
cat /etc/issueee 2> /tmp/issue.txt
标准输和错误信息输出至不同的位置
命令执行成功会输出到
file.out
,如果出现错误的话,会出现在error.out
中
COMMADN > /path/to/file.out 2> /path/to/error.out
合并标准输出和错误输出为同一个数据流进行重定向
- &>
- &>>
命令执行成功,输入到file.out,如果失败,输入到&1
,这里的&1
,其实就是 /path/to/file.out
COMMADN > /path/to/file.out 2>&1
COMMADN > /path/to/file.out 2>>&1
输入重定向:<
tr 转换或者删除字符
如果我指定一个字符集,SET1,并且加上一个特殊选项 OPTION
tr [option] SET1 [SET2]
[mali@bogon ~]$ tr abc ABC
abcAaA
ABCAAA
he;;ew ASdssdc
he;;ew ASdssdC
用户和用户组管理
资源分派
用户分为两种,一个使用来进行认证的,一个是用来授权的
Linux用户:
用户分为管理员(root),管理员的id只有0;
普通用户:id是 165535,普通用户又分为两类,一类是系统用户,一类是登录用户!系统用户是1499,登录用户是500~65535。系统用户是为了守护进程获取资源进行权限分类。登录用户,只是交互式登录。
linux组
- 管理员组:root,0
- 普通组:
- 系统组:1~499
- 普通组:500+
linux上下文:
运行的程序:进程(process)
以进程的发起者的身份运行。也就是说,谁登录的,谁就是进程的发起者。
Linux组的类别:
- 用户的基本组(主组):
- 组名和用户名相同,仅仅包含一个组:私有组
- 用户的附加组(额外组):
Linux 用户和组的相关配置文件
/etc/passwd
:保存用户及其属性信息(:名称、UID、基本组ID等等)
/etc/group
:组及其属性信息
etc/shadow
:用户密码及其相关属性
/etc/gshadow
: 组密码及其相关属性
/etc/password:
name:password:UID:GID:GECOS:directory:shell
用户名:密码:UID:GID:主目录:默认shell
/etc/group
group_name:password:GID:user_list
组名:组密码:GID:以当前组为附加组的用户列表,多个用户用逗号分隔
用户添加
useradd [option] LOGIN
- -u UID : [UID_MIN,UID_MAX],定义在 /etc/login.defs
- -g GID : 指明用户基本所属组,可为组名:也可以是组id
- -c GID : "COMMENT":用户的注释信息
- -d /PATH/TO/HOME_DIR:以指定的路径为家目录
- -s SHELL:指定用户默认shell程序。可用列表再/etc/shell文件中
- -G GROUP1[,GROUPE,...],为用户添加附加组,组必须实现存在
默认值设定:/etc/default/useeradd
文件中
useradd -D
-s SHELL
组添加
组创建:groupadd [OPTION]... group_name
- -g GID:指明GID号:[GID_MIN,GID_MAX]
- -r:创建系统组
用户切换
su [options...] [-] [user [args...]]
- 切换用户的方式:
- su UserName :非登录式切换,不会读取目标用户的配置文件
- su - UserName :非登录式切换,读取目标用户的配置文件
- Note:root 切换其他用户是不需要密码的,但是其他用户互相切换是需要密码的
- 用其他身份执行命令
- su [-] UserName -c 'COMMAND'
- -l:
su -l UserName
相当于su - UserName
给用户添加密码:passwd
- passwd [OPTIONS] UserName :修改其他用户修密码
- passwd: 修改自己的密码
- 常用选项:
- -l:锁定用户
- -u:解锁用户
- -n mindyas:指定最短使用期限
- -x maxdyas:最大使用期限
- -w marndyas:提前多少天开始警告
- -i inacticedays:非活动期限