怎样进行SOLARIS UFS文件系统解析
更新:HHH   时间:2023-1-7


这期内容当中小编将会给大家带来有关怎样进行SOLARIS UFS文件系统解析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

Solaris操作系统下每个常规文件必须包含一个文件名和与之相关联的inode(信息节点),inode中存储文件的相关信息(如文件的所有者、权限和大小等信息),以及该文件所关联的数据块的指针.因此,inode数量的多少决定着一个UFS文件系统所允许创建的文件数.  

  一个UFS文件系统在其创建时,所允许最大的indoe数就已经固定,当该文件系统中有大量的(上千万甚至上亿个)小文件存在时,有可能出现inode数量不够用的情况,由于文件需要用inode来存储元数据(MetaData),inode数量超出将导致新文件无法被创建,尽管此时实际的存储空间还远远不到极限,所以在创建此类文件系统的时候需要考虑到这一点.  

  inode数计算公式:

  inode_number=文件系统大小/nbpi  

  nbpi:The number of bytes per inode,每个inode所占用的字节数,它是文件系统inode数多少的决定因素.  

  在创建文件系统时,如果不特别指定,Solaris将根据文件系统的大小使用不同的nbpi值来决定inode的密度,参见下表.  

  文件系统大小(GB) 缺省的nbpi大小(byte)

  ≤1 2048
  1
        2
        3
        ≥1024(即1T) 1048576 (即1M)  

  根据上表,在默认情况下,对于一个1G的文件系统(在Solaris 9下,其可用的空间大约为961M),得到理论上的该文件系统所拥有的inode数:

  1024 * 1024 / 2 ≌ 500000  

  而对于一个1T的文件系统,其可用的inode数将比略小于1T的文件(比如900G)系统锐减很多(因为nbpi值增大了好几倍):  

  900*1024*1024/8 = 117964800

  1024*1024*1024/1024 ≌ 1000000 (一百万)  

  对于一个已创建的文件系统,可以通过下列命令得到该文件系统的可用inode数,从而得出在该文件系统下所能创建的最大文件数(不考虑实际的物理空间限制,理论值可能会与实际有些偏差,但可以作为一个参考):  

  # df -F ufs -oi  

  实验:

  step1. 按缺省方式创建一个1G大小的UFS文件系统(nbpi=2048),挂接到/tmp/mnt目录下,实际可用的空间为961M:  

  # df -h /tmp/mnt

  Filesystem size used avail capacity Mounted on

  /dev/vx/dsk/oradg/lv_simon

  961M 1.0M 903M 1% /tmp/mnt

  # mkfs -m /dev/vx/dsk/oradg/lv_simon

  mkfs -F ufs

  -o nsect=64,ntrack=32,bsize=8192,fragsize=1024,cgsize=32,free=6,rps=120,nbpi=2054,

  opt=t,apc=0,gap=0,nrpos=8,maxcontig=128 /dev/vx/dsk/oradg/lv_simon 2097152  

  # df -oi /tmp/mnt

  Filesystem iused ifree %iused Mounted on

  /dev/vx/dsk/oradg/lv_simon

  4 507900 0% /tmp/mnt  

  在不考虑实际物理空间限制的情况下,该文件系统所允许创建的最大常规文件数理论值为: 507900个.

附:UFS 文件系统的柱面组结构
创建 UFS 文件系统时,磁盘片被分成若干个柱面组。柱面组由一个或多个连续的磁盘柱面组成。柱面组又进一步分成若干个可寻址的块,以控制和组织柱面组中文件的结构。在文件系统中,每种类型的块都具有特定的功能。UFS 文件系统具有以下四种类型的块,这些都是UFS文件系统**的根本所在。
 

 
 

 

上述就是小编为大家分享的怎样进行SOLARIS UFS文件系统解析了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注天达云行业资讯频道。

返回云计算教程...