linux shell命令
一、shell基本系统维护命令
(一)、man命令
1、使用man命令可以找到特定的联机帮助页,并提供简短的命令说明。一般语法格式为:
man commandname
2、联机帮助页提供了指定命令commandname的相关信息,包括:名称、函数、语法以及可选参数描述等。
无论帮助有多长,都遵循这个格式显示。在页面很多的情况下使用PageUp和PageDown键翻页。最后,使用“:q”退出帮助页面。
3、通常联机帮助信息包括以下几个部分:
(1)NAME:命令的名称
(2)SYNOPSIS:命令的语法格式
(3)DESCRIPTION:命令的一般描述以及用途
(4)OPTIONS:描述命令所有的参数或选项
(5)SEE ALSO:列出联机帮助页中与该命令直接相关或功能相近的其他命令
(6)BUGS:解释命令或其输出中存在的任何已知的问题或缺陷
(7)EXAMPLES:普通的用法示例
(8)AUTHORS:联机帮助页以及命令的作者
4、man 3 printf 查库函数
man 2 open 查系统调用
man -a open 会将系统中与open相关的都列出来
(二)、password命令
1) passwd
a. 出于系统安全考虑,Linux系统中的每一个帐号都必须同时具备用户名和密码。
b. 可以使用passwd命令,为已有账户重新修改用户口令。
c. 需要说明的是,超级用户root可以修改所有其他用户的口令,而普通用户只能修改自己的用户口令,
如果确要修改超级用户或其他用户口令的话,需要具有超级用户的权限。
d. passwd命令的一般语法格式为:
passwd username
2) 单独使用passwd命令,意为修改当前用户自己的口令。下面命令实例用于修改用户自己的口令。
linux@ubuntu:~$ passwd
Changing password for linux #修改当前用户口令
(current) UNIX password: #用户输入旧口令
Enter new UNIX password: #用户输入新口令
Retype new UNIX password: #确认新口令
passwd:已成功更新密码
(三)、su命令
a. su命令用于临时改变用户身份,具有其他用户的权限。普通用户可以使用su命令临时具有超级用户的权限;
超级用户也可以使用普通用户身份完成一些操作。当需要放弃当前用户身份,可以使用exit命令切换回来。su命令的一般语法格式为:
su [-c | -m - ] username
b.选项“-c”表示执行一个命令后就结束;-m表示仍保留环境变量不变;-表示转换用户身份时,同时使用该用户的环境。
单独使用su命令,默认为要转换为超级用户root。下面命令实例临时获取超级用户root的权限。
可以从命令提示符中可以看出,“linux”用户使用su命令切换为root用户。
linux@ubuntu:~$ su
Password: #当前用户输入超级用户的口令
root@ubuntu:/home/linux#
(四)、echo命令
a.echo命令用于在标准输出——显示器上显示一段文字,一般起到提示作用。
echo命令的一般语法格式为:
echo [-n] information
b.选项-n表示输出文字后不换行。提示信息字符串可以加引号,也可以不加。
linux@ubuntu:~$ echo "Hello everyone." #输入信息字符串使用引号
Hello everyone.
linux@ubuntu:~$ echo ‘$PATH’ #严格的原样输出
$PATH.
linux@ubuntu:~$ echo Hello everyone. #输入信息字符串不使用引号,字符串之间用一个空格隔开
Hello everyone.
( 五) 、 date命令
a. date命令用于显示和设置系统日期和时间。date命令的一般语法格式为:
date [-d | -s|-u ] datestr
b. 选项-s表示按照datestr日期显示格式设置日期;单独使用date命令,用于显示系统时钟中当前日期。
时间的格式为:“hh:mm:ss”,日期格式为:“mm/dd/yy”。
linux@ubuntu:~$ date #查看当前时间
2007年 09月 16日 星期日 18:44:45 CST
linux@ubuntu:~$ sudo date -s 1:19:18 #设置新时间,需要系统管理员权限
Password:
2007年 09月 16日 星期日 01:19:18 CST
(六)、 clear
a. clear命令用于清除屏幕上的信息。清屏后,sell命令提示符移动到屏幕左上角。
clear命令的一般语法格式为:
clear
b.由于shell命令是逐行执行,执行结果也将随即显示。因此,用户在使用命令终端窗口时,终端窗口会很快就会被字符占满。
clear可以帮助清理一下窗口中杂乱的字符显示。
(七)、df命令
a. df命令用于查看磁盘空间的使用情况。查看磁盘空间是用户应当经常做的事情,
因为谁也不希望看到根或/var分区在不经意间填满,以便及时清理。df命令的一般格式为:
df [-a | -T | -h | -k ] Filesystem
其中,参数Filesystem表示物理文件系统。各选项的含义如表所示。
选项 含义
-a 显示所有物理文件系统的使用情况,包括虚拟文件系统,如/proc、/sys等
-T 显示物理文件系统的文件格式类型
-h 物理文件系统大小按兆字节为单位显示
-k 物理文件系统大小按千字节为单位显示
b. 从以下命令的执行结果可以看到,这台计算机只有一块硬盘(/dev/sda1),文件格式类型为Ext3,已经使用36%的存储空间。
同时,可以发现计算机上还安装了CD-ROM(/dev/hdc)、USB存储器(/dev/sdb1)。其他分区均为专用的虚拟文件系统
linux@ubuntu:~$ df –T
文件系统 1K-块 已用 可用 已用% 挂载点
/dev/sda1 ext3 7850996 2664868 4787316 36% /
c. df 命令
常用参数:
-a :列出所有文件系统
-k :列出磁盘的分配情况(KB)
-h :同-k, 但大小以G、M,K单位显示
-l :仅列出本地文件系统
例:
#df -h
(八)、du命令
du命令,列出目录和文件所使用的磁盘块数,每块占512个字节。
常用参数:
-a :仅列出空闲的文件数
-h :列出磁盘的使用情况(KB)
-s :列出总的空闲空间(KB)
例:
#du –h /etc
二、linux 用户管理
(一)、用户管理相关文件介绍
1、用户管理
用户的属性
1)用户名
2)口令
3)用户ID(UID)
4)用户主目录(HOME)
5)用户shell
2、 /etc/passwd文件
/etc/passwd文件是系统能够识别的用户清单。用户登陆时,系统查询这个文件,确定用户的UID并验证用户口令
1)登陆名
2)经过加密的口令
3)UID
4)默认的GID
5)个人信息
6)主目录
7)登陆shell
3、 /etc/group文件
1)包含了UNIX组的名称和每个组中成员列表
2)每一行代表一个组,包括4个字段:
组名
加密的口令
GID号
成员列表,彼此用逗号隔开
4、添加用户
adduser
语法:adduser <username>
实例:
# adduser newuser
添加用户名为newuser的新用户
5、adduser配置文件
/etc/adduser.conf
FIRST_UID=1000
LAST_UID=29999
USERS_GID=100
DHOME=/home
DSHELL=/bin/bash
SKEL=/etc/skel
6、SKEL模板
/etc/skel目录是被 /usr/sbin/useradd使用
把想要新用户拥有的配置文件从/etc/skel目录拷贝,常用的文件:
.bash_profile
.bashrc
.bash_logout
dircolors
.inputrc
.vimrc
(二)、用户管理相关命令介绍
1、添加新用户的过程
1) 系统
编辑passwd和shadow文件,定义用户帐号
设置一个初始口令
创建用户主目录,用chown和chmod命令改变主目录的属主和属性
2) 为用户所进行的步骤
将默认的启动文件复制到用户主目录中
设置用户的邮件主目录并建立邮件别名
2、 设置初始口令
1) 使用passwd命令可以修改用户口令
2) root用户可以修改任何用户的口令
语法:passwd [-k] [-l] [u] [-f] [-d] [-S] username
使用方法:
passwd username
3、 修改用户属性
usermod
语法:usermod [-u uid [-o]] [-g group] [-G gropup,…]
[-d home [-m]] [-s shell] [-c comment]
[-l new_name] [-f inactive][-e expire]
[-p passwd] [-L|-U] name
举例用户oldname改名为newname,注意要同时更改家目录:
usermod –d /home/newname –m –l newname oldname
4、 删除用户
deluser
语法: deluser <username>
使用方法:
deluser --remove-home user1
删除用户user1的同时删除用户的工作目录
5、添加用户组
addgroup
语法: addgroup groupname
使用方法:
addgroup groupname
6、删除用户组
delgroup
语法: delgroup groupname
使用方法:
delgroup groupname1
三、进程管理相关命令
(一)、进程的概念
(1)编译程序上的两个进程
程序的一次执行就是一个进程 。
程序的两次执行就产生了p1和p2两个进程 。
(二)、使用ps命令查看进程
(1)显示进程(process)?的动态
cd /proc/
(2)语法:
ps [options]
(3)常见的参数:
-A 列出所有的行程
-w 显示加宽可以显示较多的资讯
-au 显示较详细的资讯
-aux/ -elf 显示所有包含其他使用者的行程
(4) %CPU 占用的 CPU 使用率
%MEN 占用的记忆体使用率
VS2 占用的虚拟记忆体大小
RSS 占用的记忆体大小
STAT 该进程的状态
START 进程开始时间
TIME 执行的时间
(5)进程的状态标志
D: 不可中断的静止
R: 正在执行中
S: 阻塞状态
T: 暂停执行
Z: 不存在但暂时无法消除
<: 高优先级的进程
N: 低优先级的进程
L: 有内存分页分配并锁在内存中
(6) top命令
1)监视进程
2)通常会全屏显示,而且会随着进程状态的变化不断更新
3)整个系统的信息也会显示,为查找问题提供了便利
4)可以显示系统总共有多少CPU和内存资源以及负载平衡等信息。
(7) pstree命令
1) 将所有行程以树状图显示,树状图将会以pid(如果有指定)或是以init这个基本进程为根,
如果有指定使用者id,则树状图会只显示该使用者所拥有的进程。
2)参数:
-a 显示该进程的完整指令及参数,如果是被记忆体置换出去的进程则会加上括号
-c 如果有重覆的进程名,则分开列出
(三)、使用kill命令终止进程
(1)使用kill命令终止进程
kill [-signal] PID -9:杀死
signal是信号,PID是进程号
kill 命令向指定的进程发出一个信号signal,在默认的情况下,kill 命令向指定进程发出信号15,
正常情况下,将杀死那些不捕捉或不忽略这个信号的进程
四、文件系统的类型和结构
(一)、Linux文件系统的类型
(1)在任何一个操作系统中,文件系统无疑是其最重要的组件,用于组织和管理计算机存储设备上的大量文件,
并提供用户交互接口。Linux同样具备完善的文件系统。用户既可以使用界面友好的Nautilus图形文件管理器,
也可以使用功能强大的shell文件系统管理工具。
(2)linux是一种兼容性很高的操作系统,支持的文件系统格式很多,大体可分以下几类:
1)磁盘文件系统:指本地主机中实际可以访问到的文件系统,包括硬盘、CD-ROM、DVD、USB存储器、磁盘阵列等。
常见文件系统格式有:autofs、coda、Ext(Extended File sytem,扩展文件系统)、Ext3、Ext4、VFAT、ISO9660(通常是CD-ROM)、
UFS(Unix File System,Unix文件系统)、FAT、FAT16、FAT32、NTFS等;
2)网络文件系统:是可以远程访问的文件系统,这种文件系统在服务器端仍是本地的磁盘文件系统,客户机通过网络远程访问数据。
常见文件系统格式有:NFS、Samba等;
3)专有/虚拟文件系统:不驻留在磁盘上的文件系统。常见格式有:TMPFS(临时文件系统)、PROCFS(Process File System,进程文件系统)
和LOOPBACKFS(Loopback File System,回送文件系统)。
(3) 目前Ext4是Linux系统广泛使用的一种文件格式。在Ext3基础上,对有效性保护、数据完整性、数据访问速度、向下兼容性等方面做了改进。
最大特点是日志文件系统:可将整个磁盘的写入动作完整地记录在磁盘的某个区域上,以便在必要时回溯追踪。
(4) SCSI与IDE设备命名
1)sata硬盘的设备名称是“/dev/sda”
/dev/sda1 含义?
/dev/sdb3 含义?
2)IDE硬盘的设备名称是“/dev/hda”
/dev/hdc2 含义?
3)如果很在意系统的高性能和稳定性,应该使用SCSI硬盘
4)cat /proc/partitions
(5) Linux分区的命名方式
1)字母和数字相结合
2)前两个字母表示设备类型
“hd”代表IDE硬盘
“sd”表示SCSI或SATA硬盘
3)第三个字母说明具体的设备
“/dev/hda”表示第一个IDE硬盘
“/dev/hdb”表示第二个IDE硬盘
(6) 交换分区
1)将内存中的内容写入硬盘或从硬盘中读出,称为内存交换(swapping)
2)交换分区最小必须等于计算机的内存
3)可以创建多于一个的交换分区
4)尽量把交换分区放在硬盘驱动器的起始位置
(7) 文件系统逻辑结构
1) 某所大学的学生可能在一两万人左右,通常将学生分配在以学院-系-班为单位的分层组织机构中。若需要查找一名学生时,
最笨的办法是依次问询大学中的每一个学生,直到找到为止。如果按照从学院、到系、再到班的层次查询下去,必然可以找到该学生,且查询效率高。
这种树形的分层结构就提供了一种自顶向下的查询方法。
2) 如果把学生看作文件,院-系-班的组织结构看作是Linux文件目录结构,那么就同样可以有效地管理数量庞大的文件。
3) 一直使用微软Windows操作系统的用户似乎已经习惯了将硬盘上的几个分区,并用A:、B:、C:、D:等符号标识。
存取文件时一定要清楚存放在哪个磁盘的哪个目录下。
4) Linux的文件组织模式犹如一颗倒置的树,这与Windows文件系统有很大差别。所有存储设备作为这颗树的一个子目录。
存取文件时只需确定目录就可以了,无需考虑物理存储位置。
(二)、Linux文件系统的结构
(1) 分区与目录的关系:
在Windows下,目录结构属于分区;在Linux下,分区属于目录结构。
(2) 如何知道文件存储的具体硬件位置呢?
1) 在Linux中,将所有硬件都视为文件来处理,包括硬盘分区、CD-ROM、软驱以及其他USB移动设备等。
为了能够按照统一的方式和方法访问文件资源,Linux中提供了对每种硬件设备相应的设备文件。
一旦Linux系统可以访问到硬件,就将其上的文件系统挂载到目录树中的一个子目录中。
2) 例如,用户插入USB移动存储器,Ubuntu Linux自动识别后,将其挂载到“/media/disk”目录下。
而不象Windows系统将USB存储器作为新驱动器,表示为“F:”盘。
(3) Linux文件系统就是一个树形的分层组织结构。将根(/)作为整个文件系统的惟一起点,其他所有目录都从该点出发。
将Linux的全部文件按照一定的用途归类,合理地挂载到这颗“大树”的“树枝”或“树叶”上,如图所示。
而这些全不用考虑文件的实际存储位置,无论是存在硬盘上,还是在CD-ROM或USB存储器中,甚至是网络终端。
(4) 基本目录
1) 由于Linux是完全开源的软件,各Linux发行机构都可以按照自己的需求对文件系统进行裁剪,所以如此众多的Linux发行版本的目录结构也不尽相同。
为了规范文件目录命名和存放标准,颁发了文件层次结构标准(FHS,File Hierarchy Standard),2004年发行版本FHS 2.3。Ubuntu Linux系统同样也遵循这个标准。
2) 绝对路径和相对路径
a. 在认识到Linux文件系统是树形分层的组织结构,且只有一个根节点之后。在Linux文件系统中查找一个文件,只要确定文件名和路径,就可以惟一确定这个文件。
例如 “/usr/games/gnect”
b. 绝对路径:指文件在文件系统中的准确位置。通常在本地主机上,以根目录为起点。例如“/usr/games/gnect”就是绝对路径。
c. 相对路径:指相对于用户当前位置的一个文件或目录的位置。例如,用户处在usr目录中时,只需要“games/gnect”就可确定这个文件。
(5) Linux文件系统与Windows文件系统比较
五、文件系统相关命令
(一)、file、mkdir、rmdir、ln命令
(1)文件和目录相关的命令
pwd ls cd touch cp mv rm cat head tail已经在C语言基础补习课程中讲过
(2)file命令
1) 在Linux文件系统中,文件扩展名不总是被使用或被一致地使用。如果一个文件没有扩展名,或者文件与其扩展名不符时怎么办呢?
file命令功能用于判定一个文件的类型。file命令一般语法格式为:
file [ filename ]
2) 其中filename是文件名。命令的输出将显示该文件是二进制文件、文本文件、目录文件、设备文件,还是Linux中其他类型的文件。
linux@ubuntu:~$ file /usr/games/banner
banner: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), for GNU/Linux 2.6.0, dynamically linked (uses shared libs), stripped
linux@ubuntu:~$ file Textfile.txt
Textfile.txt: UTF-8 Unicode text
(3)mkdir命令
1)mkdir命令用于创建一个目录。mkdir命令一般语法格式为:
mkdir [ -p ] directory_name
2)其中,directory_name为要创建的目录名,并且不能是已有的目录,通常不允许嵌套创建子目录。
3)使用选项“-p”表示可以嵌套创建子目录,即多层目录。
4)需要说明的是,创建目录的用户在工作目录应具有写入权限。假设要创建下面这样结构的目录。
dir1
dir1/dir2
dir1/dir2/dir3
当然可以使用三条mkdir命令依次创建各层目录。
linux@ubuntu:~$ mkdir dir1
linux@ubuntu:~$ mkdir dir1/dir2
linux@ubuntu:~$ mkdir dir1/dir2/dir3
不过使用“-p”选项会简单许多,一步达到目标。
linux@ubuntu:~$ mkdir –p dir1/dir2/dir3
linux@ubuntu:~$ ls –R dir1
dir1:
dir2
dir1/dir2:
dir3
dir1/dir2/dir3:
5)rmdir命令用于删除一个目录。rmdir命令一般语法格式为:
rmdir [ -p ] directory_name
其中,directory_name为要删除的一个或多个目录名。
使用选项“-p”表示可以递归删除子目录,即多层目录。
需要说明的是,删除的目录必须为空目录,并且必须具有对该目录有写入权限。
假设要删除下面这样结构的目录。
dir1
dir1/dir2
dir1/dir2/dir3
当然可以使用三条rmdir命令从里向外依次删除各层目录(保证删除的目录为空)
linux@ubuntu:~$ rmdir dir1/dir2/dir3
linux@ubuntu:~$ rmdir dir1/dir2
linux@ubuntu:~$ rmdir dir1/
不过使用“-p”选项可以一步到位。
以上命令的执行效果与“rm –r dir1”执行效果相同,并且后者的效率更高,因为它不要求各层目录均为空。
linux@ubuntu:~$ rmdir –p dir1/dir2/dir3
(6)创建链接文件
1) Linux中有两种类型的链接:
a. 硬链接是利用Linux中为每个文件分配的物理编号——inode建立链接。
因此,硬链接不能跨越文件系统。
b. 软链接(符号链接)是利用文件的路径名建立链接。
通常建立软链接使用绝对路径而不是相对路径,以最大限度增加可移植性。
2) 需要注意的是,如果是修改硬链接的目标文件名,链接依然有效;如果修改软链接的目标文件名,
则链接将断开;对一个已存在的链接文件执行移动或删除操作,有可能导致链接的断开。
假如删除目标文件后,重新创建一个同名文件,软链接将恢复,硬链接不再有效,因为文件的inode已经改变。
(7)ln命令
1)命令可以用于创建文件的链接文件。ln命令一般语法格式为:
ln [ -s ] target link_name
2)其中,选项“-s”表示为创建软链接。在缺省情况下,创建硬链接。参数target为目标文件,link_name为链接文件名。
如果链接文件名已经存在但不是目录,将不做链接。目标文件可以是任何一个文件名,也可以是一个目录。
linux@ubuntu:~$ ln -s /proc/cpuinfo mycpuinfo
linux@ubuntu:~$ ls –l mycpuinfo
lrwxrwxrwx 1 wdl wdl 13 2007-09-22 00:43 mycpuinfo -> /proc/cpuinfo
以上命令为/proc/cpuinfo文件创建了一个软链接文件。使用“ls –l”命令可以查看到新创建的链接文件所指向的目标文件名。
(二)、文件的归档和压缩
(1)压缩文件
用户在进行数据备份时,需要把若干文件整合为一个文件以便保存。尽管整合为一个文件进行管理,但文件大小仍然没变。
若需要网络传输文件时,就希望将其压缩成较小的文件,以节省在网络传输的时间。因此本节介绍文件的归档与压缩。
(2)
归档文件是将一组文件或目录保存在一个文件中。
压缩文件也是将一组文件或目录保存一个文件中,并按照某种存储格式保存在磁盘上,所占磁盘空间比其中所有文件总和要少。
a. 归档文件仍是没有经过压缩的,它所使用的磁盘空间仍等于其所有文件的总和。因而,用户可以将归档文件再进行压缩,使其容量更小。
b. gzip是Linux中最流行的压缩工具,具有很好的移植性,可在很多不同架构的系统中使用。bzip2在性能上优于gzip,提供了最大限度的压缩比率。
如果用户需要经常在Linux和微软Windows间交换文件,建议使用zip。
压缩工具 解压工具 文件扩展名
gzip gunzip .gz
bzip2 bunzip2 .bz2
zip unzip .zip
(3) 目前,归档工具使用最广泛的tar命令,可以把很多文件(甚至磁带)合并到一个称为tarfile的文件中,通常文件扩展名为.tar。
然后,再使用zip、gzip或bzip2等压缩工具进行压缩。
(4) shell归档和压缩工具
使用shell归档和压缩工具可以更直接地完成文档的打包任务。由于该类shell命令是成对使用的,因此下面按对介绍相关命令。
(5) gzip与gunzip命令
与zip明显区别在于只能压缩一个文件,无法将多个文件压缩为一个文件。gzip命令符号模式的一般语法格式为:
其中,filename表示要压缩的文件名,gzip会自动在这个文件名后添加扩展名为.gz,作为压缩文件的文件名。
gzip [ -l| -d | -num ] filename
选项 描述
-l 查看压缩文件内的信息,包括文件数、大小、压缩比等参数,并不进行文件解压
-d 将文件解压,功能与gunzip相同
-num 指定压缩比率,num为1~9个等级
gunzip命令符号模式的一般语法格式为:
gunzip [ -f ] file.gz
其中,选项“-f”用于解压文件时,对覆盖同名文件不做提示。
在执行gzip命令后,它将删除旧的未压缩的文件并只保留已压缩的版本。以下命令以最大的压缩率对文件file_1进行压缩,生成file_1.gz文件。
使用“-l”选项可以查看压缩的相关信息。最后使用gunzip命令对文件进行了解压。与压缩时相反,file_1.gz文件会被删除,继之生成file_1。
linux@ubuntu:~$ gzip -9 file_1
linux@ubuntu:~$ gzip -l file_1.gz
compressed uncompressed ratio uncompressed_name
1200 4896 76.0% file_1
linux@ubuntu:~$ gunzip file_1.gz
(6) tar命令
tar命令主要用于将若干文件或目录合并为一个文件,以便备份和压缩。当然,之后出现tar程序的改进版本,可以实现在合并归档的同时进行压缩。
tar命令符号模式的一般语法格式为:
tar [ -t | -x | -u | -c | -v | -f | -j | -z ] tarfile filelist
-t 显示归档文件的内容
-x 释放归档文件
-u 更新归档文件
-c 创建一个新的归档文件
-v 显示归档和释放的过程信息
-f 用户指定归档文件的文件名,否则使用默认名称
-j 由tar生成归档,然后由bzip2压缩
-z 由tar生成归档,然后由gzip压缩
第一,将myExamples/目录下的所有文件全部归档,打包到一个文件中myExamples.tar;
第二,将myExamples/目录下的所有文件全部归档,并使用bzip2压缩成一个文件myExamples.tar.bz;
第三,将myExamples/目录下的所有文件全部归档,并使用gzip压缩成一个文件myExamples.tar.gz。
linux@ubuntu:~$ tar –cf myExamples.tar myExamples
linux@ubuntu:~$ tar -cjf myExamples.tar.bz myExamples
linux@ubuntu:~$ tar -czf myExamples.tar.gz myExamples
linux@ubuntu:~$ ls -lh myExamples.tar*
-rw-r--r-- 1 wdl wdl 9.3M 2007-09-23 00:42 myExamples.tar
-rw-r--r-- 1 wdl wdl 8.6M 2007-09-23 00:43 myExamples.tar.bz
-rw-r--r-- 1 wdl wdl 8.5M 2007-09-23 00:44 myExamples.tar.gz
如果想查看一下归档文件中的详细内容,使用类似以下命令:
linux@ubuntu~$ tar –tvf myExamples.tar.gz
使用以下命令完成tar文件的释放。其中,“tar -xjf”和“tar –xzf”等效与先解压缩后释放tar文件。
linux@ubuntu:~$ tar –xvf myExamples.tar
linux@ubuntu:~$ tar -xvjf myExamples.tar.bz
linux@ubuntu:~$ tar -xvzf myExamples.tar.gz
六、网络配置
(一)、网络配置基础
(1)用户既可以通过命令行的方式,也可以通过友好的图形界面,轻松完成网络配置。
(2)实现Linux网络配置的惟一目标就是修改系统中众多的网络配置文件,
如/etc/interfaces、/etc/hosts,/etc/resolv.conf 等等。
(3)通常,用户可能使用普通以太网卡、无线网卡、调制解调器等不同类型的设备接入网络。
不同类型的网络设备在主机中被映射为相应的网络接口,比如以太网卡映射为eth,无线网卡映射为wlan。
有时,用户还可能同时使用多个网络设备,就会出现eth0、eth1…,或wlan0、wlan1…的情况。
那么,如何标识每个连接到Internet的网络接口呢?
解决办法是:为每个网络接口分配一个全世界范围内惟一的32bit的标识符。这个标识符就是IP(Internet Protocol)地址。
(二)、配置IP地址
(1)IP地址
IP地址包括三部分:Internet网络号(Net-ID)、子网号(Subnet-ID)和主机号(Host-ID)。
三级IP地址 net-id subnet-id host-id
子网掩码 1111,1111,1111,1111 1111,1111 0000,0000
(2)因而可以这样解释:一个IP地址惟一标识了,处在某个互联网中的,某个子网的,某个网络接口。
(3)根据Internet网络号的字段长度(1,2,3字节长),IP地址区分为A类、B类、C类。三类IP地址的掩码如下所示。
1) A类地址的默认子网掩码是255.0.0.0,或0xFF000000;
2) B类地址的默认子网掩码是255.255.0.0,或0xFFFF0000;
3) C类地址的默认子网掩码是255.255.255.0,或0xFFFFFF00;
(4) IP网络中通常用最小的IP地址标识网络本身,将最大的IP地址作为该网络的广播地址,其余所有IP地址都分配给网络中的主机。
然而,局域网中的主机并不能直接访问Internet,需要通过一个作为代理的网关或网络地址转换服务(NAT)才能访问Internet。
通常将IP地址的第一个或最后一个留给该网络的Internet网关。
(5) 配置IP地址
接入网络的计算机主机依靠IP地址,惟一地标识其在网络中的身份,因此为主机配置IP地址是接入网络的关键。
配置IP地址的方法有两种:
1) 配置静态IP:在主机进入网络之前,事先为主机设置固定的IP地址;
2) 配置动态IP:选择DHCP网络服务,在主机进入网络之后,动态随机获取IP地址。
(三)、网络相关命令
(1) Ifconfig命令
ifconfig是GNU/Linux中配置网卡的基本命令,包含在net-tools软件包中。它可用于显示或设置网卡的配置,
如IP地址、子网掩码、最大分组传输数、IO端口等,还可以启动或禁用网卡。
ifconfig命令有以下两种格式:
ifconfig [interface]
ifconfig interface [aftype] option | address…
ifconfig的第一种格式用于查看当前系统的网络配置情况;
第二种格式用于配置网卡,包括添加、删除网卡,以及绑定多个IP地址等。
1) 如果主机安装了第二块、第三块网卡,则有eth1,eth2标识。常见的接口类型还有以下几种(N表示接口号):
2) pppN表示调制解调设备
3) wlanN表示无线网卡
4) trN表示令牌环网卡
5) 如果只是关心某个网络设备,可以在ifconfig后面加上接口名称,则只显示该设备的相关信息,例如:
linux@ubuntu:~$ ifconfig eth1
6) 假设主机现有的IP地址为192.168.182.129,需要为其重新分配IP地址192.168.182.128,即。使用ipconfig命令设置主机的第一块网卡(eth0)的IP地址。
(2) 配置动态IP地址
1) 在大型网络中,由于存在许多的移动计算机系统,随时都可能进入网络,在每次更换网络时,就不得不重新配置网络信息。
如果计算机在网络里能够自动获取IP地址、子网掩码、路由表、DNS服务器地址等网络信息,具有动态配置IP的能力,就可以大大简化客户端的网络配置难度。
动态主机配置协议(DHCP,Dynamic Host Configuration Protocol)可以实现动态分配IP资源。
2) 只要在局域网中架设有DHCP服务器,在Ubuntu Linux中为主机配置DHCP客户端是非常容易的。需要说明的是,通常普通以太网卡和无线网卡可以配置动态IP,
而调制解调器等网络设备不能配置动态IP。
linux@ubuntu:~$ dhclient
3) 动态IP的获取过程
可比作一个“租赁”过程。DHCP服务器好比是IP地址的出租方,用户主机(即DHCP客户端)好比是IP地址的临时租用者。
如果将用户主机设置为DHCP客户端之后,手动启动网络服务,就可以从执行结果中看出获取动态IP的过程。
执行过程中包括以下四个阶段。
a. 客户端寻找DHCP服务器(DHCPDISCOVER):客户端广播申请动态IP的请求;
b. 服务器提供可分配的IP地址(DHCPOFFER):所有接收到请求的DHCP服务器都将向客户端提供一个IP地址;
c. 客户端接受IP地址租借(DHCPREQUEST):客户端从多个IP选择中挑选一个,通知DHCP服务器,并标识出所选中的服务器;
d. 服务器确认租借IP(DHCPACK):被选中的DHCP服务器最后发出一个确认信息,包含IP地址、子网掩码、默认网关、DNS服务器和租借期(客户端使用这个IP的这段时间,称为租借期)。
最终客户端临时“租借”的IP地址为192.168.182.129。
(3) IP地址存放在哪里——interfaces配置文件
无论是配置静态IP还是动态IP,计算机系统将IP信息保存放在什么地方?答案是配置文件“/etc/network/interfaces”。
在Ubuntu Linux启动时就能获得IP地址的配置信息。若是配置静态IP,就从配置文件中读取IP地址参数,直接配置网络接口设备;
若是配置动态IP,就通知主机通过DHCP协议获取网络配置。
以下分别为配置静态IP和动态IP时,配置文件“/etc/network/interfaces”的实例。
(4) DNS客户端配置文件—resolv.conf
1) Ubuntu Linux将DNS服务器地址保存在配置文件/etc/resolv.conf中。
2) 依然延续上面的例子,添加DNS服务器IP地址后,查看配置文件/etc/hosts,如下所示。
linux@ubuntu:~$ cat /etc/resolv.conf
nameserver 172.16.28.1
nameserver 202.204.58.2
nameserver 192.168.182.2
(5) ping命令
1) ping(Packet Internet Groper)命令可能是最有名气的网络连接检测工具。
它使用了Internet控制报文协议(ICMP)回送请求与回送应答报文,测试两个主机之间的连通性。该命令的一般格式如下所示。
2) ping命令测试的远程主机,既可用域名,也可用IP地址标识。
ping [DomainName | IP-address]
3) 可以使用该命令来判断主机与远程主机是否可达,或之间的网络是否拥塞。min/avg/max/mdev是ping命令的完成测试后的统计结果,
分别表示最小响应时间/平均响应时间/最大响应时间/响应时间方差。这些指标用于反应网络的联通程度。
linux@ubuntu:~$ ping www.ustb.edu.cn
4) ping命令执行时,会持续不断地向目的主机发送ICMP包。在得到对方的应答后,显示每次连接的统计数据,直到用Ctrl+C组合键中断执行。
但是,目前很多主机通过设置防火墙,对ping命令不予应答。在这种情况下,ping命令由于不停地发送测试数据包,又得不到返回任何结果,而致使ping命令僵死。
不过,使用-c参数设置发送测试数据包的次数,以便在有限时间内完成测试。
linux@ubuntu:~$ ping -c 3 www.google.com
PING www-china.l.google.com (66.249.89.99) 56(84) bytes of data.
--- www-china.l.google.com ping statistics ---
3 packets transmitted, 0 received, 100% packet loss, time 2000ms
(6) 管理DNS服务器地址
1) DNS域名解析可以在更大范围的计算机网络、Internet,提供域名到IP地址的转换。
网络中的每台计算机都是一个DNS客户端,向DNS服务器提交域名解析的请求;DNS服务器完成域名到IP地址的映射。
2) 因此DNS客户端至少有一个DNS服务器地址,作为命名解析的开端。
(7) nslookup命令
1) 使用nslookup命令可以查看当前系统所使用的DNS服务器的IP地址。
linux@ubuntu:~$ nslookup www.google.com
Server: 192.168.182.2
Address: 192.168.182.2#53
Non-authoritative answer:
www.google.com canonical name = www.l.google.com.
www.l.google.com canonical name = www-china.l.google.com.
Name: www-china.l.google.com
Address: 66.249.89.99
2) 服务器192.168.182.2完成了域名解析。Server表示提供服务的DNS服务器,Address中的#53表示TCP/UDP命名服务的端口号。
若所有的DNS服务器都访问失败,则出现如下的执行结果。
linux@ubuntu:~$ nslookup www.google.com
;; connection timed out; no servers could be reached