使用lvm2整合系统磁盘资源


 使用lvm2整合系统磁盘资源


1, 如果是逻辑分区,先在其上创建新的分区

fdisk /dev/sdc        //新建的分区为sdc6

2, 创建物理卷 

pvcreate /dev/sdc6

pvdisplay显示物理卷信息

3, 创建卷组

vgcreate  dnfs   /dev/sdc6

如果卷组已经存在,可使用vgextend/dev/sdc6加入。

vgextend dnfs /dev/sdc6

4,创建逻辑卷

   lvcreate –n osd –L 500G dnfs //dnfs逻辑卷中创建osd逻辑卷,大小为200G

   可使用lvextend动态改变逻辑卷的容量

   lvextend –L +200G /dev/dnfs/osd  //osd的空间增加200G

5, 创建文件系统

   osd逻辑卷上使用mkfs创建文件系统

   mkfs –t ext3 /dev/dnfs/osd

    mkfs.ext3 /dev/dnfs/osd

6, 挂载文件系统

   mount –t ext3 /dev/dnfs/osd /mnt/osd

 

系统开机自动挂载,在/etc/fstab中加入

/dev/dnfs/osd   /mnt/osd  ext3 defaults  0 0

 

df /mnt/osd 即可查看挂载的逻辑卷的信息

Filesystem           1K-blocks      Used Available Use% Mounted on
/dev/mapper/dnfs-osd 743128848    201720 705178392   1% /mnt/osd

 

 

这样DNFS系统就能使用/dev/dnfs/osd的空间作为实际文件数据的存储空间,可以灵活的加入磁盘扩展容量。

 

 

改变ext3文件系统大小

# resize2fs /dev/dnfs/osd

这样会改变osd逻辑卷上的ext3文件系统的大小到osd逻辑卷的总大小,resize2fs也可以指定大小, resize2fs支持在线改变ext3文件系统大小,不需卸载即可调整大小。

 

删除操作

如果不想用逻辑卷管理器了,可以从LVVGPV逐层删除

# lvremove /dev/dnfs/osd

dnfs转为休眠状态:

# vgchange -an dnfs

# lvremove dnfs

# pvremove /dev/sdc6

 

 

由于osd需要获取磁盘信息(可用空间,可用空间),这可以通过

df /mnt/osd完成,而popen可以帮助我们在C程序中获取shell命令的输出。

 

#include <stdio.h>
FILE *popen(const char *cmdstring, const char *type) ;
函数popen 先执行fork,然后调用exec以执行cmdstring,并且返回一个标准I/O文件指针。
如果type是"r", cmdstring进程的输出端从stdout重定向到管道的写端,并返回管道的读端。

如果type是"w", cmdstring进程的输入端从stdin重定向到管道的读端,并返回管道的写端。

 

// getspace.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h>

#define LV  "/dev/mapper/dnfs-osd"


/* used space used K   
 * available space used K
 */

typedef struct space
{
 uint64_t used;
 uint64_t avail;
}space;


int spaceinfo(space *sinfo)
{

 FILE *fp;
 if((fp = popen("df /mnt/osd", "r")) == NULL)
 {
  perror("popen failed");
  return -1;
 }

 char buf[256];
 int i;
 for(i = 0; i < 2; i++)
 {
  fgets(buf, sizeof(buf)-1, fp);
 }
 
       
 char *p = strstr(buf, LV);
        if(p == NULL)
 {
  perror("LV not found");
  return -3;
 }
 
 p += strlen(LV);
 while(*p == ' ') p++;
 sscanf(p, "%*u %u %u", &sinfo->used, &sinfo->avail);

 if(pclose(fp) == -1)
 {
  perror("pclose error");
  return -1;
 }

 return 0;
}

int main()
{
 space s;
 spaceinfo(&s);
 printf("%u %u\n", s.used, s.avail);
 return 0;
}

 

#gcc -o getspace getspace.c

#./getspace

201720 705178392  //即为逻辑卷的已用空间 和 可用空间

 

#include <stdio.h>
#include <unistd.h>

int main()
{
    FILE *fp = popen("bc -q", "w");
    fwrite("2+5\n", 4, 1, fp);
    pclose(fp);
}
//bc的输入被连接到管道的读端,往管道的写端写数据,会输出计算结果

posted @ 2013-04-19 14:04  ydzhang  阅读(318)  评论(0编辑  收藏  举报