发表时间:2012-07-11
最后修改:2012-07-11
Linux虽然是免费的,但它的确是一个非常优秀的操作系统,与MS-WINDOWS相比具有可靠、 稳定、速度快等优点,且拥有丰富的根据UNIX版本改进的强大功能。下面让我们一起来学习Linux的一些主要命令。有一点一定要注意,和dos命令不同的是,Linux的命令(也包括文件名等等)对大小写是敏感的。
sbin 系统底层命令存放目录
bin 一般用户常用命令目录
一年多linux(字符界面)使用记录大概使用了以下命令,我按照自己意思把linux(centos)命令大概分为几种类型,有些也不是很合理的分类:
文件用户管理
ls -lh
显示权限
cp -r
复制文件 文件夹
mkdir test
创建文件夹
rm -rf
删除文件 文件夹
mv
源目录 目标目录
移动文件或者文件夹
touch
建立空文件
ln -s
源文件路径 目标文件
cp -rf
r代表递归目录 f代表不提示强制
passwd user1
修改一个用户的口令 (只允许root执行)
usermod -g
组名 用户名
改变用户所在组
usermod -d
目录名 用户名
改变用户登入初始 所在目录
useradd
添加用户
useradd -g
组名 用户名
userdel
删除用户 -r
groupadd groupname
组添加
groupdel groupname
组删除
chmod
权限编号 用户名
chgrp testgroup test3.txt
改变文件所属组
chgrp -R testgroup testdir/
改变目录所属组
chown testuser test.txt
改变文件拥有者
chmod a+x
改变文件权限 可执行
chattr
改变文件的特殊属性
chattr +a file1
只允许以追加方式读写文件
lsattr file
显示文件的特殊属性!
umask
改变预设的建立文件或目录时的属性
cat file
由第一行开始显示文件内容
tac file
从最后一行开始显示,可以看出 tac 是 cat 的倒着写!
more file
一页一页的显示文件内容
less file
与 more 类似,但是比 more 更好的是,他可以往前翻页!
head file
只看头几行
tail file
只看尾巴几行
nl file
显示的时候,顺道输出 行号!
od file
以二进制的方式读取文件内容!
gzip
压缩 zaa.zip 文件名称 -r aa.zip 目录路径 代表压缩目录 -m代表删除源文件
unzip
解压缩 -x abc 排除abc文件外 其他都解压
rpm -qa | grep 软件包名称
查看是否安装该软件
rpm -ivh 软件包名称
安装软件
rpm -e
卸载软件
make
多文件编译
tar -zvxf filename.tar
打开压缩文件
rpm -ql | grep mysql
查找mysql已安装的包
rpm -e 包的名字
,强制删除加参数 --nodeps
rpm -qa
显示系统中所有已经安装的rpm包
yum install 包名字
yum安装
yum remove 包名字
yum删除
yum list
列出当前系统中安装的所有包
file
可以用来查看这个文件的类型
diff
这个指令可以将『两个文件之间的差异性列出来』
patch
来进行更新,将 expatch.old 更新到 expatch.new
patch -p0 < expatch.patch
ldd /usr/bin/passwd
判断某个可执行的 binary 文件含有什么动态函式库
which
查看可执行文件的位置
whereis
查看文件的位置
locate
配合数据库查看文件位置
vi 编辑文件内容 通用
grep -n "关键字" 文件
查找文件内容
find
查找文件
find -size +1000000c -print
#查长度大于1Mb的文件
find /home -mmin +60
# 在/home下查60分钟前改动过的文件
find /home -size +512k
#
查大于512k的文件
find / -mmin -5
#
查找在系统中最后5分钟里修改过的文件
ls a*
a开头所有
ls a?
a开头只有两个字符的
ls abc[1-6]
以开始abc后面1-6数字结尾的文件
ls 》cmd
输出文件夹内容
ls -ahl
查看文件所在组
磁盘管理
ls
查看目录
cd
进入目录 ..代表上一级 cd直接进入工作目录 .代表当前目录
pwd
显示当前目录
df
/目录 查看目录在系统分区挂载点
mount
/目录 挂载目录
umount
/目录 卸载挂载点
head -n 1 /etc/issue
查看操作系统版本
cat /proc/cpuinfo
查看CPU信息
hostname
查看计算机名
lspci -tv
列出所有PCI设备 (centos6)需要安装 pciutils
lsusb -tv
列出所有USB设备 (centos6)需要安装 usbutils
lsmod
列出加载的内核模块
env
查看环境变量
echo $path
查看环境变量
free -m
查看内存使用量和交换区使用量
du -sh <目录名>
查看指定目录的大小
grep MemTotal /proc/meminfo
查看内存总量
grep MemFree /proc/meminfo
查看空闲内存量
uptime
查看系统运行时间、用户数、负载
cat /proc/loadavg
查看系统负载
sar
来看系统的资源
du
来知道目前磁盘的文件容量
hdparm -i /dev/hda
查看磁盘参数(仅适用于IDE设备)
dmesg | grep IDE
查看启动时IDE设备检测状况
dump -0aj -f /tmp/home0.bak /home
制作一个 '/home' 目录的完整备份
dump -1aj -f /tmp/home0.bak /home
制作一个 '/home' 目录的交互式备份
restore -if /tmp/home0.bak
还原一个交互式备份
网络通讯
netstat -lntp
查看所有监听端口
netstat -antp
查看所有已经建立的连接
netstat -s
查看网络统计信息
traccroute
追踪路由
route -n
查看路由表
ping
查看网络是否畅通
系统管理
chkconfig --list
列出所有系统服务
chkconfig --list | grep on
列出所有启动的系统服务
cut -d: -f1 /etc/passwd
查看系统所有用户
cut -d: -f1 /etc/group
查看系统所有组
crontab -l
查看当前用户的计划任务
crontab -e
例行性工作编辑
ifconfig
查看ip配置
kill
杀死进程 -9 强制杀死
ps -aux
查看进程信息
top
显示系统重要信息 包括内存 cpu 负载 登入用户
setup
图形化界面配置系统信息
runlevel
显示当前运行级别
w
查看活动用户
id <用户名>
查看指定用户信息
last
查看用户登录日志
who
问问自己是谁
exit
退出当前用户
uname -a
查看内核/操作系统/CPU信息
fdisk -l
查看所有分区
echo $0
查看系统当前用户转换后的shell
echo $shell
查看系统默认使用shell
/etc/shells
查看shell列表
sh
转换sh
bash
转换bash
redhat系统 chsh -s 转换shell 需要注销才能转换不同的shell
shutdown
关机相关 -h 关机 -r now 重启
su - user
切换用户
su
切换root
reboot
系统重启
mount | column -t
查
看挂接的分区状态
swapon -s
查看所有交换分区
iptables -L
查看防火墙设置
mke2fs
建立Linux系统使用的ext2文件系统
fsck
检查和维护不一致的文件系统。若系统掉电或磁盘发生问题,可利用fsck命令对文件系统进行检查修理磁盘
mkfs.ext3
建立为ext2/ext3文件系统
dumpe2fs
查看特定设备上现存的文件系统的超级块(super block)和块群(blocks group)的信息
mkswap /dev/hda3
创建一个swap文件系统
service
服务名称 restart stop start 服务重启等
其他
history
查看历史命令
clear
清理屏幕
su
切换超级管理用户
sudo passwd root
超级管理用户密码
bc
计算器
cal
日期
date
时间 月 年
wall
发送消息给所有登入用户
write
发送消息给某个用户
mesg
阻挡其他用户传递过来的消息
mail
发送邮箱给用户
pidof :
找出某支正在运行的程序的 PID
fuser:
藉由文件(或文件系统)找出正在使用该文件的程序
vmstat :
侦测系统资源变化
dmesg :
分析核心产生的信息
------------------------------------------
下面是比较重要的命令详解 经常用到
top、ps、setup命令详解,vi使用
1 top命令
top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器。下面详细介绍它的使用方法。
top 显示结果如下所示:
01:06:48 up 1:22, 1 user, load average: 0.06, 0.60, 0.48
Tasks: 29 total, 1 running, 28 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.3% user, 1.0% system, 0.0% nice, 98.7% idle, 0.0% wa, 0.0% hi, 0.0% si
Mem: 191272k total, 173656k used, 17616k free, 22052k buffers
Swap: 192772k total, 0k used, 192772k free, 123988k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1379 root 16 0 7976 2456 1980 S 0.7 1.3 0:11.03 sshd
14704 root 16 0 2128 980 796 R 0.7 0.5 0:02.72 top
1 root 16 0 1992 632 544 S 0.0 0.3 0:00.90 init
2 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0
3 root RT 0 0 0 0 S 0.0 0.0 0:00.00 watchdog/0统计信息区
前五行是系统整体的统计信息。
第一行是任务队列信息
,同uptime命令的执行结果。其内容如下:
01:06:48 当前时间
up 1:22 系统运行时间,格式为时:分
1 user 当前登录用户数
load average: 0.06, 0.60, 0.48系统负载,即任务队列的平均长度。
三个数值分别为1分钟、5分钟、15分钟前到现在的平均值。
第二、三行为进程和CPU的信息。当有多个CPU时,这些内容可能会超过两行。内容如下:
Tasks: 29 total 进程总数
1 running 正在运行的进程数
28 sleeping 睡眠的进程数
0 stopped 停止的进程数
0 zombie 僵尸进程数
Cpu(s): 0.3% us 用户空间占用CPU百分比
1.0% sy 内核空间占用CPU百分比
0.0% ni 用户进程空间内改变过优先级的进程占用CPU百分比
98.7% id 空闲CPU百分比
0.0% wa 等待输入输出的CPU时间百分比
0.0% hi
0.0% si
最后两行为内存信息。
内容如下:
Mem: 191272k total物理内存总量
173656k used 使用的物理内存总量
17616k free 空闲内存总量
22052k buffers 用作内核缓存的内存量
Swap: 192772k total交换区总量
0k used 使用的交换区总量
192772k free 空闲交换区总量
123988k cached 缓冲的交换区总量。
内存中的内容被换出到交换区,而后又被换入到内存,但使用过的交换区尚未被覆盖,
该数值即为这些内容已存在于内存中的交换区的大小。
相应的内存再次被换出时可不必再对交换区写入。
进程信息区
统计信息区域的下方显示了各个进程的详细信息。首先来认识一下各列的含义。
序号 列名 含义
a PID 进程id
b PPID 父进程id
c RUSER Real user name
d UID 进程所有者的用户id
e USER 进程所有者的用户名
f GROUP 进程所有者的组名
g TTY 启动进程的终端名。不是从终端启动的进程则显示为?
h PR 优先级
i NI nice值。负值表示高优先级,正值表示低优先级
j P 最后使用的CPU,仅在多CPU环境下有意义
k %CPU 上次更新到现在的CPU时间占用百分比
l TIME 进程使用的CPU时间总计,单位秒
m TIME+ 进程使用的CPU时间总计,单位1/100秒
n %MEM 进程使用的物理内存百分比
o VIRT 进程使用的虚拟内存总量,单位kb。VIRT=SWAP+RES
p SWAP 进程使用的虚拟内存中,被换出的大小,单位kb。
q RES 进程使用的、未被换出的物理内存大小,单位kb。RES=CODE+DATA
r CODE 可执行代码占用的物理内存大小,单位kb
s DATA 可执行代码以外的部分(数据段+栈)占用的物理内存大小,单位kb
t SHR 共享内存大小,单位kb
u nFLT 页面错误次数
v nDRT 最后一次写入到现在,被修改过的页面数。
w S 进程状态。
D=不可中断的睡眠状态
R=运行
S=睡眠
T=跟踪/停止
Z=僵尸进程
x COMMAND命令名/命令行
y WCHAN 若该进程在睡眠,则显示睡眠中的系统函数名
z Flags 任务标志,参考sched.h
默认情况下仅显示比较重要的PID、USER、PR、NI、VIRT、RES、SHR、S、%CPU、%MEM、TIME+、COMMAND列。可以通过下面的快捷键来更改显示内容。
------------------------------------------
2 ps 命令说明
ps命令就是最基本同时也是非常强大的进程查看命令.使用该命令可以确定有哪些进程正在运行和运行的状态、进程是否结束、进程有没有僵死、哪些进程占用了过多的资源等等.总之大部分信息都是可以通过执行该命令得到的
top 显示结果如下所示:
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 3532 0.0 0.2 2428 452 ? Ss 20:40 0:00 gpm -m /dev/input/mice -t imps2
USER:说明该程序是属于哪一个人的;
PID:该程序的代号;
%CPU:代表该程序使用了多少 CPU 资源;
%MEM:代表该程序使用了多少的 RAM ;
VSZ, RSS:占去的 ram 的大小( bytes );
TTY:是否为登入者执行的程序?若为 tty1-tty6 则为本机登入者,若为 pts/?? 则为远程登入者执行的程序
STAT:该程序的状态,( R )为可执行的,( S )为该程序正在睡眠中,就是没有执行了,( T )正在侦测或者是停止了,( Z )僵尸程序,就是 zombie 死掉的程序啦!需要以 kill 除去啰!
START:该程序开始的日期;
TIME:该程序跑了多久的时间?
COMMAND:该程序的内容啦!
------------------------------------------
3 setup介绍
setup是redhat系列(包括centos,fedora等)里很好用的一个工具,不过可惜的是其它发行版里并没有。
为了系统的干净高效,安装系统时使用centos 6最小化安装(为了可以手工编译一些软件包,在安装时选择了马上定制,多选择了开发工具),装完了配置系统时,发现没有setup这个工具,whereis setup ,结果是空的。yum install setup, 系统提示已经安装了setup包。上网查,原来这个包的名字不叫setup, 而是setuptool,
yum install setuptool
不过运行这时setup只有Authentication configuration可用
防火墙的配置包叫system-config-firewall, yum安装,自动安装两个依赖包:system-config-firewall-tui, system-config-firewall-base.
通过yum list system-config*查询有好几个相关的包,应该都是与setup功能有关的
system-config-firewall.noarch
system-config-firewall-base.noarch
system-config-firewall-tui.noarch
system-config-date.noarch
system-config-date-docs.noarch
system-config-kdump.noarch
system-config-keyboard
system-config-kickstart.noarch
system-config-language.noarch
system-config-lvm.noarch
system-config-network-tui.noarch
system-config-printer
system-config-printer-libs
system-config-printer-udev
system-config-services.noarch
system-config-services-docs
system-config-users.noarch
system-config-users-docs.noarch
另外还有一个服务配置工具,它的名字比较特殊,跟上面所述包名字完全不一样,它叫ntsysv
运行yum install ntsysv 安装setup的服务设置工具
不过,系统配置方面,能手工做就手工做,借助图形化工具不是提高水平的途径。
setup是一个设置公用程序,提供图形界面的操作方式。在setup中可设置7类的选项:
1.登陆认证方式
2.键盘组态设置
3.鼠标组态设置
4.开机时所要启动的系统服务
5.声卡组态设置
6.时区设置
7.X Windows组态设置
------------------------------------------
4 vi使用
vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令。由于
对Unix及Linux系统的任何版本,vi编辑器是完全相同的,因此您可以在其他任何介绍vi的地方进一步了解它。Vi也是Linux中最基本的文本编
辑器,学会它后,您将在Linux的世界里畅行无阻。
一般模式:
以 vi 处理一个文件的时后,一进入该文件就是一般模式了。在这个模式中,你可以使用『上下左右』按键来移动光标,您可以使用『删除字符』或『删除整行』来处理文件内容,也可以使用『复制、贴上』来处理您的文件数据。
编辑模式:
在一般模式中可以处理删除、复制、贴上等等的动作,但是却无法编辑的!要等到您按下『i, I, o, O, a, A, r, R』等字母之后才会进入编辑模式。注意了!通常在 Linux 中,按下上述的字母时,在画面的左下方会出现『 INSERT 或 REPLACE 』的字样,才可以输入任何字来输入到您的文件中!而如果要回到一般模式时,则必须要按下『Esc』这个按键即可退出编辑模式。
指令列命令模式:
在一般模式当中,输入『 : 或 / 』就可以将光标移动到最底下那一行,在这个模式当中,可以提供您『搜寻资料』的动作,而读取、存盘、大量取代字符、离开 vi 、显示行号 等等的动作则是在此模式中达成的!
一般模式: 移动光标
h 或 向左方向键
光标向左移动一个字符
j 或 向下方向键
光标向下移动一个字符
k 或 向上方向键
光标向上移动一个字符
l 或 向右方向键
光标向右移动一个字符
[Ctrl] + [f]
屏幕『向前』移动一页(常用)
[Ctrl] + [b]
屏幕『向后』移动一页(常用)
[Ctrl] + [d]
屏幕『向前』移动半页
[Ctrl] + [u]
屏幕『向后』移动半页
+
光标移动到非空格符的下一列
-
光标移动到非空格符的上一列
n<space>
按下数字后再按空格键,光标会向右移动这一行的 n 个字符。例如 20<space> 则光标会向后面移动 20 个字符距离。
0
这是数字『 0 』:移动到这一行的最前面字符处(常用)
$
移动到这一行的最后面字符处(常用)
H
光标移动到这个屏幕的最上方那一行
M
光标移动到这个屏幕的中央那一行
L
光标移动到这个屏幕的最下方那一行
G
移动到这个文件的最后一行(常用)
nG
移动到这个文件的第 n 行。例如 20G 则会移动到这个文件的 20 行(可配合 :set nu)
n<Enter>
光标向下移动 n 行(常用)
一般模式: 搜寻与取代
/word
向光标之后寻找一个字符串名称为 word 的字符串。(常用)
?word
向光标之前寻找一个字符串名称为 word 的字符串。
:n1,n2s/word1/word2/g
在第 n1 与 n2 行之间寻找 word1 这个字符串,并将该字符串取代为 word2 !(常用)
:1,$s/word1/word2/g
从第一行到最后一行寻找 word1 字符串,并将该字符串取代为 word2 !(常用)
:1,$s/word1/word2/gc
从第一行到最后一行寻找 word1 字符串,并将该字符串取代为 word2 !且在取代前显示提示字符给使用者确认(conform)是否需要取代!(常用)
一般模式: 删除、复制与贴上
x, X
x 为向后删除一个字符, X 为向前删除一个字符(常用)
nx
向后删除 n 个字符
dd
删除游标所在的那一整列(常用)
ndd
删除光标所在的向下 n 列,例如 20dd 则是删除 20 列(常用)
d1G
删除游标所在到第一行的所有数据
dG
删除游标所在到最后一行的所有数据
yy
复制游标所在的那一行(常用)
nyy
复制光标所在的向下 n 列,例如 20yy 则是复制 20 列(常用)
y1G
复制游标所在列到第一列的所有数据
yG
复制游标所在列到最后一列的所有数据
p, P
p 为复制的数据在光标下一行贴上,P 则为贴在游标上一行!(常用)
J
将光标所在列与下一列的数据结合成同一列
c
重复删除多个数据,例如向下删除 10 行,[ 10cj ]
u
复原前一个动作。(常用)
进入编辑模式
i, I
插入:在目前的光标所在处插入输入之文字,已存在的文字会向后退;(常用)
a, A
增加:由目前光标所在的下一个字开始输入,已存在的文字会向后退:(常用)
o, O
插入新的一行:从光标所在的下一行枝行首开始输入文字;(常用)
r, R
取代:r 会取代光标所在的那一个字符;R会一直取代光标所在的文字,直到按下 ESC 为止;(常用)
Esc
退出编辑模式,回到一般模式中(常用)
指令列命令模式
:w
将编辑的数据写入硬盘文件中(常用)
:w!
若文件属性为『只读』时,强制写入该文件
:q
离开 vi (常用)
:q!
若曾修改过文件,又不想储存,使用 ! 为强制离开不储存文件。
:wq
储存后离开,若为 :wq! 则为强制储存后离开(常用)
:e!
将文件还原到最原始的状态!
ZZ
若文件没有更动,则不储存离开,若文件已经经过更动,则储存后离开!
:w [filename]
将编辑的数据储存成另一个文件(类似另存新档)
:r [filename]
在编辑的数据中,读入另一个文件的数据。亦即将 『filename』这个文件内容加到游标所在行后面
:set nu
显示行号,设定之后,会在每一行的前缀显示该行的行号
:set nonu
与 set nu 相反,为取消行号!
n1,n2 w [filename]
将 n1 到 n2 的内容储存成 filename 这个文件。
:! command
暂时离开 vi 到指令列模式下执行 command 的显示结果!例如[ :! ls /home ]
------------------------------------------
命令查看帮助三种方式
info command
command --help
man command