全部博文(35)
分类: 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;
}