本文最后更新于:2021年12月11日 晚上
前言
学会使用命令帮助
在linux终端,面对命令不知道怎么用,或不记得命令的拼写及参数时,我们需要求助于系统的帮助文档; linux系统内置的帮助文档很详细,通常能解决我们的问题,我们需要掌握如何正确的去使用它们;
- 在只记得部分命令关键字的场合,我们可通过man -k来搜索;
- 需要知道某个命令的简要说明,可以使用whatis;而更详细的介绍,则可用info命令;
- 查看命令在哪个位置,我们需要使用which;
- 而对于命令的具体参数及使用方法,我们需要用到强大的man;
查看命令的简要说明
- 简要说明命令的作用(显示命令所处的man分类页面):
- 正则匹配查询 “command*” 名称:
- 更加详细的说明文档:
使用man查询command的说明文档
使用page up和page down来上下翻页
在man的帮助手册中,将帮助文档分为了9个类别,对于有的关键字可能存在多个类别中, 我们就需要指定特定的类别来查看;(一般我们查询bash命令,归类在1类中);
man页面所属的分类标识(常用的是分类1和分类3)
| (1)、用户可以操作的命令或者是可执行文件 (2)、系统核心可调用的函数与工具等 (3)、一些常用的函数与数据库 (4)、设备文件的说明 (5)、设置文件或者某些文件的格式 (6)、游戏 (7)、惯例与协议等。例如Linux标准文件系统、网络协议、ASCⅡ,码等说明内容 (8)、系统管理员可用的管理条令 (9)、与内核有关的文件
|
前面说到使用whatis会显示命令所在的具体的文档类别,我们学习如何使用它
| 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的帮助:
| $man 3 printf
$man -k keyword
|
查询关键字 根据命令中部分关键字来查询命令,适用于只记住部分命令的场合;
eg:查找GNOME的config配置工具命令:
| man -k GNOME config| grep 1
|
对于某个单词搜索,可直接使用/word来使用: /-a; 多关注下SEE ALSO 可看到更多精彩内容
查看路径
查看程序的binary文件所在路径:
查看程序的搜索路径:
当系统中安装了同一软件的多个版本时,不确定使用的是哪个版本时,这个命令就能派上用场;
文件及目录管理
文件管理不外乎文件或目录的创建、删除、查询、移动,有mkdir/rm/mv
文件查询是重点,用find来进行查询;find的参数丰富,也非常强大;
查看文件内容是个大的话题,文本的处理有太多的工具供我们使用,在本章中只是点到即止,后面会有专门的一章来介绍文本的处理工具;
有时候,需要给文件创建一个别名,我们需要用到ln,使用这个别名和使用原文件是相同的效果;
创建和删除
创建文件夹
删除空文件夹
删除文件
删除文件或者非空文件夹
| rm -rf [file_name / folder_name]
|
删除日志
| rm *log ( 等价:find ./ -name “*log” -exec rm {} ;)
|
移动
| mv [file_name / folder_name] [path]
|
复制文件
复制目录:
| cp -r [folder_name] [path]
|
查看当前目录下文件个数:
目录切换
进入path目录:
切换到上一个工作目录:
切换到home目录:
显示当前路径:
列出目录项
显示当前目录下的文件和文件夹:
按时间排序,以列表的方式显示目录项:
给列出的文件前面增加一个id编号,使得看上去更加整洁:
查找目录及文件 find/locate
搜寻文件或目录
| find ./ -name "core*" | xargs file
|
查找目标文件夹中是否有obj文件
递归当前目录及子目录删除所有.o文件
| find ./ -name "*.o" -exec rm {} \
|
find是实时查找,如果需要更快的查询,可以试试locate;locate会为文件系统建立索引数据库,如果有文件更新,需要定期执行更新命令来更新索引库
寻找包含string的路径
与find不同,locate并不是实时查找,你需要更新数据库,以获得最新的文件索引信息。
查看文件内容
查看文件:cat vi head tail more
显示相同时显示行号
按页显示列表内容
只看前10行
显示文件第一行
显示文件倒数第五行
查看两个文件间的区别
动态显示文本最新信息
查找文件内容
使用egrep查询文件内容
| egrep '03.1\/CO\/AE' TSF_STAT_111130.log.012 egrep 'A_LMCA777:C' TSF_STAT_111130.log.035 > co.out2
|
文件与目录权限修改
改变文件的拥有者:
改变文件读、写、执行等属性:
递归子目录修改:
增加脚本可执行权限:
给文件增加别名
传感符号链接/硬链接
| ln cc ccAgain :硬连接;删除一个,将仍能找到; ln -s cc ccTo :符号链接(软链接);删除源,另一个无法使用;(后面一个ccTo 为新建的文件)
|
管道和重定向
批处理命令连接执行:
|
串联:
;
前面成功,则执行后面一条,否则,不执行:
&&
前面失败,则最后一条执行:
||
| ls /proc && echo suss! || echo failed.
|
能给提升命令是否执行成功or失败
与上述相同效果的是
| if ls /proc; then echo suss; else echo fail; fi
|
重定向
| ls proc/*.c > list 2> &l 将标准输出和标准错误重定向到同一文件;
|
等价的是:
清空文件:
重定向
设置环境变量
启动账号后自动执行的是文件为 .profile 。然后通过这个文件可以设置自己的环境变量
安装软件路径一般需要加入到path中
| PATH=$APPDIR:/opt/app/soft/bin:$PATH:/usr/local/bin:$TUXDIR/bin:$ORACLE_HOME/bin;export PATH
|
Bash快捷输入或删除
快捷键:
| Ctl-U 删除光标到行首的所有字符,在某些设置下,删除全行 Ctl-W 删除当前光标到前边的最近一个空格之间的字符 Ctl-H backspace,删除光标前边的字符 Ctl-R 匹配最相近的一个文件,然后输出
|
综合应用
查找record.log中包含AAA,但不包含BBB的记录的总数
| 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. 启动参数
- -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. 下载单个文件
说明:以上例子从网络下载一个文件并保存在当前目录,在下载的过程中会显示进度条,包含(下载完成百分比,已经下载的字节,当前下载速度,剩余下载时间)。
2. 下载并以不同的文件名保存
| wget -O [FILE_NAME] [URL]
|
wget默认会以[URL]
最后一个符合”/“的后面的字符来对文件进行命名,对于动态链接的下载通常文件名会不正确。
- 错误:下面的例子会下载一个文件并以名称为
download.aspx?id=1000
保存:
| wget http://www,baidu.com/download.aspx?id=1000
|
即使下载的文件是zip格式,它仍然以download.aspx?id=1000
来命名文件
- 正确:为了解决这个问题,我们可以使用参数
-O
来指定文件名:
3. 限速下载
| wget --limit-rate=300k [URL]
|
当你执行wget的时候,它默认会占用全部可能的宽带下载。但是当你准备下载一个大文件,而你还需要下载其它文件时就有必要限速了。
4. 断点续传
使用wget -c重新启动下载中断的文件,对于我们下载大文件时突然由于网络等原因中断非常有帮助,我们可以继续接着下载而不是重新下载一个文件。需要继续中断的下载时可以使用-c参数。
5. 后台下载
| wget -b [URL]
Continuing in background, pid 1840. Output will be written to 'wget-log'.
|
对于下载非常大的文件的时候,我们可以使用参数-b进行后台下载。
你可以使用以下命令来察看下载进度:tail -f wget-log
6. 伪装代理名称下载
| 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下载:
| cat > filelist.txt url1 url2 url3 url4
wget -i filelist.txt
|
8. 增加重试次数
如果网络有问题或者下载一个大文件失败,wget默认会重试20次连接下载文件,如果需要,你可以使用--tries
增加重试次数。
9. 下载指定格式文件
可以在以下情况使用该功能:
下载一个网站的所有图片
下载一个网站的所有视频
下载一个网站的所有PDF文件
10. FTP下载
可以使用wget来完成ftp链接的下载:
使用wget匿名ftp下载:
使用wget用户名和密码认证的ftp下载:
| wget –ftp-user=USERNAME –ftp-password=PASSWORD url
|
详细使用
wget 详细使用方法
高级命令