Linux基础命令

本文最后更新于:2021年12月11日 晚上

前言

学会使用命令帮助

在linux终端,面对命令不知道怎么用,或不记得命令的拼写及参数时,我们需要求助于系统的帮助文档; linux系统内置的帮助文档很详细,通常能解决我们的问题,我们需要掌握如何正确的去使用它们;

  • 在只记得部分命令关键字的场合,我们可通过man -k来搜索;
  • 需要知道某个命令的简要说明,可以使用whatis;而更详细的介绍,则可用info命令;
  • 查看命令在哪个位置,我们需要使用which;
  • 而对于命令的具体参数及使用方法,我们需要用到强大的man;

查看命令的简要说明

  1. 简要说明命令的作用(显示命令所处的man分类页面):
1
whatis [command]
  1. 正则匹配查询 “command*” 名称:
1
whatis -w "loca*"
  1. 更加详细的说明文档:
1
info [command]

使用man查询command的说明文档

1
man [command]

使用page up和page down来上下翻页

在man的帮助手册中,将帮助文档分为了9个类别,对于有的关键字可能存在多个类别中, 我们就需要指定特定的类别来查看;(一般我们查询bash命令,归类在1类中);

man页面所属的分类标识(常用的是分类1和分类3)

1
2
3
4
5
6
7
8
9
(1)、用户可以操作的命令或者是可执行文件
(2)、系统核心可调用的函数与工具等
(3)、一些常用的函数与数据库
(4)、设备文件的说明
(5)、设置文件或者某些文件的格式
(6)、游戏
(7)、惯例与协议等。例如Linux标准文件系统、网络协议、ASCⅡ,码等说明内容
(8)、系统管理员可用的管理条令
(9)、与内核有关的文件

前面说到使用whatis会显示命令所在的具体的文档类别,我们学习如何使用它

1
2
3
4
5
6
7
eg:
$whatis printf
printf (1) - format and print data
printf (1p) - write formatted output
printf (3) - formatted output conversion
printf (3p) - print formatted output
printf [builtins] (1) - bash built-in commands, see bash(1)

我们看到printf在分类1和分类3中都有;分类1中的页面是命令操作及可执行文件的帮助;而3是常用函数库说明;如果我们想看的是C语言中printf的用法,可以指定查看分类3的帮助:

1
2
3
$man 3 printf

$man -k keyword

查询关键字 根据命令中部分关键字来查询命令,适用于只记住部分命令的场合;
eg:查找GNOME的config配置工具命令:

1
man -k GNOME config| grep 1

对于某个单词搜索,可直接使用/word来使用: /-a; 多关注下SEE ALSO 可看到更多精彩内容

查看路径

查看程序的binary文件所在路径:

1
which [command]

查看程序的搜索路径:

1
$whereis [command]

当系统中安装了同一软件的多个版本时,不确定使用的是哪个版本时,这个命令就能派上用场;


文件及目录管理

文件管理不外乎文件或目录的创建、删除、查询、移动,有mkdir/rm/mv

文件查询是重点,用find来进行查询;find的参数丰富,也非常强大;

查看文件内容是个大的话题,文本的处理有太多的工具供我们使用,在本章中只是点到即止,后面会有专门的一章来介绍文本的处理工具;

有时候,需要给文件创建一个别名,我们需要用到ln,使用这个别名和使用原文件是相同的效果;

创建和删除

创建文件夹

1
mkdir [folder_name]

删除空文件夹

1
rmdir [folder_name]

删除文件

1
rm [file_name]

删除文件或者非空文件夹

1
rm -rf [file_name / folder_name]

删除日志

1
rm *log ( 等价:find ./ -name “*log” -exec rm {} ;)

移动

1
mv [file_name / folder_name] [path]

复制文件

1
cp [file_name] [path]

复制目录:

1
cp -r [folder_name] [path]

查看当前目录下文件个数:

1
find ./ | wc -l

目录切换

进入path目录:

1
cd [path]

切换到上一个工作目录:

1
cd ..

切换到home目录:

1
cd / cd - / cd ~

显示当前路径:

1
pwd

列出目录项

显示当前目录下的文件和文件夹:

1
ls

按时间排序,以列表的方式显示目录项:

1
ls -lrt

给列出的文件前面增加一个id编号,使得看上去更加整洁:

1
ls | cat -n

查找目录及文件 find/locate

搜寻文件或目录

1
find ./ -name "core*" | xargs file

查找目标文件夹中是否有obj文件

1
find ./ -nmae '*.o'

递归当前目录及子目录删除所有.o文件

1
find ./ -name "*.o" -exec rm {} \

find是实时查找,如果需要更快的查询,可以试试locate;locate会为文件系统建立索引数据库,如果有文件更新,需要定期执行更新命令来更新索引库

1
locate string

寻找包含string的路径

1
updatedb

与find不同,locate并不是实时查找,你需要更新数据库,以获得最新的文件索引信息。

查看文件内容

查看文件:cat vi head tail more

显示相同时显示行号

1
cat -n

按页显示列表内容

1
ls -al | more

只看前10行

1
head - 10 **

显示文件第一行

1
head -1 [file_name]

显示文件倒数第五行

1
tail -5 [file_name]

查看两个文件间的区别

1
diff [file1] [file2]

动态显示文本最新信息

1
tail -f crawler.log

查找文件内容

使用egrep查询文件内容

1
2
egrep '03.1\/CO\/AE' TSF_STAT_111130.log.012
egrep 'A_LMCA777:C' TSF_STAT_111130.log.035 > co.out2

文件与目录权限修改

改变文件的拥有者:

1
chown

改变文件读、写、执行等属性:

1
chmod

递归子目录修改:

1
chown -R tuxapp source/

增加脚本可执行权限:

1
chmod a+x muscript

给文件增加别名

传感符号链接/硬链接

1
2
ln cc ccAgain :硬连接;删除一个,将仍能找到;
ln -s cc ccTo :符号链接(软链接);删除源,另一个无法使用;(后面一个ccTo 为新建的文件)

管道和重定向

批处理命令连接执行:

|

串联:

;

前面成功,则执行后面一条,否则,不执行:

&&

前面失败,则最后一条执行:

||

1
ls /proc && echo  suss! || echo failed.

能给提升命令是否执行成功or失败

与上述相同效果的是

1
if ls /proc; then echo suss; else echo fail; fi

重定向

1
ls  proc/*.c > list 2> &l 将标准输出和标准错误重定向到同一文件;

等价的是:

1
ls  proc/*.c &> list

清空文件:

1
:> a.txt

重定向

1
echo aa >> a.txt

设置环境变量

启动账号后自动执行的是文件为 .profile 。然后通过这个文件可以设置自己的环境变量

安装软件路径一般需要加入到path中

1
PATH=$APPDIR:/opt/app/soft/bin:$PATH:/usr/local/bin:$TUXDIR/bin:$ORACLE_HOME/bin;export PATH

Bash快捷输入或删除

快捷键:

1
2
3
4
Ctl-U   删除光标到行首的所有字符,在某些设置下,删除全行
Ctl-W 删除当前光标到前边的最近一个空格之间的字符
Ctl-H backspace,删除光标前边的字符
Ctl-R 匹配最相近的一个文件,然后输出

综合应用

查找record.log中包含AAA,但不包含BBB的记录的总数

1
cat -v record.log | grep AAA | grep -v BBB | wc -l

文件下载

wget

Linux系统中的wget是一个下载文件的工具,它用在命令行下。对于Linux用户是必不可少的工具,我们经常要下载一些软件或从远程服务器恢复备份到本地服务器。wget支持HTTP,HTTPS和FTP协议,可以使用HTTP代理。
wget 可以跟踪HTML页面上的链接依次下载来创建远程服务器的本地版本,完全重建原始站点的目录结构。这又常被称作”递归下载”。在递归下载的时候,wget 遵循Robot Exclusion标准(/robots.txt). wget可以在下载的同时,将链接转换成指向本地文件,以方便离线浏览。
wget 非常稳定,它在带宽很窄的情况下和不稳定网络中有很强的适应性.如果是由于网络的原因下载失败,wget会不断的尝试,直到整个文件下载完毕。如果是服务器打断下载过程,它会再次联到服务器上从停止的地方继续下载。这对从那些限定了链接时间的服务器上下载大文件非常有用。

命令格式

1
wget [参数] [URL]

命令参数

1. 启动参数
  • -V, –version 显示wget的版本后退出
  • -h, –help 打印语法帮助
  • -b, –background 启动后转入后台执行
2. 下载参数
  • -t, –tries=NUMBER 设定最大尝试链接次数(0 表示无限制).
  • -c, –continue 接着下载没下载完的文件
  • -N, –timestamping 不要重新下载文件,除非比本地文件新
  • -T, –timeout=SECONDS 设定响应超时的秒数
  • -Y, -proxy=on/off 打开或关闭代理
  • -Q, -quota=NUMBER 设置下载的容量限制
  • -limit-rate=RATE 限定下载输率
3. 目录参数
  • -nd –no-directories 不创建目录
  • -x, –force-directories 强制创建目录
  • -nH, –no-host-directories 不创建主机目录
  • -P, –directory-prefix=PREFIX 将文件保存到目录 PREFIX/…

使用实例

1. 下载单个文件
1
wget [URL]

说明:以上例子从网络下载一个文件并保存在当前目录,在下载的过程中会显示进度条,包含(下载完成百分比,已经下载的字节,当前下载速度,剩余下载时间)。

2. 下载并以不同的文件名保存
1
wget -O [FILE_NAME] [URL]

wget默认会以[URL]最后一个符合”/“的后面的字符来对文件进行命名,对于动态链接的下载通常文件名会不正确。

  • 错误:下面的例子会下载一个文件并以名称为download.aspx?id=1000保存:
1
wget http://www,baidu.com/download.aspx?id=1000

即使下载的文件是zip格式,它仍然以download.aspx?id=1000来命名文件

  • 正确:为了解决这个问题,我们可以使用参数-O来指定文件名:
1
wget -O test.zip http://www,baidu.com/download.aspx?id=1000
3. 限速下载
1
wget --limit-rate=300k [URL]

当你执行wget的时候,它默认会占用全部可能的宽带下载。但是当你准备下载一个大文件,而你还需要下载其它文件时就有必要限速了。

4. 断点续传
1
wget -c [URL]

使用wget -c重新启动下载中断的文件,对于我们下载大文件时突然由于网络等原因中断非常有帮助,我们可以继续接着下载而不是重新下载一个文件。需要继续中断的下载时可以使用-c参数。

5. 后台下载
1
2
3
4
wget -b [URL]

Continuing in background, pid 1840.
Output will be written to 'wget-log'.

对于下载非常大的文件的时候,我们可以使用参数-b进行后台下载。

你可以使用以下命令来察看下载进度:tail -f wget-log

6. 伪装代理名称下载
1
wget --user-agent="Mozilla/5.0 (Windows; U; Windows NT 6.1; en-US) AppleWebKit/534.16 (KHTML, like Gecko) Chrome/10.0.648.204 Safari/534.16" [URL]

有些网站能通过根据判断代理名称不是浏览器而拒绝你的下载请求。不过你可以通过–user-agent参数伪装。

7. 下载多个文件

首先,保存一份下载链接文件,接着使用这个文件和参数-i下载:

1
2
3
4
5
6
7
cat > filelist.txt
url1
url2
url3
url4

wget -i filelist.txt
8. 增加重试次数
1
wget --tries=40 [URL]

如果网络有问题或者下载一个大文件失败,wget默认会重试20次连接下载文件,如果需要,你可以使用--tries增加重试次数。

9. 下载指定格式文件
1
wget -r -A.pdf url

可以在以下情况使用该功能:

下载一个网站的所有图片

下载一个网站的所有视频

下载一个网站的所有PDF文件

10. FTP下载

可以使用wget来完成ftp链接的下载:

  • 使用wget匿名ftp下载:

    1
    wget ftp-url
  • 使用wget用户名和密码认证的ftp下载:

    1
    wget –ftp-user=USERNAME –ftp-password=PASSWORD url

详细使用

wget 详细使用方法


高级命令


本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 协议 ,转载请注明出处!