快速掌握Linux操作系统
一、Linux 简介
二、Linux的结构组成
相信组装过电脑的朋友都知道,我们的电脑最主要的几个零件是:CPU、内存、硬盘。但我们实际使用的时候,我们并不会主动跟硬件打交道,而是和显示器上显示的操作系统打交道。那么问题来了,操作系统到底是怎么操作CPU、内存、硬盘,让其实现我们的功能的呢?操作系统与硬件之间的层级结构是怎样的?
了解过 Linux 的朋友会知道,Linux系统一般有4个主要部分:内核、shell、文件系统和应用程序。内核、shell和文件系统一起形成了基本的操作系统结构,它们使得用户可以运行程序、管理文件并使用系统。层次结构如下图所示。
紧挨着硬件的是内核,只有内核才能操作硬件,一般我们也叫它内核空间。
2、系统的基石:系统调用
3、集大成者:库函数
4、效率利器:Shell
5、友好使者:应用
Linux最初是由芬兰赫尔辛基大学学生Linus Torvalds由于自己不满意教学中使用的MINIX操作系统,所以在1990年底由于个人爱好设计出了LINUX系统核心。后来发布于芬兰最大的ftp服务器上,用户可以免费下载,所以它的周边的程序越来越多,Linux本身也逐渐发展壮大起来,之后Linux在不到三年的时间里成为了一个功能完善,稳定可靠的操作系统。
四、Linux的特点
1、开放性,多用户,多任务,丰富的网络功能,可靠的系统安全,良好的可移植性,具有标准兼容性,良好的用户界面(命令界面,图形界面等),出色的速度性能。
2、基于GPL(通用公共许可证)。
五、Linux发展与未来
现在有很多公司都在使用Linux操作系统,Linux操作系统从桌面到服务器,从操作系统到嵌入式系统,从零散的应用到整个产业都初见雏形。Linux服务器操作系统在整个服务器操作系统市场格局中占据了越来越多的市场份额,并且形成了大规模的应用局面。
六、Linux目录结构
登录系统后,在当前命令窗口下输入命令,你会看到如下图所示:
树状目录结构:
以下是对这些目录的解释:
/bin:
bin 是 Binaries (二进制文件) 的缩写, 这个目录存放着最经常使用的命令。
/boot:
这里存放的是启动 Linux 时使用的一些核心文件,包括一些连接文件以及镜像文件。
/dev:
dev 是 Device(设备) 的缩写, 该目录下存放的是 Linux 的外部设备,在 Linux 中访问设备的方式和访问文件的方式是相同的。
/etc:
etc 是 Etcetera(等等) 的缩写,这个目录用来存放所有的系统管理所需要的配置文件和子目录。
/home:
用户的主目录,在 Linux 中,每个用户都有一个自己的目录,一般该目录名是以用户的账号命名的,如上图中的 alice、bob 和 eve。
/lib:
lib 是 Library(库) 的缩写这个目录里存放着系统最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要用到这些共享库。
/lost+found:
这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件。
/media:
linux 系统会自动识别一些设备,例如U盘、光驱等等,当识别后,Linux 会把识别的设备挂载到这个目录下。
/mnt:
系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将光驱挂载在 /mnt/ 上,然后进入该目录就可以查看光驱里的内容了。
/opt:
opt 是 optional(可选) 的缩写,这是给主机额外安装软件所摆放的目录。比如你安装一个ORACLE数据库则就可以放到这个目录下。默认是空的。
/proc:
proc 是 Processes(进程) 的缩写,/proc 是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,这个目录是一个虚拟的目录,它是系统内存的映射,我们可以通过直接访问这个目录来获取系统信息。
这个目录的内容不在硬盘上而是在内存里,我们也可以直接修改里面的某些文件,比如可以通过下面的命令来屏蔽主机的ping命令,使别人无法ping你的机器:
echo 1 > /proc/sys/net/ipv4/icmp_echo_ignore_all
/root:
该目录为系统管理员,也称作超级权限者的用户主目录。
/sbin:
s 就是 Super User 的意思,是 Superuser Binaries (超级用户的二进制文件) 的缩写,这里存放的是系统管理员使用的系统管理程序。
/selinux:
这个目录是 Redhat/CentOS 所特有的目录,Selinux 是一个安全机制,类似于 windows 的防火墙,但是这套机制比较复杂,这个目录就是存放selinux相关的文件的。
/srv:
该目录存放一些服务启动之后需要提取的数据。
/sys:
这是 Linux2.6 内核的一个很大的变化。该目录下安装了 2.6 内核中新出现的一个文件系统 sysfs 。sysfs 文件系统集成了下面3种文件系统的信息:针对进程信息的 proc 文件系统、针对设备的 devfs 文件系统以及针对伪终端的 devpts 文件系统。该文件系统是内核设备树的一个直观反映。当一个内核对象被创建的时候,对应的文件和目录也在内核对象子系统中被创建。
/tmp:
tmp 是 temporary(临时) 的缩写这个目录是用来存放一些临时文件的。
/usr:
usr 是 unix shared resources(共享资源) 的缩写,这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似于 windows 下的 program files 目录。
/usr/bin:
系统用户使用的应用程序。
/usr/sbin:
超级用户使用的比较高级的管理程序和系统守护程序。
/usr/src:
内核源代码默认的放置目录。
/var:
var 是 variable(变量) 的缩写,这个目录中存放着在不断扩充着的东西,我们习惯将那些经常被修改的目录放在这个目录下。包括各种日志文件。
/run:
是一个临时文件系统,存储系统启动以来的信息。当系统重启时,这个目录下的文件应该被删掉或清除。如果你的系统上有 /var/run 目录,应该让它指向 run。
在 Linux 系统中,有几个目录是比较重要的,平时需要注意不要误删除或者随意更改内部文件。
/etc:上边也提到了,这个是系统中的配置文件,如果你更改了该目录下的某个文件可能会导致系统不能启动。
/bin, /sbin, /usr/bin, /usr/sbin: 这是系统预设的执行文件的放置目录,比如 ls 就是在 /bin/ls 目录下的。
值得提出的是 /bin、/usr/bin 是给系统用户使用的指令(除 root 外的通用用户),而/sbin, /usr/sbin 则是给 root 使用的指令。
/var:这是一个非常重要的目录,系统上跑了很多程序,那么每个程序都会有相应的日志产生,而这些日志就被记录到这个目录下,具体在 /var/log 目录下,另外 mail 的预设放置也是在这里。
七、Linux配置
1、关闭防火墙
systemctl status firewalld.service
systemctl stop firewalld.servicetmp
systemctl disable firewalld.service
2、配置hosts文件
vi /etc/hosts
八、VI编辑器的使用
1、VI的运行模式
编辑模式:等待编辑命令输入
插入模式:编辑模式下,输入i 进入插入模式,插入文本信息
按esc键,退出到编辑模式
命令模式:在编辑模式下,输入“:” 进行命令模式
2、VI 使用的命令
w 保存这个文件
q 直接退出vi
wq 保存后退出vi ,并可以新建文件
q! 强制退出
!wq强制保存退出
set number 在编辑文件显示行号
set nonumber 在编辑文件不显示行号
九、Linux常用指令
1、文件目录操作命令
• ls 显示文件和目录列表
-l 列出文件的详细信息
-a 列出当前目录所有文件,包含隐藏文件
• mkdir 创建目录
-p 父目录不存在情况下先生成父目录
• cd 切换目录
• touch 生成一个空文件
• echo 生成一个带内容文件
• cat、tac 显示文本文件内容
Cat是从第一行开始;tac是从最后一行开始
• cp 复制文件或目录
• rm 删除文件
-r 同时删除该目录下的所有文件
-f 强制删除文件或目录
• mv 移动文件或目录、文件或改名
• find 在文件系统中查找指定的文件
-name 文件名
• wc 统计文本文档的行数,字数,字符数
• grep 在指定的文本文件中查找指定的字符串
例如:grep best book.txt
• rmdir 删除空目录
• tree 显示目录目录改名树
• pwd 显示当前工作目录
• ln 建立链接文件
例如ln -s /home/itcast/familyA/house/roomB /home/roomB (目录名在前,连接名在后)
• more,less 分页显示文本文件内容
• head,tail 分别显示文件开头和结尾内容
• # 注释行
2、打包压缩命令
• gzip 压缩(解压)文件或目录,压缩文件后缀为gz
• bzip2 压缩(解压)文件或目录,压缩文件后缀为bz2
• tar 文件、目录打(解)包
3、系统管理命令
• free 显示当前内存和交换空间的使用情况
• ifconfig 显示网络接口信息
• ping 测试网络的连通性
• netstat 显示网络状态信息
• man 命令帮助信息查询
• clear 清屏
• kill杀死一个进程
• stat 显示指定文件的相关信息,比ls命令显示内容更多
• who, w 显示在线登录用户
• hostname 显示主机名称
• uname显示系统信息
• top 显示当前系统中耗费资源最多的进程
top –d 2 : 每两秒钟更新一次top ,观察整体信息
• ps 显示瞬间的进程状态
ps –ef 使用标准格式显示每个进程信息
• du 显示指定的文件(目录)已使用的磁盘空间的总量
(磁盘块数)
• df 显示文件系统磁盘空间的使用情况
4、关机/重启命令
• shutdown系统关机
-r 关机后重启
-h 关机后不重新启动
-now 立即关机
• halt 关机后关闭电源
• reboot 重新启动
5、Linux 通道
简单地说,一个通道接受一个工具软件的输出,然后把那个输出输入到其它工具软件。使用UNIX/Linux的词汇,这个通道接受了一个过程的标准输出,并把这个标准的输出作为另一个过程的标准输入。如果你没有重新定向这个输出,这个输出就在屏幕上显示出来。使用一个通道,你可以重新定向这个输出,这样它就变成了另一个工具软件的标准的输入。
例如:grep best /home/* | more
ps –ef | grep java
十、文件权限管理
1、Linux文件基本属性
Linux 系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。
为了保护系统的安全性,Linux 系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。
在 Linux 中我们通常使用以下两个命令来修改文件或目录的所属用户与权限:
• chown (change owner) :修改所属用户与组。
• chmod (change mode) :修改用户的权限。
下图中通过 chown 来授权用户,通过 chmod 为用户设置可以开门的权限。
在 Linux 中我们可以使用 ll 或者 ls –l 命令来显示一个文件的属性以及文件所属的用户和组,如:
[root@www /]# ls -l
total 64
dr-xr-xr-x 2 root root 4096 Dec 14 2012 bin
dr-xr-xr-x 4 root root 4096 Apr 19 2012 boot
……
实例中,bin 文件的第一个属性用 d 表示。d 在 Linux 中代表该文件是一个目录文件。
在 Linux 中第一个字符代表这个文件是目录、文件或链接文件等等。
• 当为 d 则是目录
• 当为 - 则是文件;
• 若是 l 则表示为链接文档(link file);
• 若是 b 则表示为装置文件里面的可供储存的接口设备(可随机存取装置);
• 若是 c 则表示为装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)。
接下来的字符中,以三个为一组,且均为 rwx 的三个参数的组合。其中, r 代表可读(read)、 w 代表可写(write)、 x 代表可执行(execute)。要注意的是,这三个权限的位置不会改变,如果没有权限,就会出现减号 - 而已。
每个文件的属性由左边第一部分的 10 个字符来确定(如下图)。
从左至右用 0-9 这些数字来表示。
第 0 位确定文件类型,第 1-3 位确定属主(该文件的所有者)拥有该文件的权限。
第4-6位确定属组(所有者的同组用户)拥有该文件的权限,第7-9位确定其他用户拥有该文件的权限。
其中,第 1、4、7 位表示读权限,如果用 r 字符表示,则有读权限,如果用 - 字符表示,则没有读权限;
第 2、5、8 位表示写权限,如果用 w 字符表示,则有写权限,如果用 - 字符表示没有写权限;第 3、6、9 位表示可执行权限,如果用 x 字符表示,则有执行权限,如果用 - 字符表示,则没有执行权限。
2、查看文件和目录的权限
• ls –l 文件名
• 显示信息包含:
文件类型(d 目录,- 普通文件,l 链接文件),文件权限,文件的属主,文件的所属组,文件的大小,文件的创建时间,文件的名称
• -rw-r--r-- 1 itcast users 2254 2006-05-20 13:47 tt.htm
从第二个字符起rw-是说用户itcast有读、写权,没有运行权,接着的r--表示用户组users只有读权限,没有运行权,最后的r--指其他人(others)只有读权限,没有写权和运行权。
3、更改操作权限
• chmod 【u 属主g 所属组用户o 其他用户a 所有用户】【+ 加权限– 减权限=加权限同时将原有权限删除】【rwx】文件或目录名
• -R 下面的子目录做相同权限操作
• 也可以用数字来表示权限如chmod 777 file
• r 4 w 2 x 1
• 若要rwx属性则4+2+1=7;
• 若要rw-属性则4+2=6;
• 若要r-x属性则4+1=5;