Linux学习中

时间函数:

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

  1. passwd [OPTIONS] UserName :修改其他用户修密码
  2. passwd: 修改自己的密码
  3. 常用选项:
    1. -l:锁定用户
    2. -u:解锁用户
    3. -n mindyas:指定最短使用期限
    4. -x maxdyas:最大使用期限
    5. -w marndyas:提前多少天开始警告
    6. -i inacticedays:非活动期限

你可能感兴趣的:(Linux学习中)