Windows 环境使用 CloudStack的 simulator

1.  环境和需要软件信息:
    CloudStac版本: 4.2
    OS:Windows 8.1
    Maven: apache-maven-3.2.1
    Cygwin: Setup.ex version 2.850 (64 bit)
    JDK: java version "1.7.0_45"
2. 参考文档:https://cwiki.apache.org/confluence/display/CLOUDSTACK/Setting+up+a+CloudStack+dev+environment+on+Windows
   http://docs.cloudstack.apache.org/en/master/developer_guide.html?highlight=simulator        https://cwiki.apache.org/confluence/display/CLOUDSTACK/Marvin%20-%20Testing%20with%20Python#Marvin-TestingwithPython-Windowsspecifics
3. 简单安装步骤(省略了软件安装步骤):
   1) Checkout 代码
      我们假定CloudStack的源代码根目录是/opt/cloudstack, 我们用git clone源码后,通过git checkout 4.2来转到4.2的分支
      $ cd /opt; git clone https://git-wip-us.apache.org/repos/asf/cloudstack.git 
      下载完成后,转到4.2的分支
      $ git checkout 4.2
   2) 修改代码
       a.  修改cloudstack4.2\cloudstack\tools\apidoc\build-apidoc.sh
        为了让cygwin执行此文件, 首先使用NotePad++等把build-apidoc.sh文件的格式转换为unix格式;然后在找到“
CP=$PATHSEP/
for file in $TARGETJARDIR/*.jar
do
  CP=${CP}$PATHSEP$file
done
for file in $DEPSDIR/*.jar; do
  CP=${CP}$PATHSEP$file
done
java -cp $CP com.cloud.api.doc.ApiXmlDocWriter -d "$DISTDIR" $*”

修改为:

CP=$PATHSEP/
for file in $TARGETJARDIR/*.jar
do
  CP=${CP}$PATHSEP$file
done
java -cp $CP com.cloud.api.doc.ApiXmlDocWriter -d "$DISTDIR" $*
CP=$PATHSEP/
for file in $DEPSDIR/*.jar; do
  CP=${CP}$PATHSEP$file
done
java -cp $CP com.cloud.api.doc.ApiXmlDocWriter -d "$DISTDIR" $*

此处修改的目的是为了解决,cygwin命令执行的时,参数(主要是编译的jar的路径)过长,造成数据溢出的错误。我们这里分成两次执行java命令解决这个问题。
  b. 修改cloudstack4.2\cloudstack\utils\src\com\cloud\utils\script\Script.java文件。
  在Script类的构造函数,添加下面代码,使/bin/bash执行的命令修改为cygwin的bash的方式执行。
    public Script(String command, long timeout, Logger logger) {
     if("/bin/bash".equals(command)){
      command = "C:/cygwin64/bin/bash";
     }
        _command = new ArrayList<String>();
        _command.add(command);
        _timeout = timeout;
        if (_timeout == 0) {
         /* always using default timeout 1 hour to avoid thread hang */
         _timeout = _defaultTimeout;
        }
        _process = null;
        _logger = logger != null ? logger : s_logger;
    }
3.编译代码
F:\cloudstack4.2\cloudstack>pwd
/cyg/f/cloudstack4.2/cloudstack
F:\cloudstack4.2\cloudstack>mvn -P developer,systemvm  -Dnonoss -Dsimulator clean install
我这里需要编译nonoss的代码,所以添加了Dnonoss参数。

5.部署数据库
部署数据库之前,需要修改CloudStack的数据库配置信息,包括url,数据实例名,用户名和密码。
配置文件路径为:cloudstack4.2\cloudstack\utils\conf\db.properties
# CloudStack database settings
db.cloud.username=cloud
db.cloud.password=cloud
db.root.password=password
db.cloud.host=localhost
db.cloud.port=3306
db.cloud.name=cloud

修改完了数据库的配置信息,我们就可以部署数据库了,执行下面两个命令,在CloudStack的代码目录下
mvn -Pdeveloper -pl developer -Ddeploydb
mvn -Pdeveloper -pl developer -Ddeploydb-simulator
6. 使用 pip 安装simulator,
在用pip安装simulator之前,我们要保证在Cygwin已经正确安装了pip插件。
然后我们执行下面的命令去安装(/cyg/f/cloudstack4.2/,是CloudStack的源代码目录在Cygwin里面的短路径):
pip install /cyg/f/cloudstack4.2/cloudstack/tools/marvin/dist/Marvin-0.1.0.tar.gz
7. 用jetty运行CloudStack
用maven编译完CloudStack的源代码,我们就可以用内置的jetty服务器去运行CloudStack了。
默认的CloudStack的web应用地址是在:cloudstack4.2\cloudstack\client\target\cloud-client-ui-4.2.1-SNAPSHOT\
//在当前窗口设置MAVEN_OPTS参数,增加执行分配的java内存,否则可能会报内存溢出的错误;另外还指定了远程监听的端口为4000,方便我们在Eclipse进行远程调试
F:\cloudstack4.2\cloudstack> set MAVEN_OPTS= -Xms128m -Xmx512m -XX:MaxPermSize=128M -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=4000,server=y,suspend=n
F:\cloudstack4.2\cloudstack> mvn -pl client jetty:run

8. 使用Marvin安装基本Zone或是高级Zone
在CloudStack的运行期间,另外开启一个窗口,执行下面命令:
F:\cloudstack4.2\cloudstack> mvn -Pdeveloper,marvin.setup -Dmarvin.config=setup/dev/basic.cfg -pl :cloud-marvin integration-test 或者安装高级zone
F:\cloudstack4.2\cloudstack>mvn -Pdeveloper,marvin.setup -Dmarvin.config=setup/dev/advanced.cfg -pl :cloud-marvin integration-test
9.重启应用,步骤完成。我们就可以通过浏览器去访问CloudStack的应用了。

猜你喜欢

转载自gltomorrow.iteye.com/blog/2089817