Linux 常用命令。
Linux的命令有几百个,下面我将总结我常用到几个命令。如果大家在学习和工作中遇到了陌生的且高频的Linux命令,多查资料,掌握它,日积月累,知识面就会宽广。
1、关机:init 0
2、重启:init 6
3、清屏:clear
4、查看服务器的ip地址:ip addr
5、查看时间:date
6、设置时区为中国上海时间:cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
7、设置时间:date -s “yyyy-mm-dd hh:mi:ss”
8、查看当前目录:pwd
9、改变当前工作目录:cd 目录名
示例:
(1)、cd /user(进入/user目录)
(2)、cd …(进入上一级目录)
(3)、cd (进入用户主目录)】
10、列出目录和文件信息:ls [-lt] 目录或文件名
选项-l列出目录和文件的详细信息。
选项-lt列出目录和文件的详细信息,按时间降序显示。
示例:
(1)、ls:列出当前工作目录下全部的目录和文件名信息
(2)、ls -l:列出当前工作目录下全部的目录和文件名详细的信息。
(3)、ls /tmp:列出/tmp目录下全部的目录和文件。
11、正则表达式【星号“*”:匹配任意数量的字符。问号“?”:匹配一个字符。】
示例:
(1)、ls /tmp/.cpp:列出/dmp目录下以匹配.dmp的目录和文件。
(2)、ls /tmp/.log列出/tmp目录下匹配.log的目录和文件,按时间降序显示
12、创建目录:mkdir 目录名
13、删除目录和文件:rm [-rf] 目录或文件列表
选项-r可以删除目录,如果没有-r只能删除文件。
选项-f表示强制删除,不需要确认。
目录和文件列表中间用空格分隔。
示例:rm .*.swp:删除当前目录下所有的.swp交换文件
14、移动目录和文件:mv 旧目录或文件名 新目录或文件名
如果第二个参数是已经存在的目录,则把第一个参数(旧目录或文件名)移动到该目录中。
示例:
1)mv test.c test1.c:把当前工作目录中的test.c文件重命名为test1.c
2)mv test.c /tmp/test2:如果/tmp/test2是一个已经存在的目录,以下命令将把当前工作目录下的test.c文件移动到/tmp/test3目录中。
3)mv test.c /tmp/test3:如果/tmp/test3目录不存在,以下命令将把当前工作目录下的test.c文件改名为/tmp/test3。
15、复制目录和文件:cp [-r] 旧目录或文件名 新目录或文件名
选项-r可以复制目录,如果没有选项-r只能复制文件。
示例:
1)把当前工作目录下的book1.c文件复制为book2.c
cp book1.c book2.c
2)把当前工作目录下的aaa目录复制为bbb
cp -r aaa bbb
3)把当前工作目录下的book1.c文件复制为/tmp/book1.c
cp book1.c /tmp/book1.c
cp book1.c /tmp/.
以上两个命令的效果相同。
4)把当前工作目录下的aaa目录复制为/tmp/aaa
cp -r aaa /tmp/aaa
cp -r aaa /tmp/.
以上两个命令的效果相同。
16、打包压缩和解包解压:tar命令
打包压缩的语法:
tar zcvf 压缩包文件名 目录或文件名列表
示例:
1)把当前工作目录下的aaa目录打包压缩放到/tmp目录下重命名为123.tgz文件。
tar zcvf /tmp/123.tgz aaa
2)把/home/oracle/aaa、/home/oracle/bbb和/home/oracle/ccc目录打包压缩成/tmp/123.tgz文件。
tar zcvf /tmp/123.tgz /home/oracle/aaa /home/oracle/bbb /home/oracle/ccc
解包解压的语法:
tar zxvf压缩包文件名
示例:
1)把/tmp/123.tgz压缩包文件在当前工作目录下解压。
tar zxvf /tmp/123.tgz
2)把/tmp/123.tgz压缩包文件在/tmp/aaa目录下解压。
cd /tmp/aaa
tar zxvf /tmp/123.tgz
注意:
1)用tar命令打包和解包的目录和文件没有绝对路径的说法,都成了相对的,在包中相对的。
2)用tar命令打包的文件,用winrar可以解开。
3)在Linux系统中,还有其它的打包压缩和解包解压命令,例如zip/unzip和gzip/gunzip。
17、判断网络是否连通:ping -c 包的个数 ip地址或域名
ping用于确定本地主机是否能与另一台主机成功交换数据包,判断网络是否通畅。
18、显示文本文件的内容:显示文本文件的内容有三个命令:cat、more和tail。
more 文件名:more命令分页显示文件的内容,按空格键显示下一页,按b键显上一页,按q键退出。
tail -f 文件名:tail -f用于显示文本文件的最后几行,如果文件的内容有增加,就实时的刷新。tail -f极其重要,可以动态显示后台服务程序的日志,用于调试和跟踪程序的运行。
19、 统计文本文件的行数、单词数和字节数 :wc 文件名
20、搜索文件:find 目录名 -name 文件名 -print
从当前工作目录开始搜索,把全部的*.c文件显示出来。
find . -name *.c -print
21、搜索文件中的内容:grep “内容” 文件名
22、增加/删除用户组:groupadd 组名 groupdel 组名
23、增加/删除用户:useradd -n 用户名 -g 组名 -d 用户的主目录 ------ userdel 用户名
示例:useradd -n lyp -g dba -d /home/lyp :增加一个用户,用户名为lyp,属于dba组,用户的主目录是/home/lyp
userdel lyp:删除lyp用户。
24、修改用户的密码:passwd [用户名]
25、切换用户:在命令提示符下输入:su - root ,然后按提示输入root的密码后将切换到root用户。
从root用户切换到其它普通用户不需要输入密码,从普通用户切换到任何用户都需要输入密码。
26、修改目录和文件的主人和组:chown [-R] 用户名:组名 目录或文件名列表
-R 选项表示处理各及子目录。
示例:
1)把/oracle/home和/oracle/base及其子目录的主人改为oracle,组改为dba。
chown -R oracle:dba /oracle/home /oracle/base
27、查看系统磁盘空间:df [-h] [-T]
28、查看文件编码:file filename
29、查看内存信息: free -m(TX)
cached主要负责缓存文件, 日志文件过大造成cached区内存增大把内存占用完 .
linux下如何释放cache内存
1、执行
sync
命令,将缓存中未被写入磁盘的内容写入磁盘。
2、通过调整/proc/sys/vm/drop_caches来释放内存:
目的:清空缓存,腾出更多可用内存
echo 1 > /proc/sys/vm/drop_caches
30、查看程序执行时间:time ./book
31、查看网络系统的状态信息:netstat(TX)
用于显示与IP、TCP、UDP和ICMP协议相关的统计数据,一般用于检验本机各端口的网络连接情况。

netstat的输出结果可以分为两个部分
1、Active Internet connections 有源TCP连接,其中"Recv-Q"和"Send-Q"指接收队列和发送队列。这些数字一般都应该是0。如果不是则表示软件包正在队列中堆积。这种情况只能在非常少的情况见到。
2、Active UNIX domain sockets 有源Unix域套接口(和网络套接字一样,但是只能用于本机通信,性能可以提高一倍)。
列名解释:
Proto:显示连接使用的协议。
RefCnt:表示连接到本套接口上的进程号。
Types:显示套接口的类型。
State:显示套接口当前的状态。
Path:表示连接到套接口的其它进程使用的路径名。
netstat常见参数
-a (all) 显示所有选项,默认不显示LISTEN相关。
-t (tcp) 仅显示tcp相关选项。
-u (udp) 仅显示udp相关选项。
-n 拒绝显示别名,能显示数字的全部转化成数字。
-l 仅列出有在 Listen (监听) 的服务状态。
-p 显示建立相关链接的程序名
-r 显示路由信息,路由表
-e 显示扩展信息,例如uid等
-s 按各个协议进行统计
-c 每隔一个固定时间,执行该netstat命令。
LISTEN和LISTENING的状态只有用-a或者-l才能看到。
32、监控linux的系统状况:top(TX)
是常用的性能分析工具,能够实时显示系统中各个进程的资源占用情况。
top各输出参数含义
一、top前5行统计信息
第1行:top - 05:43:27 up 4:52, 2 users, load average: 0.58, 0.41, 0.30
第1行是任务队列信息,其参数如下:
内容 | 含义 |
---|---|
05:43:27 | 表示当前时间 |
up 4:52 | 系统运行时间 格式为时:分 |
2 users | 当前登录用户数 |
load average: 0.58, 0.41, 0.30 | 系统负载,即任务队列的平均长度。 三个数值分别为 1分钟、5分钟、15分钟前到现在的平均值。 |
load average: 如果这个数除以逻辑CPU的数量,结果高于5的时候就表明系统在超负荷运转了。
第2行:Tasks: 159 total, 1 running, 158 sleeping, 0 stopped, 0 zombie
第3行:%Cpu(s): 37.0 us, 3.7 sy, 0.0 ni, 59.3 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
第2、3行为进程和CPU的信息
当有多个CPU时,这些内容可能会超过两行,其参数如下:
内容 | 含义 |
---|---|
159 total | 进程总数 |
1 running | 正在运行的进程数 |
158 sleeping | 睡眠的进程数 |
0 stopped | 停止的进程数 |
0 zombie | 僵尸进程数 |
37.0 us | 用户空间占用CPU百分比 |
3.7 sy | 内核空间占用CPU百分比 |
0.0 ni | 用户进程空间内改变过优先级的进程占用CPU百分比 |
59.3 id | 空闲CPU百分比 |
0.0 wa | 等待输入输出的CPU时间百分比 |
0.0 hi | 硬中断(Hardware IRQ)占用CPU的百分比 |
0.0 si | 软中断(Software Interrupts)占用CPU的百分比 |
0.0 st |
第4行:KiB Mem: 1530752 total, 1481968 used, 48784 free, 70988 buffers
第5行:KiB Swap: 3905532 total, 267544 used, 3637988 free. 617312 cached Mem
第4、5行为内存信息
其参数如下:
内容 | 含义 |
---|---|
KiB Mem: 1530752 total | 物理内存总量 |
1481968 used | 使用的物理内存总量 |
48784 free | 空闲内存总量 |
70988 buffers(buff/cache) | 用作内核缓存的内存量 |
KiB Swap: 3905532 total | 交换区总量 |
267544 used | 使用的交换区总量 |
3637988 free | 空闲交换区总量 |
617312 cached Mem | 缓冲的交换区总量。 |
3156100 avail Mem | 代表可用于进程下一次分配的物理内存数量 |
上述最后提到的缓冲的交换区总量,这里解释一下,所谓缓冲的交换区总量,即内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,该数值即为这些内容已存在于内存中的交换区的大小。相应的内存再次被换出时可不必再对交换区写入。
计算可用内存数有一个近似的公式:
第四行的free + 第四行的buffers + 第五行的cached
二、进程信息
列名 | 含义 |
---|---|
PID | 进程id |
PPID | 父进程id |
RUSER | Real user name |
UID | 进程所有者的用户id |
USER | 进程所有者的用户名 |
GROUP | 进程所有者的组名 |
TTY | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
PR | 优先级 |
NI | nice值。负值表示高优先级,正值表示低优先级 |
P | 最后使用的CPU,仅在多CPU环境下有意义 |
%CPU | 上次更新到现在的CPU时间占用百分比 |
TIME | 进程使用的CPU时间总计,单位秒 |
TIME+ | 进程使用的CPU时间总计,单位1/100秒 |
%MEM | 进程使用的物理内存百分比 |
VIRT | 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES |
SWAP | 进程使用的虚拟内存中,被换出的大小,单位kb |
RES | 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA |
CODE | 可执行代码占用的物理内存大小,单位kb |
DATA | 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb |
SHR | 共享内存大小,单位kb |
nFLT | 页面错误次数 |
nDRT | 最后一次写入到现在,被修改过的页面数。 |
S | 进程状态。D=不可中断的睡眠状态 R=运行 S=睡眠 T=跟踪/停止 Z=僵尸进程 |
COMMAND | 命令名/命令行 |
WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
Flags | 任务标志 |
33、查看进程
ps [-au]查看当前终端的进程。
ps -ef 查看系统全部的进程。
ps -ef |more 查看系统全部的进程,结果分页显示。
UID :启动进程的操作系统用户。
PID :进程编号。
PPID :进程的父进程的编号。
C :CPU使用的资源百分比。
STIME :进程启动时间。
TTY :进程所属的终端。
TIME :使用掉的CPU时间。
CMD :执行的是什么指令。
ps -ef |grep book 查看系统全部的进程,然后从结果集中过滤出包含“book”单词的记录。
34、查看当前运行的进程:ps aux | grep test
35、查看当前运行的轻量级进程:ps -aL | grep test
36、查看主线程和子线程的关系:pstree -p 主线程id
37、查看线程
在top命令中,如果加上-H参数,top中的每一行显示的不是进程,而是一个线程。
top -H
2)在ps命令中加-xH参数也可以显示线程,加grep可以过滤内容。
ps -xH
ps -xH|grep book261