Linux基本命令

目录

1.head命令

2.which命令

3.whereis命令

4.locate命令

5.find命令

6.chmod命令

7.chown命令

8.tar命令

9.date命令

10.cal命令

11.grep命令

12.ps命令

13.kill命令


1.head命令

作用:用于查看文件的开头部分的内容,有一个常用的参数 -n 用于显示行数,默认为 10,即显示 10 行的内容

      语法:head [参数] [文件]

参数参数描述
-q隐藏文件名
-v显示文件名
-c<数目>显示的字节数
-n<行数>显示的行数
  (1)显示 1.log 文件中前 5 行

 [root@localhost ~]# head 1.log -n 5

(2)显示 1.log 文件前 20 字节  

(3)显示 1.log最后 10 行

:tail 命令,查看文件的末尾

2.which命令

在 linux 要查找某个命令或者文件,但不知道放在哪里了,可以使用下面的一些命令来搜索

which     查看可执行文件的位置。
whereis   查看文件的位置。
locate    配合数据库查看文件位置。
find      实际搜寻硬盘查询文件名称

 which 作用:用于查找文件(which指令会在环境变量$PATH设置的目录里查找符合条件的文件。)

语法:which [文件...]

参数参数描述
-n<文件名长度>指定文件名长度,指定的长度必须大于或等于所有文件中最长的文件名
-p<文件名长度>与-n参数相同,但此处的<文件名长度>包括了文件的路径
-w指定输出时栏位的宽度
-V显示版本信息
 
(1)查看 ls 命令是否存在,执行哪个
    [root@localhost ~]#   which ls
alias ls='ls --color=auto'
        /usr/bin/ls
 
(2)查看当前 PATH 配置
   [root@localhost ~]#
echo $PATH
/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin

    

3.whereis命令

whereis  命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件     (参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。
whereis locate 都是基于系统内建的数据库进行搜索,因此效率很高,
而find则是遍历硬盘查找文件

       作用:用于查找文件

        语法:whereis [-bfmsu][-B <目录>...]-M <目录>...][-S <目录>...][文件...]

命令参数: 

参数参数描述
-b定位可执行文件
-B<目录>只在设置的目录下查找可执行文件
-f不显示文件名前的路径名称
-m定位帮助文件
-M<目录>只在设置的目录下查找说帮助文件
-s定位源代码文件
-S<目录>只在设置的目录下查找源代码文件
-u搜索默认路径下除可执行文件、源代码文件、帮助文件以外的其它文件
        (1)找查locate相关的程序文件
  [root@localhost ~]#  whereis   locate
locate: /usr/bin/locate /usr/share/man/man1/locate.1.gz


        2)查找 locate 的源码文件
           [
root@localhost ~]# whereis -s locate
        

4.locate命令

locate

需要注意这个命令在我们的最小mini系统里面是没有安装的

[root@localhost ~]# yum install mlocate
...省略...
[root@localhost ~]# updatedb

作用:用于查找符合条件的文档,他会去保存文档和目录名称的数据库内,查找合乎范本样式条件的文档或目录

语法:locate [-d ][--help][--version][范本样式...]

命令参数:

参数参数描述
-b仅匹配路径名的基本名称
-c只输出找到的数量
-d使用 DBPATH 指定的数据库,而不是默认数据库 /var/lib/mlocate/mlocate.db
-e仅打印当前现有文件的条目
-1如果 是 1.则启动安全模式。在安全模式下,使用者不会看到权限无法看到 的档案。 这会始速度减慢,因为 locate 必须至实际的档案系统中取得档案的 权限资料
-0在输出上带有NUL的单独条目
-S不搜索条目,打印有关每个数据库的统计信息
-q安静模式,不会显示任何错误讯息
-P检查文件存在时不要遵循尾随的符号链接
-l将输出(或计数)限制为LIMIT个条目
-n至多显示 n个输出
-m被忽略,为了向后兼容
-rREGEXP -- 使用基本正则表达式
--regex使用扩展正则表达式
-o指定资料库存的名称
-h显示帮助
-i忽略大小写
-V显示版本信息

常用参数:

参数参数描述
-lnum(要显示的行数)
-f将特定的档案系统排除在外,如将proc排除在外
-r使用正则运算式做为寻找条件

1)查找和 pwd 相关的所有文件(文件名中包含 pwd)

[root@localhost ~]# locate pwd
/etc/.pwd.lock
/usr/bin/pwd
...省略...

(2)搜索 etc 目录下所有以 sh 开头的文件

[root@localhost ~]# locate /etc/sh
/etc/shadow
/etc/shadow-
/etc/shells

(3)查找 /root 目录下,以 sh 结尾的文件

 [root@localhost ~]# locate -r '^/root.*sh$'
/root/test.sh

5.find命令

find

作用:用于在文件树中查找文件,并作出相应的处理

语法:

find [-H] [-L] [-P] [-Olevel] [-D help|tree|search|stat|rates|opt|exec] [path...] [expression]

命令参数:

参数参数描述
pathnamefind命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录
-printfind命令将匹配的文件输出到标准输出
-execfind命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为'command' { } \;,注意{ }和\;之间的空格
-ok和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行

命令选项:

选项选项描述
-name按照文件名查找文件
-perm按文件权限查找文件
-user按文件属主查找文件
-group按照文件所属的组来查找文件
-type查找某一类型的文件,诸如: b - 块设备文件 d - 目录 c - 字符设备文件 l - 符号链接文件 p - 管道文件 f - 普通文件

来看例子

(1)查找 48 小时内修改过的文件

[root@localhost ~]# find -atime -2
.
./.bash_logout
./.bash_profile
./.bashrc
./.cshrc
./.tcshrc
./anaconda-ks.cfg
./.bash_history
./1.log
./lohs8.log
./test3

 (2)在当前目录查找 以 .log 结尾的文件。 . 代表当前目录

[root@localhost ~]# find ./ -name '*.log'
./1.log
./lohs8.log
 

6.chmod命令

        Linux/Unix 的文件调用权限分为三级 : 文件拥有者、群组、其他。


用于改变 linux 系统文件或目录的访问权限。用它控制文件或目录的访问权限。该命令有两种用法。一种是包含字母和操作符表达式的文字设定法;另一种是包含数字的数字设定法。

每一文件或目录的访问权限都有三组,每组用三位表示,分别为文件属主的读、写和执行权限;与属主同组的用户的读、写和执行权限;系统中其他用户的读、写和执行权限。可使用 ls -l test.txt 查找

[root@localhost ~]# ll
总用量 20
-rw-------. 1 root root 1437 8月  31 15:54 anaconda-ks.cfg
-rw-r--r--. 1 root root    0 9月   8 18:29 file1
lrwxrwxrwx. 1 root root   15 9月   7 16:31 link_text2 -> mydir/text2.log
drwxr-xr-x. 4 root root   92 9月   7 18:08 mydir
-rw-r--r--. 1 root root   13 9月   8 16:35 myfile
-rw-r--r--. 1 root root   36 9月   9 13:16 test3
-rw-r--r--. 1 root root   36 9月   8 18:36 test.log
-rwxr-xr-x. 1 root root   67 9月   8 18:36 test.sh

这里使用test.log作为例子


-rw-r--r--. 1 root root   36 9月   8 18:36 test.log

第一列共有 10 个位置,
第一个字符指定了文件类型。
在通常意义上,一个目录也是一个文件。如果第一个字符是横线,表示是一个非目录的文件。
如果是 d,表示是一个目录。
从第二个字符开始到第十个 9 个字符,3 个字符一组,分别表示了 3 组用户对文件或者目录的权限。
权限字符用横线代表空许可,r 代表只读,w 代表写,x 代表可执行

语法:

chmod [-cfvR] [--help] [--version] mode file...

常用参数:

参数参数描述
-c当发生改变时,报告处理信息
-R处理指定目录以及其子目录下所有文件

权限范围:

u :目录或者文件的当前的用户
g :目录或者文件的当前的群组
o :除了目录或者文件的当前用户或群组之外的用户或者群组
a :所有的用户及群组

权限代号:

代号代号权限
r读权限,用数字4表示
w写权限,用数字2表示
x执行权限,用数字1表示
-删除权限,用数字0表示
s特殊权限

环境:-rw-r--r--. 1 root root   36 9月   8 18:36 test.log

(1)增加文件 test.log 所有用户可执行权限

[root@localhost ~]# ls -n test.log
-rwxr-xr-x. 1 0 0 36 9月   8 18:36 test.log

(2)撤销原来所有的权限,然后使拥有者具有可读权限,并输出处理信息

[root@localhost ~]# chmod u=r test.log -c
mode of "test.log" changed from 0755 (rwxr-xr-x) to 0455 (r--r-xr-x)
[root@localhost ~]# ls -n test.log
-r--r-xr-x. 1 0 0 36 9月   8 18:36 test.log 

7.chown命令

chown 将指定文件的拥有者改为指定的用户或组,
用户可以是用户名或者用户 ID;
组可以是组名或者组 ID;文件是以空格分开的要改变权限的文件列表,支持通配符  


注意:一般来说,这个指令只有是由系统管理者(root)所使用,一般使用者没有权限可以改变别人的文件拥有者,也没有权限把自己的文件拥有者改设为别人。只有系统管理者(root)才有这样的权限。

常用参数:

参数参数描述
user新的文件拥有者的使用者 ID
group新的文件拥有者的使用者组(group)
-c显示更改的部分的信息
-f忽略错误信息
-h修复符号链接
-v显示详细的处理信息
-R处理指定目录以及其子目录下的所有文件
--help显示辅助说明
--version显示版本

           (1)改变拥有者和群组 并显示改变信息

 [root@localhost ~]# chown -c tyf:tyf 1.log 
changed ownership of "1.log" from root:root to tyf:tyf
[root@localhost ~]# ll
总用量 8
-r--r--r--. 1 tyf  tyf  2075 3月  18 17:08 1.log
-rw-------. 1 root root 1416 3月  18 10:50 anaconda-ks.cfg
-rw-r--r--. 1 root root    0 3月  18 18:32 lohs8.log
-r--r--r--. 1 tyf  tyf     0 3月  18 18:32 test3

(2)改变文件群

 [root@localhost ~]# chown -c :tyf 1.log 
changed ownership of "1.log" from tyf:mail to :tyf
[root@localhost ~]# ll
总用量 8
-r--r--r--. 1 tyf  tyf  2075 3月  18 17:08 1.log
-rw-------. 1 root root 1416 3月  18 10:50 anaconda-ks.cfg
-rw-r--r--. 1 root root    0 3月  18 18:32 lohs8.log
-r--r--r--. 1 tyf  tyf     0 3月  18 18:32 test3

8.tar命令

用来压缩和解压文件。tar 本身不具有压缩功能,只具有打包功能,有关压缩及解压是调用其它的功能来完成。

弄清两个概念:打包和压缩。打包是指将一大堆文件或目录变成一个总的文件;压缩则是将一个大的文件通过一些压缩算法变成一个小文件

                    作用:用于备份文件(tar是用来建立,还原备份文件的工具程序,它可以加入,解开备份文件内的文件)

          语法

                tar [-ABcdgGhiklmMoOpPrRsStuUvwWxzZ][-b <区块数目>][-C <目的目录>][-f <备份文件>][-F <Script文件>][-K <文件>][-L <媒体容量>][-N <日期时间>][-T <范本文件>][-V <卷册名称>][-X <范本文件>][-<设备编号><存储密度>][--after-date=<日期时间>][--atime-preserve][--backuup=<备份方式>][--checkpoint][--concatenate][--confirmation][--delete][--exclude=<范本样式>][--force-local][--group=<群组名称>][--help][--ignore-failed-read][--new-volume-script=<Script文件>][--newer-mtime][--no-recursion][--null][--numeric-owner][--owner=<用户名称>][--posix][--erve][--preserve-order][--preserve-permissions][--record-size=<区块数目>][--recursive-unlink][--remove-files][--rsh-command=<执行指令>][--same-owner][--suffix=<备份字尾字符串>][--totals][--use-compress-program=<执行指令>][--version][--volno-file=<编号文件>][文件或目录...]

命令参数:

参数参数描述
-c建立新的压缩文件
-f定压缩文件
-r添加文件到已经压缩文件包中
-u添加改了和现有的文件到压缩包中
-x从压缩包中抽取文件
-t显示压缩文件中的内容
-z支持gzip压缩
-j支持bzip2压缩
-Z支持compress解压文件
-v显示操作过程

                  有关 gzip 及 bzip2 压缩:

 gzip 实例:压缩 gzip fileName .tar.gz 和.tgz  解压:gunzip filename.gz 或 gzip -d filename.gz
          对应:tar zcvf filename.tar.gz     tar zxvf filename.tar.gz

bz2实例:压缩 bzip2 -z filename .tar.bz2 解压:bunzip filename.bz2或bzip -d filename.bz2
       对应:tar jcvf filename.tar.gz         解压:tar jxvf filename.tar.bz2 

                 (1)将test.log test.sh全部打包成 tar 包  

[root@localhost ~]# [root@localhost ~]# tar -cvf log.tar test.log  test.sh
test.log
test.sh

                   (3)查看刚打包的文件内容(一定加z,因为是使用 gzip 压缩的)

[root@localhost ~]# tar -ztvf ./etc.tar.gz

9.date命令

   **作用:**用来显示或设定系统的日期与时间

​           **语法:**

date [-u] [-d datestr] [-s datestr] [--utc] [--universal] [--date=datestr] [--set=datestr] [--help] [--version] [+FORMAT] [MMDDhhmm[[CC]YY][.ss]]

时间参数

参数描述参数
%印出 %
%n下一行
%t跳格
%H小时(00..23)
%I小时(01..12)
%k小时(0..23)
%l小时(1..12)
%M分钟(00..59)
%p显示本地 AM 或 PM
%r直接显示时间 (12 小时制,格式为 hh:mm:ss [AP]M)
%s从 1970 年 1 月 1 日 00:00:00 UTC 到目前为止的秒数
%S秒(00..61)
%T直接显示时间 (24 小时制)
%X相当于 %H:%M:%S
%Z显示时区

日期参数

参数描述参数
%a星期几 (Sun..Sat)
%A星期几 (Sunday..Saturday)
%b月份 (Jan..Dec)
%B月份 (January..December)
%c直接显示日期与时间
%d日 (01..31)
%D直接显示日期 (mm/dd/yy)
%h同 %b
%j一年中的第几天 (001..366)
%m月份 (01..12)
%U一年中的第几周 (00..53) (以 Sunday 为一周的第一天的情形)
%w一周中的第几天 (0..6)
%W一年中的第几周 (00..53) (以 Monday 为一周的第一天的情形)
%x直接显示日期 (mm/dd/yy)
%y年份的最后两位数字 (00.99)
%Y完整年份 (0000..9999)

若是不以加号作为开头,则表示要设定时间,而时间格式为 MMDDhhmm[[CC]YY][.ss],其中 MM 为月份,DD 为日,hh 为小时,mm 为分钟,CC 为年份前两位数字,YY 为年份后两位数字,ss 为秒数。

使用权限:所有使用者。

当您不希望出现无意义的 0 时(比如说 1999/03/07),则可以在标记中插入 - 符号,比如说 date '+%-H:%-M:%-S' 会把时分秒中无意义的 0 给去掉,像是原本的 08:09:04 会变为 8:9:4。另外,只有取得权限者(比如说 root)才能设定系统时间。

当您以 root 身分更改了系统时间之后,请记得以 clock -w 来将系统时间写入 CMOS 中,这样下次重新开机时系统时间才会持续抱持最新的正确值。

10.cal命令

作用:用户显示公历(阳历)日历

语法:cal [选项] [[[日] 月] 年]

参数参数描述
-1只显示当前月份(默认)
-3显示上个月、当月和下个月
-s周日作为一周第一天
-m周一用为一周第一天
-j输出儒略日
-y输出整年
-V显示版本信息并退出
-h显示此帮助并退出

(1)显示指定年月日期

[root@localhost ~]# cal 9 2020

(2)显示2020年每个月日历

[root@localhost ~]# cal -y 2020

(3)将星期一做为第一列,显示前中后三月

[root@localhost ~]# cal -3m

11.grep命令

11、grep命令

grep

强大的文本搜索命令,grep(Global Regular Expression Print) 全局正则表达式搜索

grep 的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到标准输出,不影响原文件内容

作用:用于查找文件里符合条件的字符串

注意:如果发现某文件的内容符合所指定的范本样式,预设 grep 指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为 **-**,则 grep 指令会从标准输入设备读取数据

语法:

grep [option] pattern file|dir

常用参数:

参数参数描述
-A n显示匹配字符后n行
-B n显示匹配字符前n行
-C n显示匹配字符前后n行
-c计算符合样式的列数
-i忽略大小写
-l只列出文件内容符合指定的样式的文件名称
-f从文件中读取关键词
-n显示匹配内容的所在文件中行数
-R递归查找文件夹

grep 的规则表达式

^               #锚定行的开始 如:'^grep'匹配所有以grep开头的行。 
$               #锚定行的结束 如:'grep$'匹配所有以grep结尾的行。 
.               #匹配一个非换行符的字符 如:'gr.p'匹配gr后接一个任意字符,然后是p。  
*               #匹配零个或多个先前字符 如:'*grep'匹配所有一个或多个空格后紧跟grep的行。
.*              #一起用代表任意字符。  
[]              #匹配一个指定范围内的字符,如'[Gg]rep'匹配Grep和grep。 
[^]             #匹配一个不在指定范围内的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一个字母开头,紧跟rep的行。  
\(..\)          #标记匹配字符,如'\(love\)',love被标记为1。   
\<              #锚定单词的开始,如:'\<grep'匹配包含以grep开头的单词的行。
\>              #锚定单词的结束,如'grep\>'匹配包含以grep结尾的单词的行。
x\{m\}          #重复字符x,m次,如:'0\{5\}'匹配包含5个o的行。 
x\{m,\}         #重复字符x,至少m次,如:'o\{5,\}'匹配至少有5个o的行。  
x\{m,n\}        #重复字符x,至少m次,不多于n次,如:'o\{5,10\}'匹配5--10个o的行。  
\w              #匹配文字和数字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零个或多个文字或数字字符,然后是p。  
\W              #\w的反置形式,匹配一个或多个非单词字符,如点号句号等。  
\b              #单词锁定符,如: '\bgrep\b'只匹配grep。

(1)查找指定进程

[root@localhost ~]# ps -ef | grep svn
root       6771   9267  0 15:17 pts/0    00:00:00 grep --color=auto svn

(2)查找指定进程个数

[root@localhost ~]# ps -ef | grep svn -c
1
​

(3)从文件中读取关键词

[root@localhost ~]# cat test.log | grep -f test.log
马士兵教育:www.mashibing.com
​

(4)从文件夹中递归查找以.sh结尾的行,并只列出文件

[root@localhost ~]# grep -lR '.sh$'
.bash_history
test.sh
.viminfo
log.tar
​

(5)查找非x开关的行内容

[root@localhost ~]# grep '^[^x]' test.log
马士兵教育:www.mashibing.com
​

(6)显示包含 ed 或者 at 字符的内容行

[root@localhost ~]# grep -E 'ed|at' test.log

12.ps命令

ps

作用:用于显示当前进程 (process) 的状态

语法:

ps [options] [--help]
linux上进程有5种状态:
​
1. 运行(正在运行或在运行队列中等待)
2. 中断(休眠中, 受阻, 在等待某个条件的形成或接受到信号)
3. 不可中断(收到信号不唤醒和不可运行, 进程必须等待直到有中断发生)
4. 僵死(进程已终止, 但进程描述符存在, 直到父进程调用wait4()系统调用后释放)
5. 停止(进程收到SIGSTOP, SIGSTP, SIGTIN, SIGTOU信号后停止运行运行)

ps 工具标识进程的5种状态码:

D 不可中断 uninterruptible sleep (usually IO)
R 运行 runnable (on run queue)
S 中断 sleeping
T 停止 traced or stopped
Z 僵死 a defunct (”zombie”) process

命令参数

参数参数描述
-A显示所有进程
a显示所有进程
-a显示同一终端下所有进程
c显示进程真实名称
e显示环境变量
f显示进程间的关系
r显示当前终端运行的进程
-aux显示所有包含其它使用的进程

(1)显示当前所有进程环境变量及进程间关系

[root@localhost ~]# ps -ef

(2)显示当前所有进程

[root@localhost ~]# ps -A

(3)与grep联用查找某进程

[root@localhost ~]# ps -aux | grep apache
root      20112  0.0  0.0 112824   980 pts/0    S+   15:30   0:00 grep --color=auto apache

(4)找出与 cron 与 syslog 这两个服务有关的 PID 号码

[root@localhost ~]# ps aux | grep '(cron|syslog)'
root      20454  0.0  0.0 112824   984 pts/0    S+   15:30   0:00 grep --color=auto (cron|syslog)
​

13.kill命令

kill

kill 命令用于删除执行中的程序或工作

kill 可将指定的信息送至程序。预设的信息为 SIGTERM(15),可将指定程序终止。若仍无法终止该程序,可使用 SIGKILL(9) 信息尝试强制删除程序。程序或工作的编号可利用 ps 指令或 jobs 指令查看

语法:

kill [-s <信息名称或编号>][程序] 或 kill [-l <信息编号>]

常用参数:

参数参数描述
-l信号,若果不加信号的编号参数,则使用“-l”参数会列出全部的信号名称
-a当处理当前进程时,不限制命令名和进程号的对应关系
-p指定kill 命令只打印相关进程的进程号,而不发送任何信号
-s指定发送信号
-u指定用户

(1)先使用ps查找进程pro1,然后用kill杀掉

[root@localhost ~]# kill -9 $(ps -ef | grep pro1)
-bash: kill: root: 参数必须是进程或任务 ID
-bash: kill: (27319) - 没有那个进程
-bash: kill: (27317) - 没有那个进程

This moment will nap, you will have a dream; But this moment study,

you will interpret a dream

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值