赞
踩
答案: 绝对路径: 如/etc/init.d 当前目录和上层目录: ./ ../ 主目录: ~/ 切换目录: cd
答案: 查看当前进程: ps 执行退出: exit 查看当前路径: pwd
前用户 id?查看指定帮助用什么命令?
答案:
清屏: clear
退出当前命令: ctrl+c
彻底退出 执行睡眠 : ctrl+z
挂起当前进程 fg 恢复后台
查看当前用户 id: ”id“:查看显示目前登陆账户的 uid 和 gid 及所属分组及用户名
查看指定帮助: 如 man adduser 这个很全 而且有例子;
adduser --help 这个告诉你一些常用参数; info adduesr;
答案: ls 执行的功能: 列出指定目录中的目录,以及文件哪些参数以及区别: a 所有文件 l 详细信息,包括大小字节数,可读可写可执行的权限等。
vi 文件名 #编辑方式查看,可修改
cat 文件名 #显示全部文件内容
more 文件名 #分页显示文件内容
less 文件名 #与 more 相似,更好的是可以往前翻页
tail 文件名 #仅查看尾部,还可以指定行数
head 文件名 #仅查看头部,还可以指定行数
列出文件列表:ls【参数 -a -l】
创建目录和移除目录:mkdir rmdir
用于显示文件后几行内容:tail,例如: tail -n 1000:显示最后1000行
打包:tar -xvf
打包并压缩:tar -zcvf
查找字符串:grep
显示当前所在目录:pwd
创建空文件:touch
编辑器:vim vi
Linux查看日志的命令有多种: tail、cat、tac、head、echo等,本文只介绍几种常用的方法。
最常用的一种查看方式
命令格式: tail[必要参数][选择参数][文件]
-f 循环读取
-q 不显示处理信息
-v 显示详细的处理信息
-c 显示的字节数
-n 显示行数
-q, --quiet, --silent 从不输出给出文件名的首部
-s, --sleep-interval=S 与-f合用,表示在每次反复的间隔休眠S秒
例如:
- tail -n 10 test.log 查询日志尾部最后10行的日志;
- tail -n +10 test.log 查询10行之后的所有日志;
- tail -fn 10 test.log 循环实时查看最后1000行记录(最常用的)
一般还会配合着grep搜索用,例如 :
tail -fn 1000 test.log | grep '关键字'
如果一次性查询的数据量太大,可以进行翻页查看,例如 :
tail -n 4700 aa.log |more -1000 可以进行多屏显示(ctrl + f 或者 空格键可以快捷键)
跟tail是相反的head是看前多少行日志
- head -n 10 test.log 查询日志文件中的头10行日志;
- head -n -10 test.log 查询日志文件除了最后10行的其他所有日志;
head其他参数参考tail
cat 是由第一行到最后一行连续显示在屏幕上
一次显示整个文件 :
$ cat filename
从键盘创建一个文件 :
$cat > filename
将几个文件合并为一个文件:
$cat file1 file2 > file 只能创建新文件,不能编辑已有文件
将一个日志文件的内容追加到另外一个 :
$cat -n textfile1 > textfile2
清空一个日志文件:
$cat : >textfile2
注意:> 意思是创建,>>是追加。千万不要弄混了。
cat其他参数参考tail
more命令是一个基于vi编辑器文本过滤器,它以全屏幕的方式按页显示文本文件的内容,支持vi中的关键字定位操作。more名单中内置了若干快捷键,常用的有H(获得帮助信 息),Enter(向下翻滚一行),空格(向下滚动一屏),Q(退出命令)。more命令从前向后读取文件,因此在启动时就加载整个文件。
该命令一次显示一屏文本,满屏后停下来,并且在屏幕的底部出现一个提示信息,给出至今己显示的该文件的百分比:–More–(XX%)
more的语法:
more 文件名
Enter 向下n行,需要定义,默认为1行
Ctrl f 向下滚动一屏
空格键 向下滚动一屏
Ctrl b 返回上一屏
= 输出当前行的行号
:f 输出文件名和当前行的行号
v 调用vi编辑器
!命令 调用Shell,并执行命令
q退出more
这个命令可以查找日志文件特定的一段 , 根据时间的一个范围查询,可以按照行号和时间范围查询按照行号
sed -n '5,10p' filename 这样你就可以只查看文件的第5行到第10行。
按照时间段
sed -n '/2014-12-17 16:17:20/,/2014-12-17 16:17:36/p' test.log
less命令在查询日志时,一般流程是这样的
- less log.log
- shift + G 命令到文件尾部 然后输入 ?加上你要搜索的关键字例如 ?1213
- 按 n 向上查找关键字
- shift+n 反向查找关键字
- less与more类似,使用less可以随意浏览文件,而more仅能向前移动,不能向后移动,而且 less 在查看
- 之前不会加载整个文件。
- less log2013.log 查看文件
- ps -ef | less ps查看进程信息并通过less分页显示
- history | less 查看命令历史使用记录并通过less分页显示
- less log2013.log log2014.log 浏览多个文件
常用命令参数:
- less与more类似,使用less可以随意浏览文件,而more仅能向前移动,不能向后移动,而且 less 在查看
- 之前不会加载整个文件。
- less log2013.log 查看文件
- ps -ef | less ps查看进程信息并通过less分页显示
- history | less 查看命令历史使用记录并通过less分页显示
- less log2013.log log2014.log 浏览多个文件
- 常用命令参数:
- -b <缓冲区大小> 设置缓冲区的大小
- -g 只标志最后搜索的关键词
- -i 忽略搜索时的大小写
- -m 显示类似more命令的百分比
- -N 显示每行的行号
- -o <文件名> 将less 输出的内容在指定文件中保存起来
- -Q 不使用警告音
- -s 显示连续空行为一行
- /字符串:向下搜索"字符串"的功能
- ?字符串:向上搜索"字符串"的功能
- n:重复前一个搜索(与 / 或 ? 有关)
- N:反向重复前一个搜索(与 / 或 ? 有关)
- b 向后翻一页
- h 显示帮助界面
- q 退出less 命令
一般本人查日志配合应用的其他命令
- history // 所有的历史记录
- history | grep XXX // 历史记录中包含某些指令的记录
- history | more // 分页查看记录
- history -c // 清空所有的历史记录
- !! 重复执行上一个命令
- 查询出来记录后选中:!323
- 软链接: ln -s slink source
- 硬链接: ln link source
- 创建目录: mkdir
- 创建文件:典型的如 touch,vi 也可以创建文件,其实只要向一个不存在的文件
- 输出,都会创建文件
- 复制文件: cp 7. 文件权限修改用什么命令?格式是怎么样的?
- 文件权限修改: chmod
- 格式如下:
- chmodu+xfile 给 file 的属主增加执行权限 chmod 751 file 给 file 的属主分配
- 读、写、执行(7)的权限,给 file 的所在组分配读、执行(5)的权限,给其他用户
- 分配执行(1)的权限
- chmodu=rwx,g=rx,o=xfile 上例的另一种形式 chmod =r file 为所有用户分配
- 读权限
- chmod444file 同上例 chmod a-wx,a+r file 同上例
- $ chmod -R u+r directory 递归地给 directory 目录下所有文件和子目录的属
- 主分配读的权限
- vi 文件名 #编辑方式查看,可修改
- cat 文件名 #显示全部文件内容
- more 文件名 #分页显示文件内容
- less 文件名 #与 more 相似,更好的是可以往前翻页
- tail 文件名 #仅查看尾部,还可以指定行数
- head 文件名 #仅查看头部,还可以指定行数
写文件命令:vi
向屏幕输出带空格的字符串:echo hello world
终端 /dev/tty
黑洞文件 /dev/null
mv mv
cp cp -r ?? ??
rm rm -r rmdir
- ? ”可替 代单 个字 符。
- “*” 可替 代任 意多 个字 符。
- 方括 号“ [charset]” 可替 代 charset 集中 的任 何单 个字 符, 如 [a-z], [abABC]
wc 命令 - c 统计字节数 - l 统计行数 - w 统计字数。
是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来。
grep [stringSTRING] filename grep [^string] filename
1、不可中断状态:进程处于睡眠状态,但是此刻进程是不可中断的。不可中断,指进程不响应异步信号。
2、暂停状态/跟踪状态:向进程发送一个 SIGSTOP 信号,它就会因响应该信号 而进入 TASK_STOPPED 状态;当进程正在被跟踪时,它处于 TASK_TRACED 这个特殊的状态。正被 跟踪”指的是进程暂停下来,等待跟踪它的进程对它进行操作。
3、就绪状态:在 run_queue 队列里的状态
4、运行状态:在 run_queue 队列里的状态
5、可中断睡眠状态:处于这个状态的进程因为等待某某事件的发生(比如等待socket 连接、等待信号量),而被挂起
6、zombie 状态(僵尸):父亲没有通过 wait 系列的系统调用会顺便将子进程的尸体(task_struct)也释放掉
7、退出状态
D 不可中断 Uninterruptible(usually IO)
R 正在运行,或在队列中的进程
S 处于休眠状态
T 停止或被追踪
Z 僵尸进程
W 进入内存交换(从内核 2.6 开始无效)
X 死掉的进程
一般都是使用 & 在命令结尾来让程序自动运行。(命令后可以不追加空格)
- ps -ef (system v 输出)
- ps -aux bsd 格式输出
- ps -ef | grep pid
job -l
把后台任务调到前台执行 fg
把停下的后台任务在后台执行起来 bg
kill [-s ][程序] 或 kill [-l ]
kill-9 pid
kill -l
- find <指定目录> <指定条件> <指定动作>
- whereis 加参数与文件名
- locate 只加文件名
- find 直接搜索磁盘,较慢。
- find / -name "string*"
查找自己所在的终端信息:who am i
查看当前谁在使用该主机:who
history
df -hl
文件系统 容量 已用 可用 已用% 挂载点
- Filesystem Size Used Avail Use% Mounted on /dev/hda2 45G 19G 24G
- 44% /
- /dev/hda1 494M 19M 450M 4% /boot
netstat
ifconfig
查看所有 env 查看某个,如 home: env $HOME
\u:显示当前用户账号
\h:显示当前主机名
\W:只显示当前路径最后一个目录
\w:显示当前绝对路径(当前用户目录会以~代替)
$PWD:显示当前全路径
$:显示命令行’$'或者’#'符号
#:下达的第几个命令
\d:代表日期,格式为 week day month date,例如:"MonAug1"
\t:显示时间为 24 小时格式,如:HH:MM:SS
\T:显示时间为 12 小时格式
\A:显示时间为 24 小时格式:HH:MM
\v:BASH 的版本信息 如 export PS1=’[\u@\h\w#]$‘
whereis [-bfmsu][-B ...][-M ...][-S ...][文 件 ...]
补 充 说 明 : whereis 指 令 会 在 特 定 目 录 中 查 找 符 合 条 件 的 文 件 。 这 些 文 件 的 烈 性应 属 于 原 始 代 码 , 二 进 制 文 件 , 或 是 帮 助 文 件 。
-b 只查找二进制文件。
-B 只在设置的目录下查找二进制文件。
-f 不显示文件名前的路径名称。
-m 只查找说明文件。
-M 只在设置的目录下查找说明文件。
-s 只查找原始代码文件。
-S 只在设置的目录下查找原始代码文件。
-u 查找不包含指定类型的文件。
w -h ich 指令会在 PATH 变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。
-n 指定文件名长度,指定的长度必须大于或等于所有文件中最长的文件名。
-p 与-n 参数相同,但此处的包括了文件的路径。
-w 指定输出时栏位的宽度。
-V 显示版本信息
which 只能查可执行文件
whereis 只能查二进制文件、说明文档,源文件等
- alias la='ls -a
du 显示目录或文件的大小
df 显示每个所在的文件系统的信息,默认是显示所有文件系统。(文件系统分配其中的一些磁盘块用来记录它自身的一些数据,如 i 节点,磁盘分布图,间接块,超级块 等。这些数据对大多数用户级的程序来说是不可见的,通常称为 Meta Data。) du 命令是用户级的程序,它不考虑 Meta Data,而 df命令则查看文件系统的磁盘分配图并考虑 Meta Data。
df 命令获得真正的文件系统数据,而 du 命令只查看文件系统的部分情况
- awk '{pattern + action}' {filenames}
- #cat /etc/passwd |awk -F ':' '{print 1"\t"7}' //-F 的意思是以':'分隔 root
- /bin/bash
- daemon /bin/sh 搜索/etc/passwd 有 root 关键字的所有行
- #awk -F: '/root/' /etc/passwd root:x:0:0:root:/root:/bin/bash
可以使用 bind 命令,bind 可以很方便地在 shell 中实现宏或按键的绑定。
在进行按键绑定的时候,我们需要先获取到绑定按键对应的字符序列。
比如获取 F12 的字符序列获取方法如下:先按下 Ctrl+V,然后按下 F12 .我们就可 以得到 F12 的字符序列 ^[[24~。
接着使用 bind 进行绑定
[root@localhost ~]# bind ‘”\e[24~":"date"'
注意:相同的按键在不同的终端或终端模拟器下可能会产生不同的字符序列。
【附】也可以使用 showkey -a 命令查看按键对应的字符序列。
使用命令 compgen -c,可以打印出所有支持的命令列表。
- [root@localhost ~]$ compgen -c
- l.
- ll
- ls
- which
- if
- then
- else
- elif
- fi
- case
- esac
- for
- select
- while
- until
- do
- done
- ....
使用 Linux 命令 dirs 可以将当前的目录栈打印出来。
- [root@localhost ~]# dirs
- /usr/share/X11
使用 linux 命令 ’disown -r ’可以将所有正在运行的进程移除。
linux 命令’hash’管理着一个内置的哈希表,记录了已执行过的命令的完整路径,用该命令可以打印出你所使用过的命令以及执行的次数。
- [root@localhost ~]# hash
- hits command
- 2 /bin/ls
- 2 /bin/su
bash shell 的内置命令 let 可以进行整型数的数学运算
- #! /bin/bash
- … … le
- t c=a+b
- … …
通过管道将命令”cat file_name.txt” 和 ’more’ 连接在一起可以实现这个需要
[root@localhost ~]# cat file_name.txt | more
数据字典是属于’SYS’用户的,用户‘SYS’ 和 ’SYSEM’是由系统默认自动创建的
使用命令 whatis 可以先出显示出这个命令的用法简要,比如,你可以使用 whatis zcat 去查看‘zcat’的介绍以及使用简要。
- [root@localhost ~]# whatis zcat
- zcat [gzip] (1) – compress or expand files
使用 命令 repquota 能够 显示 出一 个文 件系 统的 配额 信息
【附 】只 有 root 用户 才能 够查 看其 它用 户的 配额 。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。