FreeVM分布式存储的创建和使用

概述

FreeVM系统具备分布式存储功能,可以利用集群中服务器的空闲硬盘组建分布式存储。具体步骤如下。

1、存储网络测试和分布式存储的创建

如下图所示,一次点击“虚拟化”–“存储资源”–“分布式存储”–“新建分布式存储”。
在界面的右侧点击“创建分布式存储集群”。
在这里插入图片描述
点击后,可以看到如下界面,在创建分布式存储前,我们要先对存储网络进行检测,点击下图的“检测”按钮。开始检测。

在存储网络检测完毕前,是无法创建分布式存储的。
在这里插入图片描述

在这里插入图片描述
在本次演示中,我们的存储网络和管理网络使用的是同一块网卡,在实际使用环境中,建议进行分离。如下图所示,存储网络检测通过。点击“下一步”,继续操作。
在这里插入图片描述
可以看到,集群中的两个节点已经正确的被识别出来了。分别点击“请选择数据盘”,将服务器的空余硬盘添加到分布式存储网络中。
在这里插入图片描述
45.11节点剩余两块100G硬盘,全部选择。
在这里插入图片描述
45.12节点剩余一块100G和一块50G,两块硬盘。也全部选择上。
在这里插入图片描述
选择完毕后,可以配置副本的数量。在下图界面的下方进行副本数量的选择。最小副本数为“2”
在这里插入图片描述
副本数选择完毕后,点击“确定”按钮。进入创建过程。

在这里插入图片描述
在分布式存储集群创建过程中,可以看到进度条。
在这里插入图片描述
等待一段时间后,可以看到创建完毕的提示。
在这里插入图片描述

2、分布式存储状态查看和管理

如下图所示,依次点击“虚拟化”–“存储资源”–“分布式存储”–“分布式存储维护”。点击后,可以看到右侧的界面显示了分布式存储的情况,我们可以查看分布式存储的“拓扑”、“磁盘管理”、“健康”三种信息。
下图显示的是“拓扑”信息,也是查看分布式存储的默认显示界面。
在这里可以对存储节点进行管理。
在这里插入图片描述

磁盘管理查看。
点击下图箭头所指示的“磁盘管理”。可以查看分布式存储所包含的各个硬盘的状态。可以查看到硬盘的物理大小、所归属的节点、状态。
也可以在这个界面继续添加硬盘。

在这里插入图片描述

分布式存储健康查看。
点击如下图箭头所示的“健康”按钮,可以看到如下界面。在选择工具中可以选择“对象树”、“监控”、“集群状态”三种信息。
在这里插入图片描述
在这里插入图片描述
对象树所展示的信息如下图:可以查看到分布式存储的各个硬盘信息。

在这里插入图片描述
集群状态信息展示如下图:可以看到分布式存储的一些概要信息。

在这里插入图片描述
健康信息展示界面如下:
在这里插入图片描述
可以看到FreeVM的分布式存储,底层应该是采用的Ceph技术。

3、分布式存储的使用

如下图,在查看存储池的时候,在每个节点下都可以查询到分布式存储的信息。
在这里插入图片描述
分布式存储的概要信息如下。
在这里插入图片描述
点击如下图所示的“文件”按钮,可以查看到分布式存储的文件,可以看到已经默认创建了三个文件夹分别为,“images”、“iso”、“vms”。

在这里插入图片描述
在此界面,可以上传镜像文件。点击如下图所示的“本地上传”按钮。
在这里插入图片描述
文件上传的速度较慢,可能和测试环境有关系,同时管理网络和存储网络未作分离,也会对存储的速度造成影响。
对于实际的工作环境,建议对存储网络、业务网络、管理网络,配置三网隔离。
在这里插入图片描述

在新建虚拟机的时候,也可以使用分布式存储。
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将echo命令最后一行的exit()替换为`return 0`后,运行echo命令会出现如下错误提示: ``` $ echo test echo test panic: initproc: not sleeping cpuid = 0 ``` 这个错误提示是在`panic()`函数中打印的,该函数定义在`/kernel/proc.c`文件中,具体的打印语句是在该函数的第7行。 出现这种状况的原因是,在xv6中,每个进程都有自己的用户栈和内核栈。当进程结束时,会调用`exit()`函数,该函数会在用户栈中设置返回值并跳转到内核栈中的`trap()`函数,然后进一步调用`panic()`函数,打印上述错误信息。 而我们将exit()替换为`return 0`后,虽然也会在用户栈中设置返回值,但并不会跳转到内核栈中的`trap()`函数,因此就会出现上述错误。 为了解决这个问题,我们需要在`exit()`函数中,将返回值传递给`wait()`函数,并在`wait()`函数中进行处理。我们可以添加一个新的全局变量`int wait_return_code`,在`exit()`函数中将返回值赋值给该变量,然后在`wait()`函数中对该变量进行判断。修改后的代码如下: ```c int wait_return_code = 0; void exit(void) { struct proc *curproc = myproc(); struct proc *p; int fd; if(curproc == initproc) panic("init exiting"); // Close all open files. for(fd = 0; fd < NOFILE; fd++){ if(curproc->ofile[fd]){ fileclose(curproc->ofile[fd]); curproc->ofile[fd] = 0; } } begin_op(); iput(curproc->cwd); end_op(); curproc->cwd = 0; acquire(&ptable.lock); // Parent might be sleeping in wait(). wakeup1(curproc->parent); // Pass abandoned children to init. for(p = ptable.proc; p < &ptable.proc[NPROC]; p++){ if(p->parent == curproc){ p->parent = initproc; if(p->state == ZOMBIE) wakeup1(initproc); } } // Jump into the scheduler, never to return. curproc->state = ZOMBIE; wait_return_code = curproc->xstate; sched(); panic("zombie exit"); } int wait(void) { struct proc *p; int havekids, pid; acquire(&ptable.lock); for(;;){ // Scan through table looking for zombie children. havekids = 0; for(p = ptable.proc; p < &ptable.proc[NPROC]; p++){ if(p->parent != myproc()) continue; havekids = 1; if(p->state == ZOMBIE){ // Found one. pid = p->pid; kfree(p->kstack); p->kstack = 0; freevm(p->pgdir); p->state = UNUSED; p->pid = 0; p->parent = 0; p->name[0] = 0; p->killed = 0; p->xstate = 0; wait_return_code = 0; release(&ptable.lock); return pid; } } // No point waiting if we don't have any children. if(!havekids || myproc()->killed){ release(&ptable.lock); return -1; } // Wait for children to exit. (See wakeup1 call in proc_exit.) sleep(myproc(), &ptable.lock); //DOC: wait-sleep } } ``` 我们在`exit()`函数中将当前进程的返回值赋值给全局变量`wait_return_code`,在`wait()`函数中根据`wait_return_code`的值进行判断,如果为0,则正常结束,不打印提示信息;否则,打印原来的错误信息。 修改后的echo命令代码如下: ```c #include "kernel/types.h" #include "user/user.h" int main(int argc, char *argv[]) { int i; for (i = 1; i < argc; i++) { printf("%s ", argv[i]); } printf("\n"); if (argc < 2) { return 0; } if (strcmp(argv[argc - 1], "0x88") == 0) { return 0x88; } else { return 0; } } ``` 修改后的代码运行结果如下: ``` $ echo test echo test panic: initproc: not sleeping cpuid = 0 $ echo test 0x88 echo test 0x88 ``` 可以看到,如果返回值为0,程序正常结束,没有任何提示信息;如果返回值为0x88,则打印原来的错误信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值