Mars Sample 使用说明
Mars Sample 使用说明
为了更好地帮助开发者使用和理解Mars并且体验Mars的特性,需要开发者自行搭建服务器。服务器的代码在mars源码目录下的samples/server中
体验内容包括:
- 基于TCP长连接的聊天室体验。
- 数据通信成功率、耗时、流量的展示。
- 网络状况检测结果展示。
如果开发者想要本地体验,可以遵照下面的方法。
Server启动
进入mars源码目录下的samples/server,执行start_server.py脚本,选择对应平台
$ python start_server.py
Enter menu:
1. start server on Mac, Linux or Cygwin.
2. start server on Windows.
3. exit.
若在类Unix平台执行脚本后出现
: file not found
错误,请使用vim打开gradlew文件,按
shirft+:
,输入
set fileformat=unix
后保存并退出。
server代码使用java编写,gradle集成,所以首次使用的开发者需要耐心等待gradle环境的自动下载和准备。
Mac、Windows平台执行脚本成功后会弹出Proxy和WebServer启动成功的命令行窗口:


Linux平台下Server的启动被设置为后台进程,当脚本执行完毕后可通过
ps aux|grep gradle
命令观察,并进入
{user.home}/logs/mars
目录查看日志,确认是否启动成功。
Android Sample
使用本地Server服务,有多种方法可供选择:
方法一、修改替换云服务域名marsopen.cn的NewDNS解析(MarsServiceStub.java):
{
@Override
public String[] onNewDns(String host) {
return new String[]{
"118.89.24.72"
};
}
}
将"118.89.24.72"替换为"127.0.0.1",并且需要将app/build.gradle里的useLocalMarsWrapper修改为true,使用本地wrapper project
方法二、全局搜索marsopen.cn,修改替换为localhost
强烈推荐方法二
把手机连接到电脑上或者打开模拟器,运行
adb reverse tcp:8080 tcp:8080
adb reverse tcp:8081 tcp:8081
把手机或者模拟器的端口映射到电脑上, 需要注意的Android 5.0及以上才支持 adb reverse
使用Android Studio打开mars源码目录下samples/android/build.gradle,待gradle sync完成,直接启动即可。
启动Android Sample后进入会话列表界面:

点击任意Topic即可进入聊天室:

开发者如果想查看数据通信的成功失败以及耗时等多方面数据统计,可在会话列表界面点击右上角进入:

简单解析数据统计页面内容:
- 界面底部Tab分别展示数据通信、流量、网络自动检测的统计结果。
- 数据通信页面,task 代码执行的数据通信业务类型、success 表明是否执行成功...
如图中表示拉取会话列表的通信通过 HTTP 短连接执行了两次失败。
iOS/Mac Sample
使用本地Server服务,
方法一、需要修改替换云服务域名marsopen.cn的NewDNS解析(stn_callback.mm):
std::vector<std::string> StnCallBack::OnNewDns(const std::string& _host) {
std::vector<std::string> vector;
vector.push_back("118.89.24.72");
return vector;
}
方法二、全局搜索marsopen.cn,修改替换为localhost,删除stn_callback.mm的OnNewDns方法中的
vector.push_back("118.89.24.72");
推荐方法二,然后按照下列方法运行程序:
- 通过编译脚本编出相应的库
- 把 framework 库放到相应的 sample 目录,例如 iOSDemo 目录(如果提示链接不上,或者库在其他目录通过修改 Link Binary With Libraries链接上正确的mars库)
- 把进入 mars 源码目录下 samples/iOS/iOSDemo or samples/Mac 选择 xcodeproj 启动,
Windows Sample
使用本地Server: 全局搜索marsopen.cn,替换为127.0.0.1,删除stn_callback.cpp中的
vector.push_back("118.89.24.72");
然后按照下列方法启动客户端:
- 进入到 sample/Windows目录
- 执行
md cmake_build && cd cmake_build && cmake .. && cmake --build . --target install --config Release && cd .. - 进入到cmake_build/Windows.out目录运行exe即可
- 如果需要调试,可使用cmake_build目录下的sample.sln 进行调试
Mars Sample 使用说明的更多相关文章
- hdu 3873 Invade the Mars(有限制的最短路 spfa+容器)
Invade the Mars Time Limit: 5000/2000 MS (Java/Others) Memory Limit: 365768/165536 K (Java/Others ...
- CodeForces 670 A. Holidays(模拟)
Description On the planet Mars a year lasts exactly n days (there are no leap years on Mars). But Ma ...
- Codeforces Round #350 (Div. 2) A. Holidays 水题
A. Holidays 题目连接: http://www.codeforces.com/contest/670/problem/A Description On the planet Mars a y ...
- 如约而至:微信自用的移动端IM网络层跨平台组件库Mars已正式开源
1.前言 关于微信内部正在使用的网络层封装库Mars开源的消息,1个多月前就已满天飞(参见<微信Mars:微信内部正在使用的网络层封装库,即将开源>),不过微信团队没有失约,微信Mars ...
- hdu4059 The Boss on Mars(差分+容斥原理)
题意: 求小于n (1 ≤ n ≤ 10^8)的数中,与n互质的数的四次方和. 知识点: 差分: 一阶差分: 设 则 为一阶差分. 二阶差分: n阶差分: 且可推出 性质: 1. ...
- PAT (Advanced Level) Practise:1027. Colors in Mars
[题目链接] People in Mars represent the colors in their computers in a similar way as the Earth people. ...
- word2vec使用说明(google工具包)
word2vec使用说明 转自:http://jacoxu.com/?p=1084. Google的word2vec官网:https://code.google.com/p/word2vec/ 下 ...
- hdu---(1800)Flying to the Mars(trie树)
Flying to the Mars Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Other ...
- HDU 4059 The Boss on Mars 容斥原理
The Boss on Mars Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
随机推荐
- 灵活的MyBatis
一.前言 将数据存储到数据库是开发中很重要的一环.曾经有程序员说自己做过最牛逼的事情就是增删改查.确实我们做了很多页面,后太代码写了很多,可是最终都离不开数据库的增删改查.Java有一套自己的JPA标 ...
- ubuntu16.04 用devstack部署安装OpenStack ocata
原文链接 之所以再重复一下,是因为踩坑的过程,希望能帮助有需要的人. 介绍: 宿主机win10,在vmware下创建两台ubuntu16.04虚拟机,一台作为控制节点,一台作为计算节点, ...
- 【转】干货篇:手机绕过BL锁9008模式强刷
<ignore_js_op> 高通QPST线刷其实就是利用高通芯片自带的9008端口,将手机系统内的所有分区的镜像文件,直接刷写手机.这个刷机方式比REC卡刷和fastboot线刷,更底层 ...
- 【转】解决chrome浏览器不支持audio和video标签的autoplay自动播放
声音无法自动播放这个在 IOS/Android 上面一直是个惯例,桌面版的 Safari 在 2017 年的 11 版本也宣布禁掉带有声音的多媒体自动播放功能,紧接着在 2018 年 4 月份发布的 ...
- kotlin基础 尾递归
尾调用的重要性在于它可以不在调用栈上面添加一个新的堆栈帧——而是更新它,如同迭代一般. 尾递归因而具有两个特征: 调用自身函数(Self-called): 计算仅占用常量栈空间(Stack Space ...
- pauseable 库
pauseable.js https://www.npmjs.com/package/pauseable Pauseable allows you to pause event emitters, t ...
- Qt编写控件属性设计器
一.前言 自从研究Qt编写自定义控件以来,一发不可收拾,越多越多人有类似的需求找我定制控件,陆陆续续写了上百个控件,目前已超过150个,于是逐渐衍生了另外一个需求,提供一个控件属性设计器,类似QtDe ...
- winform调用webservice假死怎么解决
主线程调用外部web service,没有返回时,主线程阻塞了,界面肯定假死耗时操作都是要在工作线程里面执行的.一般情况下winform调用webservice时步骤1添加服务引用---高级----添 ...
- Linux终端复制粘贴后前后会多出0~和~1
在终端中执行即可 printf "\e[?2004l" 在终端无法复制问题 set mouse=r
- shell基础知识之 stdin,stdout,stderr和文件描述符
stdin,stdout,stderr stdin=0 stdout=1 stderr=2 使用tee来传递内容,把stdout 作为stdin 传到下个命令 root@172-18-21-195:/ ...