Chinaunix首页 | 论坛 | 博客
  • 博客访问: 168712
  • 博文数量: 35
  • 博客积分: 2067
  • 博客等级: 大尉
  • 技术积分: 282
  • 用 户 组: 普通用户
  • 注册时间: 2009-05-31 10:29
文章分类

全部博文(35)

文章存档

2014年(3)

2011年(2)

2010年(20)

2009年(10)

我的朋友

分类: LINUX

2009-09-25 14:00:09

Xenstore简介及Xenstore读写机制的研究与实现

Xenstore是Xen提供的一个域间共享的存储系统(数据库),也可以说它是一个由Domain 0管理的简单的分层操作系统,其作为虚拟机间的中介通信是基于共享内存页与事件通道来实现的。Xenstore中存储了各个虚拟机(包括Domain 0)的配置信息,例如Domain ID,Domain Name,UUID,前后端设备,启动时间,虚拟机状态等。

Xenstore是一个具有层次结构的目录,类似于Linux中的树形目录。Xenstore中存储了 Domain之间共享的配置信息,Domain 0作为管理域,可以查看整个结构的内容,而Domain U只能查看自身的信息,这种设计方法提高了Xenstore的安全性。

Xenstore的数据结构与文件系统非常相似。Xenstore只是用于domain间少量信息的传送,并不用于大规模数据的存储。它也保存着正在运行的domain信息,这些信息存储在一个稳定的位置,所以是易读的。

Xenstore中主要有三个路径:

/vm – 存储了domain的配置信息

/local/domain – 存储了本地节点的虚拟机信息,类似于Linux的/proc结构

/tool-存储了各种工具的信息

Xenstore提供了访问的接口程序,基本的接口包括两个缓冲环(ring buffer)。关于Xenstore的数据内容更新的Request放在1号环,Response 和状态改变的异步通知被放入2号环。第一个环被domU写入,dom0读出,而第二个环由dom0写入,domU读出。

在Xenstore里,可以使用命令xenstore-read和xenstore-write对数据进行读写。我的毕设是基于硬件计数器虚拟化的多虚拟机profile研究,涉及到各个domain配置信息的读写问题,于是考虑使用xenstore来实现。

实现代码如下:
#include
#include
#include

char buf[100] ;
void  xenstore_w(char* key, char* value)    //将key/value的键值对写入xenstore
{
char *a = " '", *b = "'", c[100] = "xenstore-write ";
strcat(c, key);
strcat(c, a);
strcat(c, value);
strcat(c, b);
printf("%s\n", c);     //使用xenstore-write命令,即xenstore-write key value
system(c);
}
char* xenstore_r(char* key)               //从xenstore里读取键值为key的值
{
FILE *stream;
char a[100] = "xenstore-read ";
memset(buf, '\0', sizeof(buf));             //设buf都设置为'\0',防止乱码
strcat(a, key);
stream = popen(a, "r");                   //执行命令a,并创建读取其执行结果的流
fread(buf, sizeof(char), sizeof(buf), stream);    //将流中的数据读取到buf中
pclose(stream);
printf("buf=%s\n", buf);
return buf;
}

阅读(1433) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~