Osv的开发使用
简介
Osv 是一款专注于云计算的操作系统,其目标是将客户端运行在虚拟机之上。在Linux环境中,可以为单个Linux可执行文件或应用程序,定制专属的操作系统。
参考:这里
开发使用( 以下操作均在Ubuntu环境下运行 )
下载源码
https://github.com/cloudius-systems/osv.git
下载所需要的依赖环境
进入源码的根目录后,执行:sudo scripts/setup.py
更新子模块
git submodule update --init --recursive
编译所需要执行的镜像文件
在源码根目录下执行:sudo scripts/build
在app目录下,有一些已经制作好的,可以直接使用的镜像文件。
例如,要编译Memecached镜像文件:sudo scripts/build image=memcached
运行Osv
最简单的方法,执行:sudo scripts/run.py
当然有一些应用程序,是需要打开所对应的端口的,如Memcached的启动方式为:sudo scripts/run.py -e "memcached -u root -p 11211" --forward "tcp:11211::11211"
(使用--foword
指令打开所需要的端口)
制作运行自己的镜像
参考:这里
简单的介绍一下,如何在Osv里面部署自己的镜像。
Makefile
参考:这里
简单的说,其主要工作,就是告诉编译器,要如何编译源文件。
usr.manifest
在这个文件中,需要告诉Osv如何将所要运行程序部署到Osv中。
文件的结构大致为:
[manifest]
/usr/file1: ${MODULE_DIR}/file1
/usr/file2: ${MODULE_DIR}/file2
其中,左边为客户端的位置(即映射到Osv中的位置),右边为主机中的位置(此处可以简单理解为,所要运行程序在主机中的位置)。
module.py
这个文件是其中的核心文件,其主要功能有以下几个方面
- 声明与其它模块之间的依赖关系
- 声明运行时候的相关配置
- 访问其它模块的属性
- 定义文件的映射关系(可以替代
usr.manifest
文件的功能)
java-example
以下通过介绍Osv中自己所带的镜像,简要的梳理一下上面各个文件的具体作用。
Hello.java
一个普通的java,"Hello,World!"程序
public class Hello {
public static void main(String[] args) {
System.out.println("Hello, World!");
}
}
Makefile
第一部分指明,所要生成的文件为Hello.class
第二部分指明,通过:javac
指令,将.java文件,编译成.class文件
第三部分指明,若执行:make clean
,即自动将编译痕迹清除
module: Hello.class
%.class: %.java
javac -target 7 -source 7 $^
clean:
rm -rf *.class
usr.manifest
此处指明所生成的Hello.class,将会映射到Osv的/java-example/Hello.class
路径下。其中右边代表了在主机中编译生成的Hello.class的位置,其中{MODULE_DIR}指代的为当前目录下。
/java-example/Hello.class: ${MODULE_DIR}/Hello.class
module.py
在Osv环境下,运行Hello.class
from osv.modules import api
api.require('java')
default = api.run_java(classpath=['/java-example'], args=['Hello'])