linux系统分区与挂载的关系
一 Linux的安装
Linux的安装是比较简单的,整个过程和安装XP差不多。首先BIOS中设置从光驱启动,(不知道怎么设置?那你还是先装虚拟机玩玩吧!)会要你选安装模式,直接回车用图形界面;然后Linux安装程序会有一个检查光盘的过程,这里可以选择跳过【Skip】;然后等待初始化工作,系统就可以进入到安装界面了;进入安装界面后就可以进行一些设置(区域,语言,时间,密码,分区等),设置完成后选择要安装的组件,安装完成就一切OK了。
二 Linux系统分区
这里我说的是指在分区时采用手动分区,而不是自动分区。Linux分区和Windows有很大的区别,你无法在Linux中看到诸如Windows中的C盘,D盘。这确实会让我们这些用惯了WIN操作系统的人感到很不习惯。其实理解了Linux分区结构后就很清晰了。
1: 硬盘分区
首先我们来看硬盘分区,分区是和操作系统没有任何关系的,因为她是在安装操作系统之前进行了。我们可以简单的认识,分区就是把硬盘分割为不同的区域。在谈具体分区前,有个比较简单的问题想问下大家:硬盘问什么要分区?.....哈哈!怎么样,不是很好回答吧,首先是因为操作系统在启动时会通过MBR来获得操作系统文件所在的分区,所以一个可引导分区是不能缺少的。这也是为什么新买的硬盘不能直接用的原因。而且进行多个分区是为了提高管理效率,所有东西放在一个分区,OS管理其起来效率比较低,因为每次要检索的东西太多。
下面我们简单看下硬盘的分区结构:
硬盘主引导扇区 = 硬盘主引导记录(MBR)+ 硬盘分区表(DPT),一共是512个字节,其中MBR是446,分区表一共64字节,然后是2个字节的结束标志。引导扇区存储在硬盘的0头0道1扇区,也就是Boot Sector。(如图1)
操作系统在启动时通过BIOS(BIOS实际是一个基础输入输出系统,用于和硬件打交到)程序把Boot Sector读入内存,然后执行其中MBR,这个时候BIOS就把启动交给MBR控制;MBR作用是在4个分区表中搜索标志为活动的分区,找到后把活动分区的第一个扇区读入内存,然后开始执行它,运行特定系统的启动程序(LILO,GRUB,NT Loader);这个时候启动的启动就交给了操作系统的引导程序来控制了。然后操作系统进行一系列的初始化,最后把系统交给系统内核进行管理。
2:分区类型
上面介绍了硬盘分区结构和系统启动,下面就看下各个分区。硬盘分区一共有3种,主分区,扩展分区和逻辑分区(如图2)
主分区上可以安装操作系统,因为MBR中记录的主分区信息,系统启动时会到主分区来查找操作系统引导文件,所以操作系统的引导文件必须在主分区中,否则系统就无法启动了。而最多只支持4个主分区(由于硬盘仅仅为分区表保留了64个字节的存储空间,而每个分区的参数占据16个字节,故主引导扇区中总计可以存储4个分区的数据。操作系统只允许存储4个分区的数据。所以为了建立更多的逻辑磁盘供操作系统使用,系统引入了扩展分区的概念)。
扩展分区并不是一个真实存在的分区,它只是内存管理链表中的一个指针,指示出那一块区域是扩展分区。上面也提到出现扩展分区的原因。所以一个扩展分区也是一个主分区。而通过在扩展分区中在划分逻辑分区对系统分区进行扩展。实际上所有的逻辑分区都是在一个分区类,只是逻辑上分开,这也是叫逻辑分区的原因。但对用户来说一切都是透明了,我们看起来系统中有很多分区。
3:Linux分区
其面介绍了硬盘分区结构和分区类型,这里就要讲讲Linux系统中分区的表示了。首先回顾下WINDOWS下分区的情况。在WINDOWS系统里,我们看到,每个分区都有一个名字,C,D,E,F....实际这是OS使用的一种映射。通过操作系统中看到的这些盘符和分区联系起来,然后我们就可以在这些盘符下读写文件,操作系统负责把文件写入到硬盘分区。在WINDOWS中盘符名称和分区是对应了。
我们在来看看LINUX下的情况,在Linux下使用/dev/hda,hdb..这样来标识硬盘,具体硬盘上的分区就用/dev/hda1,hda2,来表示.最后的数字代表分区号,主分区是1-4,逻辑分区是5以后的数字。Linux中最大的区别就是我们在也看不到所谓的盘符了。Liunx采用树形的文件管理系统,也就是在Linux系统中,可以说已经没有分区的概念了。分区在Linux和其他设备一样都只是一个文件。要使用一个分区必须把它加载到文件系统中。这可能难于理解,继续往下看。
Linux中树形的文件结构,最顶层是/ 目录。在安装系统时,你必须选择把一个主分区挂载在/ 目录下,因为系统需要安装在/挂载的主分区下。否则系统会提示你。这里又一次提到了挂载。所以挂载就是把目录和分区连接起来,和上面说的WINDOWS下的映射关系是一样的。不同的是WINDOWS是把分区映射到一个盘符,而LINUX下是映射到一个目录。 这是理解他们不同最重要的地方,而导致不同的是因为文件系统结构不同。
4:Linux文件系统
上面说了Linux的文件系统是树形的,安装的系统必须是在/ 目录下,因为/目录下挂载了一个主分区。/目录是树形的根,其他所有目录都是他的子节点。
我们看上图3 可以更好的理解, Linux整个系统结构如上, 我们安装系统的时候已经把分区1挂载到 / 目录下了. 而这个时候没有挂载其他任何分区,所以/ 目录下的所有其他目录都在这个分区下,也就是说,我在任何目录下读写操作实际都是操作的这个1号分区。
如果我们想使用其他分区,就必须把这个分区挂载到一个目录下(而这个目录必定是以 / 为根目录的目录树的一个子目录),这个目录可以是已经存在的目录,比如/home,也可以是我们自己建立的目录,比如/oracle。当然有些目录比如/lib, /dev, /etc, /usr这些都不能挂载其他分区,因为他们都存放着系统需要的文件,一旦被挂载其他分区,那没OS就无法找到所需的文件,系统就会崩溃。比如我们把分区2挂载到 /usr/X11 目录下时,系统就无法通过 X11 目录找到分区1上的文件,这个时候系统图形界面就无法使用了. 虽然文件还在硬盘上。前面说过,目录 --- 分区 是通过挂载吧他们联系起来。你更换了分区,也就破坏了联系,就无法在找到之前的文件了。我们在看分区5和分区6,我们把它挂载到/home/ftp 和 /oracle目录下,这个时候我们在操作这2个目录是,就是操作对用的分区了.
而WINDOWS就没这么复杂,她不是采用树形的结构,每个分区对应一个盘符,一旦建立映射关系就无法在修改。实际上,LINUX的每个挂载了分区的目录就相当于WINDOWS系统中的盘符,比如上面的,/home/ftp 和 /oracle目录我们就可以把她看做一个盘符和一个分区关联,只是因为LINUX文件系统,使得她更加灵活,所以也更复杂和难以理解。
三 Linux中的设置
1:查看Linux分区信息
前面介绍完了Linux文件系统和分区的关系,大家应该对分区有很清楚的认识了。下面我们就关注下Linux系统中如何查看分区情况。
在Linux系统中我们使df -u 命令就可以看到系统目前分区情况
- Filesystem 容量 已用 可用 已用% 挂载点
- /dev/hda1 21G 6.7G 13G 35% /
- none 506M 0 506M 0% /dev/shm
- /dev/hda2 11G 5.2G 5.0G 52% /home
- /dev/hda5 16G 9.3G 5.1G 65% /oracle
- /dev/hda6 19G 201M 18G 2% /usr1
从中我们可以看到目前系统加载了4个分区,其中2个主分区(hda1,hda2)和两个逻辑分区(hda5,hda6)。也可以看到他们的加载点。其中hda1分区是系统分区,上面安装了操作系统。而/home,/orace,/usr1分别加载了其他3个分区。
而通过fdisk -l 命令可以看到目前系统中所有分区的信息,如下表
1 Disk /dev/hda: 80.0 GB, 80026361856 bytes 2 255 heads, 63 sectors/track, 9729 cylinders 3 Units = cylinders of 16065 * 512 = 8225280 bytes 4 Device Boot Start End Blocks Id System 5 /dev/hda1 * 1 2677 21502971 83 Linux 6 /dev/hda2 2678 4079 11261565 83 Linux 7 /dev/hda3 4080 9729 45383625 5 Extended 8 /dev/hda5 4080 6080 16073001 83 Linux 9 /dev/hda6 6081 8581 20089251 83 Linux 10 /dev/hda7 8582 9729 9221278+ 82 Linux swap
可以看到hda3是一个主分区,但实际上他是一个扩展分区,前面我们介绍了扩展分区,她实际会占用一个主分区,因为MBR只能记录4个分区信息. 由一个比较特殊的是hda7,她是一个交换分区,在WINDOWS系统中就是虚拟内存文件. 所以用df命令是查看不到她的.
这里顺便说下为什么标识为/dev/hda,前面简单提到过,LINUX下所有设备都被认为是文件,而/dev目录存放所有系统设备文件的,而一个分区就是一个文件,名字就是分区的名字.
2:Linux分区挂载
常用的挂载和卸载分区及文件系统的命令是mount和umount ,比如 mount /orace /dev/hda5,就是把5号分区挂载到/oracle目录下。具体的命令格式就不介绍了,网上很多,也可以使用man来查看。我们这里主要讲讲自动挂载。并经每次都要使用命令手动挂载确实很麻烦,我们可以通过编辑/etc/fstab文件来让系统开机时自动加载(这里介绍的是系统安装好后,使用fdisk分区后,进行加载)
vi /etc/fstab 就可以看到一下信息:
1 # This file is edited by fstab-sync - see 'man fstab-sync' for details 2 LABEL=/ / ext3 defaults 1 1 3 none /dev/pts devpts gid=5,mode=620 0 0 4 none /dev/shm tmpfs defaults 0 0 5 LABEL=/home /home ext3 defaults 1 2 6 none /proc proc defaults 0 0 7 none /sys sysfs defaults 0 0 8 LABEL=/oracle /oracle ext3 defaults 1 2 9 LABEL=/usr1 /usr1 ext3 defaults 1 2 10 LABEL=SWAP-hda7 swap swap defaults 0 0 11 /dev/hdc /media/cdrom auto pamconsole,fscontext=system_u:object_r:removable_t,exec,no auto,managed 0 0
这个文件第一列就是具体的分区,第2列是分区挂载的目录,第3列是文件格式,第4列是挂载规则,第5列是备份;0为从不备份,或显示上次至今备份之天数;第7列是启动时fsck检查顺序,0为不检查, “/”永远为1;
了解了各个字段我们就具体来看下,其中/ 目录系统会自动写到这个文件中,因为不加载系统如何启动??那几个none挂载的我还不太清楚。我们具体看看我们实际分区的挂载。我们可以在linux中使用fdisk 来进行分区。比如我们用fdisk划分了hda2,5,6,7这4个分区。但我们想使用他们的时候,我们必须手动添加。
我们可以通过一下命令来完成自动加载
- mkfs.ext3 /dev/hdax
- e2lable /dev/hda2 /home
- LABEL=/home /home ext3 defaults 1 2 //修改Fstab
分区要使用首先要格式化,目前使用较多的是ext3文件格式, 他相对于ext2更安全,更快,但是比较浪费空间了,我80G硬盘用ext3后,可用的只有67G左右,XP下 NTFS和FAT32可是有70G左右的.
格式话之后就可以给分区设置一个标签名(一般和要挂载的目录名字相同),然后在fstab文件中添加一行。大家可能有疑问,第一列不是标识分区吗,这里为什么要用标签,其实你也可以用 /dev/hda5 ,这里LABLE是一个分区的标签,你可以把它当作分区的名字。
以上就是对一个新建分区自动加载的过程。开机后我们可以通过 vi /etc/mtab查看已经加载的分区和文件系统。
3:关于交换分区
目前计算机内存越来越大,LINUX和VISTA都使用了内存做缓存,cached和buffers的区别在于一个是读一个是写。目前系统最大的开销都是I/O操作,通过buffers先把文件读到内存,这样就减少了I/O,而使用cached就是把要写入的文件放到缓存中,操作系统一次写入磁盘,减少I/O。而交换分区是为了解决内存不足,而目前交换分区使用的很少,所以不需要给她分配过大的空间。当然作为小内存机器还是很有用。
我们可以单独划分一个分区作为交换分区,比如我们使用前门的hda7作为交换分区。因为他是交换分区,所以文件系统不能是ext3格式,必须是交换分区格式.
- mkswap -v1 -L SWAP-hda7 /dev/hda7
- swapon -a
- LABEL=SWAP-hda7 swap swap defaults 0 0 //修改Fstab
用以上的mkswap命令就可以把一个分区格式化为交换分区文件系统,其中-L 参数是设置分区的LABLE名。然后使用swapon -a来关在系统中所有交换分区。最后修改fstab,加入这一句, 开机就可以自动加载交换分区了。
4:加载其他文件系统
除了加载Linux系统分区以外,我们还可以加载光驱,软驱,USB存储设备,设置是WINDOWS文件系统。方法和上面完全一样,这里就不废话了。
最后要注意的是修改fstab要注意,如果设置的不正确,可能导致系统无法启动.所以编辑时要小心.
参考资料:
一 、Linux文件结构
文件结构是文件存放在磁盘等存贮设备上的组织方法。主要体现在对文件和目录的组织上。
目录提供了管理文件的一个方便而有效的途径。
Linux使用标准的目录结构,在安装的时候,安装程序就已经为用户创建了文件系统和完整而固定的目录组成形式,并指定了每个目录的作用和其中的文件类型。
/根目录
┃
┏━━┳━━━┳━━━┳━━━╋━━━┳━━━┳━━━┳━━━┓
┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃
bin home dev etc lib sbin tmp usr var
┃ ┃
┏━┻━┓ ┏━━┳━━┳━━┳━┻━┳━━┓
┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃
rc.d cron.d X11R6 src lib local man bin
┃
┏━━━┳━━┳━┻━┳━━━┓
┃ ┃ ┃ ┃ ┃
init.d rc0.d rc1.d rc2.d …… linux bin lib src
Linux采用的是树型结构。最上层是根目录,其他的所有目录都是从根目录出发而生成的。微软的DOS和windows也是采用树型结构,但是在DOS和 windows中这样的树型结构的根是磁盘分区的盘符,有几个分区就有几个树型结构,他们之间的关系是并列的。但是在linux中,无论操作系统管理几个磁盘分区,这样的目录树只有一个。从结构上讲,各个磁盘分区上的树型目录不一定是并列的。
如果这样讲不好理解的话,我来举个例子:
有一块硬盘,分成了4个分区,分别是/;/boot;/usr和windows下的fat
对于/和/boot或者/和/usr,它们是从属关系;对于/boot和/usr,它们是并列关系。
如果我把windows下的fat分区挂载到/mnt/winc下,(挂载??哦,别急,呵呵,一会就讲,一会就讲。)那么对于/mnt/winc和/usr或/mnt/winc和/boot来说,它们是从属于目录树上没有任何关系的两个分支。
因为linux是一个多用户系统,制定一个固定的目录规划有助于对系统文件和不同的用户文件进行统一管理。但就是这一点让很多从windows转到linux的初学者感到头疼。下面列出了linux下一些主要目录的功用。
/bin 二进制可执行命令
/dev 设备特殊文件
/etc 系统管理和配置文件
/etc/rc.d 启动的配置文件和脚本
/home 用户主目录的基点,比如用户user的主目录就是/home/user,可以用~user表示
/lib 标准程序设计库,又叫动态链接共享库,作用类似windows里的.dll文件
/sbin 系统管理命令,这里存放的是系统管理员使用的管理程序
/tmp 公用的临时文件存储点
/root 系统管理员的主目录(呵呵,特权阶级)
/mnt 系统提供这个目录是让用户临时挂载其他的文件系统。
/lost+found 这个目录平时是空的,系统非正常关机而留下“无家可归”的文件(windows下叫什么.chk)就在这里
/proc 虚拟的目录,是系统内存的映射。可直接访问这个目录来获取系统信 息。
/var 某些大文件的溢出区,比方说各种服务的日志文件
/usr 最庞大的目录,要用到的应用程序和文件几乎都在这个目录。其中包 含:
/usr/X11R6 存放X window的目录
/usr/bin 众多的应用程序
/usr/sbin 超级用户的一些管理程序
/usr/doc linux文档
/usr/include linux下开发和编译应用程序所需要的头文件
/usr/lib 常用的动态链接库和软件包的配置文件
/usr/man 帮助文档
/usr/src 源代码,linux内核的源代码就放在/usr/src/linux里
/usr/local/bin 本地增加的命令
/usr/local/lib 本地增加的库
二 、linux文件系统
文件系统指文件存在的物理空间,linux系统中每个分区都是一个文件系统,都有自己的目录层次结构。linux会将这些分属不同分区的、单独的文件系统按一定的方式形成一个系统的总的目录层次结构。一个操作系统的运行离不开对文件的操作,因此必然要拥有并维护自己的文件系统。
Llinux文件系统使用索引节点来记录文件信息,作用像windows的文件分配表。
索引节点是一个结构,它包含了一个文件的长度、创建及修改时间、权限、所属关系、磁盘中的位置等信息。一个文件系统维护了一个索引节点的数组,每个文件或目录都与索引节点数组中的唯一一个元素对应。系统给每个索引节点分配了一个号码,也就是该节点在数组中的索引号,称为索引节点号。
linux文件系统将文件索引节点号和文件名同时保存在目录中。所以,目录只是将文件的名称和它的索引节点号结合在一起的一张表,目录中每一对文件名称和索引节点号称为一个连接。
对于一个文件来说有唯一的索引节点号与之对应,对于一个索引节点号,却可以有多个文件名与之对应。因此,在磁盘上的同一个文件可以通过不同的路径去访问它。
可以用ln命令对一个已经存在的文件再建立一个新的连接,而不复制文件的内容。连接有软连接和硬连接之分,软连接又叫符号连接。它们各自的特点是:
硬连接:原文件名和连接文件名都指向相同的物理地址。
目录不能有硬连接;硬连接不能跨越文件系统(不能跨越不同的分区)
文件在磁盘中只有一个拷贝,节省硬盘空间;
由于删除文件要在同一个索引节点属于唯一的连接时才能成功,因此可以防止不必要的误删除。
符号连接:用ln -s命令建立文件的符号连接符号连接是linux特殊文件的一种,作为一个文件,它的数据是它所连接的文件的路径名。类似windows下的快捷方式。
可以删除原有的文件而保存连接文件,没有防止误删除功能。
这一段的的内容过于抽象,又是节点又是数组的,我已经尽量通俗再通俗了,又不好加例子作演示。大家如果还是云里雾里的话,我也没有什么办法了,只有先记住,日后在实际应用中慢慢体会、理解了。这也是我学习的一个方法吧。
三 、挂载文件系统
由上一节知道,linux系统中每个分区都是一个文件系统,都有自己的目录层次结构。linux会将这些分属不同分区的、单独的文件系统按一定的方式形成一个系统的总的目录层次结构。这里所说的“按一定方式”就是指的挂载。
将一个文件系统的顶层目录挂到另一个文件系统的子目录上,使它们成为一个整体,称为挂载。把该子目录称为挂载点。
举个例子吧:
根分区:
/根目录
┃
┏━━━━┳━━━━━┳━━━━━┳━━━━━╋━━━━━┳━━━━━┳━━━━━┳━━━━━┓
┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃
bin home dev etc lib sbin tmp usr var
┃
┏━┻━┓
┃ ┃
rc.d cron.d
┃
┏━━━┳━━━┳━┻━┳━━━━┓
┃ ┃ ┃ ┃ ┃
init.d rc0.d rc1.d rc2.d ……
/usr分区 :
usr
┃
┏━━━━┳━━━╋━━━┳━━━┳━━━┓
┃ ┃ ┃ ┃ ┃ ┃
X11R6 src lib local man bin
┃ ┃
┃ ┏━━━╋━━━┓
┃ ┃ ┃ ┃
linux bin lib src
挂载之后就形成了文章开始时的那个图。像不像挂上去的?
注意:1、挂载点必须是一个目录。
2、一个分区挂载在一个已存在的目录上,这个目录可以不为空,但挂载后这个目录下以前的内容将不可用。
对于其他操作系统建立的文件系统的挂载也是这样。但是需要理解的是:光盘、软盘、其他操作系统使用的文件系统的格式与linux使用的文件系统格式是不一样的。光盘是ISO9660;软盘是fat16或ext2;windows NT是fat16、NTFS;windows98是fat16、fat32;windows2000和windowsXP是fat16、fat32、 NTFS。挂载前要了解linux是否支持所要挂载的文件系统格式。
挂载时使用mount命令:
格式:mount [-参数] [设备名称] [挂载点]
其中常用的参数有
-t 指定设备的文件系统类型,常见的有:
minix linux最早使用的文件系统
ext2 linux目前常用的文件系统
msdos MS-DOS的fat,就是fat16
vfat windows98常用的fat32
nfs 网络文件系统
iso9660 CD-ROM光盘标准文件系统
ntfs windows NT 2000的文件系统
hpfs OS/2文件系统
auto 自动检测文件系统
-o 指定挂载文件系统时的选项。有些也可用在/etc/fstab中。常用的 有
codepage=XXX 代码页
iocharset=XXX 字符集
ro 以只读方式挂载
rw 以读写方式挂载
nouser 使一般用户无法挂载
user 可以让一般用户挂载设备
提醒一下,mount命令没有建立挂载点的功能,因此你应该确保执行mount命令时,挂载点已经存在。(不懂?说白了点就是你要把文件系统挂载到哪,首先要先建上个目录。这样OK?)
例子:windows98装在hda1分区,同时计算机上还有软盘和光盘需要挂载。
# mk /mnt/winc
# mk /mnt/floppy
# mk /mnt/cdrom
# mount -t vfat /dev/hda1 /mnt/winc
# mount -t msdos /dev/fd0 /mnt/floppy
# mount -t iso9660 /dev/cdrom /mnt/cdrom
现在就可以进入/mnt/winc等目录读写这些文件系统了。
要保证最后两行的命令不出错,要确保软驱和光驱里有盘。(要是硬盘的磁盘片也可以经常随时更换的话,我想就不会犯这样的错误了 :-> )
如果你的windows98目录里有中文文件名,使用上面的命令挂载后,显示的是一堆乱码。这就要用到 -o 参数里的codepage iocharset选项。codepage指定文件系统的代码页,简体中文中文代码是936;iocharset指定字符集,简体中文一般用cp936或 gb2312。
当挂载的文件系统linux不支持时,mount一定报错,如windows2000的ntfs文件系统。可以重新编译linux内核以获得对该文件系统的支持。关于重新编译linux内核,就不在这里说了。
四 、自动挂载
每次开机访问windows分区都要运行mount命令显然太烦琐,为什么访问其他的linux分区不用使用mount命令呢?
其实,每次开机时,linux自动将需要挂载的linux分区挂载上了。那么我们是不是可以设定让linux在启动的时候也挂载我们希望挂载的分区,如windows分区,以实现文件系统的自动挂载呢?
这是完全可以的。在/etc目录下有个fstab文件,它里面列出了linux开机时自动挂载的文件系统的列表。我的/etc/fstab文件如下:
/dev/hda2 / ext3 defaults 1 1
/dev/hda1 /boot ext3 defaults 1 2
none /dev/pts devpts gid=5,mode=620 0 0
none /proc proc defaults 0 0
none /dev/shm tmpfs defaults 0 0
/dev/hda3 swap swap defaults 0 0
/dev/cdrom /mnt/cdrom iso9660 noauto,codepage=936,iocharset=gb2312 0 0
/dev/fd0 /mnt/floppy auto noauto,owner,kudzu 0 0
/dev/hdb1 /mnt/winc vfat defaults,codepage=936,iocharset=cp936 0 0
/dev/hda5 /mnt/wind vfat defaults,codepage=936,iocharset=cp936 0 0
在/etc/fstab文件里,第一列是挂载的文件系统的设备名,第二列是挂载点,第三列是挂载的文件系统类型,第四列是挂载的选项,选项间用逗号分隔。第五六列不知道是什么意思,还望高手指点。
在最后两行是我手工添加的windows下的C;D盘,加了codepage=936和iocharset=cp936参数以支持中文文件名。参数defaults实际上包含了一组默认参数:
rw 以可读写模式挂载
suid 开启用户ID和群组ID设置位
dev 可解读文件系统上的字符或区块设备
exec 可执行二进制文件
auto 自动挂载
nouser 使一般用户无法挂载
async 以非同步方式执行文件系统的输入输出操作
因为空间被日志文件占用磁盘使用100%导致MQ运行异常无法正常工作停不掉起不来,需要删除日志,腾出空间。
该文件夹的完整路径 :du --max-depth 1 -lh
例,查询/var文件夹的大小: du --max-depth 1 -lh /var
删除日志文件,今天一看,公司的linux 服务器没放什么东西,但是已经使用了50%了,一查看原来是日志文件太大了,于是就手动删除了,这个比较快
sudo /dev/null > /var/log/**.log
下面这个可以推荐使用 sudo find /var/log/ -type f -mtime +30 -exec rm -f {} \;
删除30天之前的旧文件
设备是设备,分区是分区,挂载点是挂载点,他们之间是有联系的,但绝不是必须一一对应的关系。
linux入门_1 如何理解dev和挂载点
1.dev:
在Linux系统中,/dev目录用来保存设备文件的.每个文件指向一个系统设备.用户的程序可以通过使用这些设备文件,
对真实的硬件的设备进行操作。但是dev下的文件必须挂载到指定目录下,才可以被访问。
2.挂载点:
例如:把dev下的设备文件挂载到/mnt/cdr 目录下,dev下的设备文件才可被访问。而/mnt/cdr称为挂载点
挂载命令: mount /dev/cdrom /mnt/cdr
解除挂载命令: cd .. 退出当前目录
umount /mnt/cdr