系列文章目录
【跟小嘉学 Linux 系统架构与开发】一、学习环境的准备与Linux系统介绍
【跟小嘉学 Linux 系统架构与开发】二、Linux发型版介绍与基础常用命令介绍
【跟小嘉学 Linux 系统架构与开发】三、如何查看帮助文档
文章目录
- 系列文章目录
- @[TOC](文章目录)
- 前言
- 一、 命令的 `--help` 帮助说明
- 二、man page
- 2.1、man page 介绍
- 2.2、man page 快捷
- 2.3、man page 资料位置
- 2.4、man 命令用法
- 2.4.1、查看与 man 命令有关的文档
- 2.4.2、查看对应类型的 man 命令的相关资料
- 2.4.3、查找关键字有关的命令
- 2.4.3、mandb
- 三、`info`
- 3.1、info 命令介绍
- 3.2、快捷键
- 四、其他有用的文件(documents)
- 五、正确的关机方法
文章目录
- 系列文章目录
- @[TOC](文章目录)
- 前言
- 一、 命令的 `--help` 帮助说明
- 二、man page
- 2.1、man page 介绍
- 2.2、man page 快捷
- 2.3、man page 资料位置
- 2.4、man 命令用法
- 2.4.1、查看与 man 命令有关的文档
- 2.4.2、查看对应类型的 man 命令的相关资料
- 2.4.3、查找关键字有关的命令
- 2.4.3、mandb
- 三、`info`
- 3.1、info 命令介绍
- 3.2、快捷键
- 四、其他有用的文件(documents)
- 五、正确的关机方法
前言
前面我们讲解了基础的日历、日期与时间、计算器等命令,以及常用的快捷键操作,我们这一节详细讲解,如何查看Linux的手册、文档、帮助信息等信息。
参考资料
《鸟哥的Linux私房菜繁体版》
《鸟哥的Linux私房菜简体版》
一、 命令的 --help
帮助说明
几乎 Linux 上的命令,在开发的时候,开发者就会将命令的语法与参数写入到指令操作手册上了,你只需要使用 --help
这个选项,就能够将该命令的用法一个大致的理解。
我们拿最熟悉的 date 的命令来查看
[vagrant@10 ~]$ date --help
Usage: date [OPTION]... [+FORMAT]or: date [-u|--utc|--universal] [MMDDhhmm[[CC]YY][.ss]]
Display the current time in the given FORMAT, or set the system date.Mandatory arguments to long options are mandatory for short options too.-d, --date=STRING display time described by STRING, not 'now'-f, --file=DATEFILE like --date once for each line of DATEFILE-I[TIMESPEC], --iso-8601[=TIMESPEC] output date/time in ISO 8601 format.TIMESPEC='date' for date only (the default),'hours', 'minutes', 'seconds', or 'ns' for dateand time to the indicated precision.-r, --reference=FILE display the last modification time of FILE-R, --rfc-2822 output date and time in RFC 2822 format.Example: Mon, 07 Aug 2006 12:34:56 -0600--rfc-3339=TIMESPEC output date and time in RFC 3339 format.TIMESPEC='date', 'seconds', or 'ns' fordate and time to the indicated precision.Date and time components are separated bya single space: 2006-08-07 12:34:56-06:00-s, --set=STRING set time described by STRING-u, --utc, --universal print or set Coordinated Universal Time (UTC)--help display this help and exit--version output version information and exitFORMAT controls the output. Interpreted sequences are:%% a literal %%a locale's abbreviated weekday name (e.g., Sun)%A locale's full weekday name (e.g., Sunday)%b locale's abbreviated month name (e.g., Jan)%B locale's full month name (e.g., January)%c locale's date and time (e.g., Thu Mar 3 23:05:25 2005)%C century; like %Y, except omit last two digits (e.g., 20)%d day of month (e.g., 01)%D date; same as %m/%d/%y%e day of month, space padded; same as %_d%F full date; same as %Y-%m-%d%g last two digits of year of ISO week number (see %G)%G year of ISO week number (see %V); normally useful only with %V%h same as %b%H hour (00..23)%I hour (01..12)%j day of year (001..366)%k hour, space padded ( 0..23); same as %_H%l hour, space padded ( 1..12); same as %_I%m month (01..12)%M minute (00..59)%n a newline%N nanoseconds (000000000..999999999)%p locale's equivalent of either AM or PM; blank if not known%P like %p, but lower case%r locale's 12-hour clock time (e.g., 11:11:04 PM)%R 24-hour hour and minute; same as %H:%M%s seconds since 1970-01-01 00:00:00 UTC%S second (00..60)%t a tab%T time; same as %H:%M:%S%u day of week (1..7); 1 is Monday%U week number of year, with Sunday as first day of week (00..53)%V ISO week number, with Monday as first day of week (01..53)%w day of week (0..6); 0 is Sunday%W week number of year, with Monday as first day of week (00..53)%x locale's date representation (e.g., 12/31/99)%X locale's time representation (e.g., 23:13:48)%y last two digits of year (00..99)%Y year%z +hhmm numeric time zone (e.g., -0400)%:z +hh:mm numeric time zone (e.g., -04:00)%::z +hh:mm:ss numeric time zone (e.g., -04:00:00)%:::z numeric time zone with : to necessary precision (e.g., -04, +05:30)%Z alphabetic time zone abbreviation (e.g., EDT)By default, date pads numeric fields with zeroes.
The following optional flags may follow '%':- (hyphen) do not pad the field_ (underscore) pad with spaces0 (zero) pad with zeros^ use upper case if possible# use opposite case if possibleAfter any flags comes an optional field width, as a decimal number;
then an optional modifier, which is either
E to use the locale's alternate representations if available, or
O to use the locale's alternate numeric symbols if available.Examples:
Convert seconds since the epoch (1970-01-01 UTC) to a date$ date --date='@2147483647'Show the time on the west coast of the US (use tzselect(1) to find TZ)$ TZ='America/Los_Angeles' dateShow the local time for 9AM next Friday on the west coast of the US$ date --date='TZ="America/Los_Angeles" 09:00 next Fri'GNU coreutils online help: <http://www.gnu.org/software/coreutils/>
Report date translation bugs to <http://translationproject.org/team/>
For complete documentation, run: info coreutils 'date invocation'
- Usage: 表明 date 命令的语法格式
- 接下来就是 [OPTION] 选项的内容
- 在接下来就是格式化控制台输出的格式序列
二、man page
2.1、man page 介绍
date --help
并没有详细告诉你 STRING 是什么东西,我们如果想要清清楚楚的知道该指令的用法。我们可以找 man 命令(manual).
DATE(1) User Commands DATE(1)NAMEdate - print or set the system date and timeSYNOPSISdate [OPTION]... [+FORMAT]date [-u|--utc|--universal] [MMDDhhmm[[CC]YY][.ss]]DESCRIPTIONDisplay the current time in the given FORMAT, or set the system date.Mandatory arguments to long options are mandatory for short options too.-d, --date=STRINGdisplay time described by STRING, not 'now'-f, --file=DATEFILElike --date once for each line of DATEFILE-I[TIMESPEC], --iso-8601[=TIMESPEC]output date/time in ISO 8601 format. TIMESPEC='date' for date only (the default), 'hours', 'minutes',Manual page date(1) line 1 (press h for help or q to quit)
- DATE(1):括号中的1 代表 我们指令的内容,这个编码从1-9有9个含义
- 1 :用户交互的命令,例如 ls、cp、man、grep等
- 2: 系统调用和内核函数
- 3:包含库函数和标准c函数
- 4:包含配置文件和设备文件
- 5:包含配置文件格式和协议
- 6:包含游戏和演示程序
- 7:包含惯例、协议、文件格式等
- 8:包含系统管理命令
- 9:和内核有关的文件
- NAME:命令的完整名称和命令用法
- SYNPSIS:命令的基本语法
- DESCRIPTION:详细说明语法中的选项参数的用法
- ENVIRONMENT:与这个命令相关的环境参数
- EXAMPLES:使用示例
- DATE STRING:日期的格式说明
- AUTHOR:命令的作者
- COPYRIGHT 版权声明
- SEE ALSO:还可以查找的文档
2.2、man page 快捷
快捷键表格
按键 | 作用 |
---|---|
空格键 | 向下翻页 |
[Page Down] | 向下翻一頁 |
[Page Up] | 向上翻一頁 |
[Home] | 去到第一頁 |
[End] | 去到最後一頁 |
/string | 向『下』查找 string 字符串, |
?string | 向『上』查找 string 這個字串 |
n, N | 利用 / 或 ? 來查找字串時,可以用 n 來繼續下一個查找 (不论是 / 或 ?) ,可以利用 N 來進行『反向』查找。 |
q | 結束這次的 man page |
2.3、man page 资料位置
不同的发行版存放的路径可能有点差异,不过通常都是 在 /usr/share/man
目录,我们可以man 的搜索路径来改善目录的问题
修改 /etc/man_db.conf
或 man.conf
或 manpath.conf
或 man.config
,关于 man 命令的详细信息,我们也可以通过 man man
命令来查询
2.4、man 命令用法
2.4.1、查看与 man 命令有关的文档
[vagrant@10 ~]$ man -f man
man (1) - an interface to the on-line reference manuals
man (1p) - display system documentation
man (7) - macros to format man pages
man -f
命令也可以使用 whatis
来替代
[vagrant@10 ~]$ whatis man
whatis: can't set the locale; make sure $LC_* and $LANG are correct
man (1) - an interface to the on-line reference manuals
man (1p) - display system documentation
man (7) - macros to format man pages
2.4.2、查看对应类型的 man 命令的相关资料
man 1 man
man 7 man
2.4.3、查找关键字有关的命令
man -k man
man -k
命令也可以使用 apropos
命令来替代
apropos man
2.4.3、mandb
whatis
和 apropos
命令要能使用,必须建立 whatis 资料库才可以,可以在 root 账号下使用 下面命令来生成
[vagrant@10 ~]$ su - # 切换到 root 账号 - 表示环境变量也切换
Password:
Last login: Sun Mar 31 18:00:45 UTC 2024 on pts/0
[root@10 ~]# mandb
Purging old database entries in /usr/share/man...
Processing manual pages under /usr/share/man...
Purging old database entries in /usr/share/man/ru...
Processing manual pages under /usr/share/man/ru...
Purging old database entries in /usr/share/man/en...
Processing manual pages under /usr/share/man/en...
Purging old database entries in /usr/local/share/man...
Processing manual pages under /usr/local/share/man...
0 man subdirectories contained newer manual pages.
0 manual pages were added.
0 stray cats were added.
0 old database entries were purged.
三、info
3.1、info 命令介绍
info
命令 和 man
命令到用法差不多,就是用来查询命令的用法或者文件的格式,info page 是将文件拆成一个个段落,每个段落有自己的页面来编写,并且每个页面都有类似的超链接来跳到不同的页面。
info 命令的文件是存放在 /usr/share/info
目录之中.
[root@10 ~]# info infoFile: info.info, Node: Top, Next: Getting Started, Up: (dir)Info: An Introduction
*********************The GNU Project distributes most of its on-line manuals in the "Info
format", which you read using an "Info reader". You are probably using
an Info reader to read this now.There are two primary Info readers: 'info', a stand-alone program
designed just to read Info files (*note What is Info?: (info-stnd)Top.),
and the 'info' package in GNU Emacs, a general-purpose editor. At
present, only the Emacs reader supports using a mouse.If you are new to the Info reader and want to learn how to use it,
type the command 'h' now. It brings you to a programmed instruction
sequence.To read about advanced Info commands, type 'n' twice. This brings
you to 'Advanced Info Commands', skipping over the 'Getting Started'
chapter.
--zz-Info: (info.info.gz)Top, 52 lines --Top------------------------------------------------------------------------------
No `Prev' or `Up' for this node within this document.
- File:代表info page 的资料来自 info.info 这个文件所提供
- Node:代表目前这个页面属于Top节点,意思是 info.info 内容有很多,Top只是其中一部分内容
- Next:下一个节点的名称为:Getting Started,你也可以按 N 跳到下一个节点;
- Up:回到上一层的节点,你也可以按 U 来回到上一层
- Prev:前一个节点,但是TOP是第一个节点,所以上面没有前一个节点的内容
3.2、快捷键
按键 | 功能 |
---|---|
空格键 | 向下翻一页 |
[Page Down] | 向下翻一页 |
[Page Up] | 向上翻一页 |
[tab] | 在 node 之间移动,有 node 的地方,通常会以 * 显示。 |
[Enter] | 当光标在 node 上面时,按下 Enter 可以进入该 node |
b | 移动光标到该info 当中的第一个 node 处 |
e | 移动光标到该info 当中的最后一个 node 处 |
n | 前往下一个 node 处 |
p | 前往上一个 node 处 |
u | 向上移动一层 |
s(/) | 在 info page 当中进行搜索 |
h, ? | 显示帮助菜单 |
q | 結束这次的 info page |
四、其他有用的文件(documents)
一般而言,命令或软件开发者都会将自己的命令或软件的说明制作成文档,但是并不是所有的命令或软件都有。
这些文件一般都存放在 /usr/share/doc
例如
/usr/share/doc/grub2-tools-2.02
五、正确的关机方法
关机的时候要注意几件事
- 观察系统的使用状态:
who
、netstat -a
、ps -aux
- 通知用户关机的:
shutdown
- 正确的关机和重启命令:
shutdown
、reboot
- 资料同步写入硬盘命令:
sync
- 关机:
halt
、poweroff
、reboot
- 管理工具:
init
、systemctl