QCon 2015 阅读笔记 - 移动开发最佳实践

所有ppt下载地址:http://pan.baidu.com/s/1mg9o4TM

下面是移动开发实践部分的阅读笔记。

移动开发网络性能优化实践 - 陈浩然 (携程)

携程是非常标准的移动App架构,基础是各种Infrastructure Frameworks, 基于上面是UI的控件库,运行时的库(猜测用于动态配置)。最上层是业务层面,各个App层可以相对独立形成业务模块化。同时也是Hybrid的架构,有Web Container来实现WebApp的模块。

网络服务

  1. Native

    • TCP连接 + 少量Restful HTTP
    • TCP长连接
    • 数据序列化

  2. Native

    • 主要Restful HTTP

常见网络性能问题

  1. DNS劫持、解析慢
  2. TCP connection:端口被封,连接超时设置
  3. 读写:超时设置,Proxy拦截
  4. 传输Playload过大
  5. 网络环境复杂

优化实践

  1. 优化DNS解析缓存:内置Server IP列表,并行DNS解析,Server IP列表权重机制
  2. 网络质量检测:根据网络质量来改变一些策略 (TCP连接超时时长,TCP读操作时长,网络并发数)
  3. 提供网络服务重发机制
  4. 优化海外网络性能:CDN加速,动静分离

网络性能的监控:一切用数据说话

网络服务新技术方向

SPDY&HTTP/2.0协议

QUIC协议

总结:携程主要针对网络层面各个环节进行了大量优化,提高了服务的成功率,降低了耗时,减少了数据的传输,减少了数据序列化的耗时。建立了一整套网络服务监控实时系统,这样做到有的放矢。展望了下未来网络服务的新技术方向,新的网络协议会带来非常大的好处,让人期待。

美团移动平台背后的技术 - 陈晓亮(美团)

美团移动平台主要由业务需求驱动,需要支持业务和平台的同时扩展。

在代码的组织方式上面采用的是CocoaPods

最终美团移动App的架构

移动时代用户端问题高效诊断 - 马玉明(腾讯)

马玉明强调移动时代的客户端问题的复杂性,没有容易的定位方式。推出云诊断服务,用户可以一键点击完成反馈。

广告时间:http://huatuo.qq.com. 有兴趣尝试的小伙伴们可以试试看 :)

Rethinking of mobile app architecture - 郭虹宇(Geek-Zoo Studio)

移动技术发展的历史

  • 1994:Web page (HTML+CSS)
  • 2008: iOS native app (C/OC)
  • 2011: PhoneGap hybrid app (HTML+CSS)
  • 2013: BeeFramework hybrid app (XML+CSS)
  • 2015: React-Native hybrid app (JS+CSS)

鱼和熊掌的取舍:

  • Native: 复杂,发布,更多平台,更多人力投入
  • Hybrid: 不好的用户体验

Simi-Hybrid: get the best part of native and web, native framework+Web-core

核心的不同

  • Hybrid App: 最终的页面呈现形式是"Painter",是在WebView中显示web page
  • Semi-Hybrid: 最终的页面呈现形式是"Buider"出native view, 通过Web-Core将输入的HTML,JS, CSS转换成为Native View

后面开始广告阶段,介绍Samurai,核心思想和React-Native非常一致,都是将JS+CSS的语言转换成Native view。

Style&layout

  • React-Native: JSX+CSS layout
  • Samurai: HTML+CSS 2/3

Touch handling

  • React-Native: UIView mask
  • Samurai: Gesture recognizer

Native Components

  • React-Native: 自定义的UI component
  • Samurai: 采用的是元素的component命名规范

开源项目:https://github.com/hackers-painters/samurai-native

React-Native对于Web developer更加友好,Samurai对于Native developer更加友好。

Native和Web融合 - 鬼道(天猫)

天猫App大范围采用Native和Web混合模式。首页,搜索,详情,交易等部分是Native实现,频道、日常活动、大促等都是Web实现。

Native进行了大量代码重构解耦,实现业务复用。

Web体验的改进

通过打包系统,xList(解决长list占用内存),性能监控,HybridAPI

React Native

天猫iPad版本率先尝试了React Native,并获得非常好的结果。

结论:在内存/CPU/启动时间,React Native和Native接近,优于Web。

根据规划会在整个天猫App中进行大量的推广。

总结:

  • 移动App的架构基本都是平台化+业务模块化,可以保证重用性,并方便业务扩展。
  • React-Native很火,非常火!天猫App已经开始尝试,并取得不错效果。Samurai的跨平台方案核心思想和React-Native极为相似,对Native开发者更为友好。看起来这股跨平台旋风还要再刮会。
  • 网络服务的优化,性能监控都是非常重要。一切以数据说话!
时间: 2024-10-16 07:49:51

QCon 2015 阅读笔记 - 移动开发最佳实践的相关文章

QCon 2015 阅读笔记 - 团队建设

QCon 2015阅读笔记 QCon 2015 阅读笔记 - 移动开发最佳实践 QCon 2015 阅读笔记 - 团队建设 中西对话:团队管理的五项理论和实战 - 谢欣.董飞(今日头条,LinkedIn) 两位讲解人其实都是比较有经验的,来自国内外一线互联网企业. 谢欣:微软->百度->酷讯(创业)->今日头条 董飞:酷讯->百度->亚马逊->LinkedIn 实战一:人才招聘面试 来源:内推,linkedIn 喜欢:聪明,好奇,热情,交流 不喜欢:不愿学习,不符合企业

QCon 2015 阅读笔记 - 其他精选主题

QCon 2015阅读笔记 QCon 2015 阅读笔记 - 移动开发最佳实践 QCon 2015 阅读笔记 - 团队建设 QCon 2015 阅读笔记 - 其他精选主题 以前分享过两个主题:移动开发最佳实践和团队建设,有兴趣可以通过上面传送门进入.这次我的阅读笔记会比较分散,希望能够把一些我认为不错的主题介绍一下. 论DevOps式思维方式 - Chris Van Tuin 分三个维度介绍如何加速软件研发,表明软件研发的趋势 How: 开发模式 - 瀑布流.敏捷.DevOps What: 软件

【读书笔记】iOS-微信公众平台开发最佳实践

一,微信是由腾讯公司广州研发中心产品团队开发,该团队经理张小龙被称为"微信之父",公司总裁马化腾确定该产品名称为"微信". 二,常见问题及解决方案. 1,请求URL超时. 这种情况一般是由于服务器网速或响应速度太慢.可以重试几次或者等一段时间再来试,如果还是这样,则需要考虑更换速度更快,性能更好的服务器. 2,系统发生错误,请稍后重试. 这种情况一般是由于微信服务器短时间内的异常引起的,一般重试或者过一段时间尝试即可. 3,服务器没有正确响应Token验证,请阅读&

Android和PHP开发最佳实践 (第2版)——互动出版网

这篇是计算机类的优质预售推荐>>>><Android和PHP开发最佳实践 (第2版)> 51CTO社区.PHPChina社区强烈推荐!国内第一本同时讲述Android客户端开发和PHP服务端开发的经典著作!市面上第一本把Android应用客户端加服务器开发的完整解决方案分析透彻的书 本书是国内第一本同时讲述Android客户端和PHP服务端开发的经典著作. 本书以一个完整的微博应用项目实例为主线,由浅入深地讲解了Android客户端开发和PHP服务端开发的思路和技巧.从

微信公众平台开发最佳实践(第2版)

<微信公众平台开发最佳实践 第2版>微信公众平台开发经典之作全新改版,精心挑选最经典的商业项目开发,成千上万人次微信公众平台开发者从中受益 前言 出版说明 自从方倍工作室在博客园推出微信公众平台开发系列教程后,受到广大微信开发人员及爱好者的热情关注,相关文章的日访问量高达2万人次,而<微信公众平台开发入门教程>的阅读量超过50万,博客访问量总计超过500万,成为微信公众平台开发更新最快,传播最广.受众最多.资料最全的博客,很多博文被许多有影响力的网站转载,并被各大搜索引擎收录且排名

Hadoop MapReduce开发最佳实践(上篇)

body{ font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI",Tahoma,Helvetica,Sans-Serif,"Microsoft YaHei", Georgia,Helvetica,Arial,sans-serif,宋体, PMingLiU,serif; font-size: 10.5pt; line-height: 1.5;}

[1.30] 保持的力量:接口开发最佳实践

神啊,求你赐给我平静的心,去接受我无法改变的事:赐给我勇气,去做我能改变的事:赐给我智慧,去分辨两者的不同. --平静之祷 1.30.1 论保持的力量 追到一个心仪的女生不难,难于如何保持和培养一份真挚的感情:获得一时的财富也不难,难于如何长久保持收益:创业的公司很容易博得一时媒体的关注以及某次天使的投资,但难于如何排除各种障碍.充分利用各方资源发展成中企业及至上市公司. 同样,提供一时的接口很容易,但当我们需要不断为接口提供升级,以及当我们维护提供一整套接口时,面临的困难和问题会越来越大.所以

【微信公众平台开发最佳实践】正品!包邮!半价!双12特惠,仅此一天,微信开发必备,请尽快购买!

[正品!五折!包邮!] #史上最低价,错过等明年!# 微信开发必备宝典 <微信公众平台开发最佳实践>双12盛典, 定价69,现价34.5元, 点此购买

移动端WEB前端开发最佳实践

移动端WEB前端开发最佳实践 Safari,Android Browser,Chrome都是以WebKit为核心的 移动设备和PC之间的页面现实存在差异(Safari中定义了viewport) 在移动设备和桌面端WEB前端开发中,事件绑定存在差异(移动触点) 页面控件设计存差异(点触不灵敏,虚拟键盘弹出框) 移动设备的网络带宽普遍比PC慢,移动页面要设置更简洁 PC页面兼容移动设备 使用流式布局 借助CSS Media queries(媒体查询)技术 使用合适的图片显示兼容方案 保持页面简洁,不