美文网首页
OpenStf的搭建以及分布式部署的实现

OpenStf的搭建以及分布式部署的实现

作者: RmondJone | 来源:发表于2020-01-17 18:13 被阅读0次

    一、OpenStf是什么?

    OpenStf是一个可以通过网页管理和使用移动设备的平台,支持远程调试、远程使用手机浏览器打开链接、远程执行shell脚本、远程拖拽安装App、远程查看日志、远程截屏等功能。


    image.png

    二、OpenStf的搭建以及无缝接入Ldap

    (1)MAC环境安装

    MAC上安装建议使用npm的方式安装,这种方式很简单,唯一的要求就是Node版本一定要是8的版本,我采用的是8.9.3版本。如果你的电脑中已经有Node其他版本,则建议使用NVM切换版本。

    安装步骤如下:
    nvm use 8.9.3 
    
    npm install -g stf
    
    brew install rethinkdb graphicsmagick zeromq protobuf yasm pkg-config
    
    启动脚本如下: runOpenStf.sh
    . ~/.nvm/nvm.sh
    nvm use 8.9.3 
    rethinkdb & stf local --public-ip 192.168.27.180
    

    上面的脚本里192.168.27.180是我本机的IP,则我对外暴露我的IP地址,其他机器则可以直接通过http://192.168.27.180:7100访问STF平台。
    平台启动完成,直接把设备插入电脑USB及可以自动识别。

    Ldap的无缝接入

    接入Ldap,只需要在STF启动脚本加入Ldap参数即可。

    #!/bin/sh
    . ~/.nvm/nvm.sh
    nvm use 8.9.3
    rethinkdb & stf local --public-ip 192.168.27.180 --auth-type ldap \
    --auth-options '["--ldap-url","ldap://192.168.xx.xxx","--ldap-bind-dn","cn=ldapuser,cn=xxxx,dc=xxxxx,dc=xxxx","--ldap-search-dn","cn=xxx,dc=xxx,dc=xxx","--ldap-bind-credentials","xxxxxx","--ldap-search-class","user","--ldap-search-field","mail"]' 
    

    具体Ldap参数定义参照:https://testerhome.com/topics/3906

    (2)Linux环境的安装

    Linux上则可以直接通过Docker的方式安装

    拉取相关镜像
       $  docker pull openstf/stf:latest         拉取STF镜像
       $  docker pull sorccu/adb:latest     拉取adb 镜像
       $  docker pull rethinkdb:latest      拉取rethinkdb 镜像
    
    启动相关镜像
    $ docker run -d --name rethinkdb -v /srv/rethinkdb:/data --net host rethinkdb rethinkdb --bind all --cache-size 8192 --http-port 8090
    
    $ docker run -d --name adbd --privileged -v /dev/bus/usb:/dev/bus/usb --net host sorccu/adb:latest
    
    $ docker run -d --name stf --net host openstf/stf stf local --public-ip 192.168.27.200
    

    所有容器启动完成之后,即可通过 http://192.168.27.200:7100访问平台,插上设备即可使用访问。

    三、STF平台的分布式部署

    STF分布式有2种方案,方案如下:

    • 主节点部署STF服务并允许远程访问API,子节点只需部署ADB,保证ADB 5037端口对外暴露即可。这种方案的优点是部署简单,而且子节点无需部署STF服务。缺点就是子节点新增机器需要在主节点重新运行STF命令以识别子节点上新增的机器。
    • 主节点部署STF服务并允许远程访问API,子节点也部署STF服务并允许远程访问API。然后主节点连接子节点。这种方案的优点是子节点新增设备可以自动识别。缺点就是子节点也需要部署STF服务。


      分布式部署.png
    第一种情况,以Window子节点为例

    (1)开启ADB,并对外暴露5037端口

    adb nodaemon server -a -P 5037
    

    如果出现adb端口被占用的情况,则通过命令查找5037端口占用进程并杀死进程即可。

    netstat -aon|findstr 5037
    
    taskkill /pid 5008 /f
    

    (2)到MAC Master主节点运行stf provider命令连接Window子节点

    Window的IP为:192.168.27.247,MAC机器IP为:192.168.27.180

    stf provider --name GHL.local --min-port 7400 --max-port 7700 --connect-sub tcp://127.0.0.1:7114 \
    --connect-push tcp://127.0.0.1:7116 --group-timeout 900 --public-ip 192.168.27.180 \
    --storage-url http://localhost:7100/ \
    --adb-host 192.168.27.247 --adb-port 5037 \
    --vnc-initial-size 600x800 --mute-master never --allow-remote
    

    上面这么多参数,可以查看Master主节点STF启动日志即可查到,这里主要就是通过新增

    --adb-host 192.168.27.247 --adb-port 5037 \
    

    来连接Window机器。

    第二种情况,以Linux子节点为例

    Linux上部署一个STF服务并运行远程访问API,Linux的IP为:192.168.27.200,MAC机器IP为:192.168.27.180
    那么我们只需在Linux上运行stf provider连接Master节点即可,命令如下:

    stf provider --name centerOs.local --min-port 7400 --max-port 7700 \ 
    --connect-sub tcp://192.168.27.180:7114 --connect-push tcp://192.168.27.180:7116 \
    --group-timeout 20000 --public-ip 192.168.27.180 --storage-url http://192.168.27.180:7100/ \ 
    --vnc-initial-size 600x800 --allow-remote
    

    这里可以看到无需输入adb远程端口,此时Linux节点上插入机器,Master节点就可以实时的查看到Linux上挂载的机器。而无需在Master节点重新输入stf provider命令。

    相关文章

      网友评论

          本文标题:OpenStf的搭建以及分布式部署的实现

          本文链接:https://www.haomeiwen.com/subject/bdgczctx.html