Osv的开发使用

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'])

你可能感兴趣的:(Osv的开发使用)