Atlas Demo 工程介绍 | 学习笔记

简介: 简介:快速学习 Atlas Demo工程介绍

开发者学堂课程【开源 Android 容器化框架 Atlas 开发者指南: Atlas Demo 工程介绍】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/392/detail/5019


Atlas Demo 工程介绍

 

Demo 工程包含了 atlas 大部分的功能,使用方式和情况。


Atlas Demo 介绍

⒈bundle、awb、host 的介绍。

(1)bundle 类似于 OSGI 规范里面的 bundle 的概念。每个 bundle 有自己的 class loader 与其他 bundle 相隔离。

同时,atlas 框架下的 bundle 有自身的资源段,也就是 package ID ,这个是在打包时 aapt 制定的。通过资源段的自定义,解决了 bundle 与宿主资源冲突的问题。

另外,原有 OSGI 所定义的 service 格式不同之处,是 atlas 里面 bundle 透出所有定义在 manifest 里面的 component 。随着 service activity 的出发进行 bundle 的安装和运行。

(2)Awb android wear less bundle 的缩写,实际上同 AAR 类似,是最终构建整包前的中间产物,那个 AWB 会最终达成一个 bundle。Awb 与 AAR 唯一的不同之处是 awb 与之对应有个 packageID 的定义,也就是前面所提到的资源分段,他们将以 so 文件的格式放在 apk 的 Lab 文件夹下。

(3)Host 宿主的概念,所有的 bundle 可以直接调用 host 内的代码和资源,所以 host 常常集合了公共的中间件 UI 的资源。

⒉工程介绍

打开 demo 工程,给大家介绍一下工程中每个模块的作用。

使用的是 master 分支,

目录下的 settings gradle 文件

image.png

里面标明了 demo 项目是由哪些模块组成的。

project 的目录

image.png

Activity group compact 目录。可以把这个模块儿当做 atlas 框架,在 demo 项目中的工具类,负责启动 activity 。 APP 目录。主客户端的代码。

Data bind bundle。使用谷歌 datebind 框架的 bundle。 Firstbundle。

第一个业务 bundle 的代码。 lottie。这个目录是 splash screen 依赖的代码,这个项目是一个开源的项目,是根据真实文件来展示动画效果的开源库。

Middle ware library 中间键 library 这个是会达到主 dex 中的 AR 。 Public bundle 这是公共 bundle 的代码,这个是不会打入主 dex 的。 Remote bundle 目录。是远程 bundle 的代码。

远程 bundle 在 APK 发布时不会变异为 APK 内。而是在客户端使用时,先下载后加载。 second bundle 。第二个业务的 bundle 代码。Second bundle library 目录。这是第二个业务 bundle 单独依赖的 library 代码。 splash screen 是闪屏的代码。

⒊demo 中 atlas 的配置

Atlasdemo 工程的配置跟 atlas 相关的配置。一个应用要借助 atlas ,需要哪些配置呢?

配置非常简单,这里对照 demo 工程看一下。

首先看根目录下的 build.gradle 文件,

image.png

可以看到在 build script 的依赖里面。我们增加了一项 atlasplugin 的依赖。

这是负责构建 atlas 应用的插件。然后打开 APP 下的 build.gradle 文件。

image.png

我们用一个名字叫做 come.taobao.atlas 插件。

如果不清楚如何开发 gradle 插件的,可以看前面基础知识介绍,关于如何自定义插件的文章。

然后 dependencies 依赖里面有两个跟 atlas 相关的依赖,第一个是 atlascore 。atlas 运行的核心库,第二个是 atlas Update 是负责 atlas 框架下应用的更新,增量 patch 的代码,资源合并等更新功能相关的库。

这样,atlas 框架就引入到我们的工程里了。引入后我们需要进行一些配置。

gradle 文件中 atlas 相关配置项目。

image.png

atlas Enabled 这是 atlas 的开关,一般接入后这个都要打开。tBuildConfig 看这个里面的配置。

auto start bundles 也就是说跟随应用启动而进行安装下载。普通的 bundle 是要在运行的时候才进行,加载。

比如说你打开一个页面,那么这个页面的 bundles 会在你打开的时候先进行安装在加载的。

Out of a pk bundles 是打包时不打到包中的 bundle ,也就是远程 bundle,这里面需要配置的是 bundle 的 Artifact ID 。prelaunch 要实现 atlas prelauncher 里面的 innit before atlas 方法,只需要在atlas框架启动前进行启动的功能。比如崩溃信息的统计,就需要在 atlas 框架前启动,这样关于 atlas 框架的崩溃才会统计。另外注意所有在 atlas 启动前启动的功能是不能够被动态部署的。

manifest options 是指 manifest 的一些配置项,后面给出个配置的列表。patchconfigs 是指动态部署的一开始的相关配置。这里配置的 createTpatch 表示功能开启。

baseAPdependency 基线版本的坐标,后面我会说明如何发布基线版本。atlas 的配置就介绍到这里。下面我看一下依赖的写法。大家注意这个 bundlecompile 的写法,

image.png 

这样引入的依赖会把它当做一个 bundle ,打包的时候会打入到 apk 的 lab 下,也就是我们的插件了。

APP 中关于 atlas 配置的部分就说明完了。bundle 工程应该如何配置。以 firstbundle 为例。打开 build.gradle 文件,

image.png

同样我们应用 com.Taobao.atlas 的一个插件。

看 atlas 的配置相。其中重要的一个就是 awb bundle true 标明这是个 bundle 工程,产物会生成 awb 文件,也就是最后打入包中的 so 文件。

baseapfile 前面已经介绍过了,是基线版本的位置。我们看一下 bundle 工程依赖部分的写法。这里有一个 provided compile。

image.png

这个 provided compile 相当于普通应用中的 PROVIDED 依赖写法。依赖编译,但不会打入包中,只是 provided compile 也支持了 AAR 的格式。

相关文章
|
存储 缓存 文件存储
如何保证分布式文件系统的数据一致性
分布式文件系统需要向上层应用提供透明的客户端缓存,从而缓解网络延时现象,更好地支持客户端性能水平扩展,同时也降低对文件服务器的访问压力。当考虑客户端缓存的时候,由于在客户端上引入了多个本地数据副本(Replica),就相应地需要提供客户端对数据访问的全局数据一致性。
32697 79
如何保证分布式文件系统的数据一致性
|
前端开发 容器
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局(上)
HTML5+CSS3前端入门教程---从0开始通过一个商城实例手把手教你学习PC端和移动端页面开发第8章FlexBox布局
17749 20
|
设计模式 存储 监控
设计模式(C++版)
看懂UML类图和时序图30分钟学会UML类图设计原则单一职责原则定义:单一职责原则,所谓职责是指类变化的原因。如果一个类有多于一个的动机被改变,那么这个类就具有多于一个的职责。而单一职责原则就是指一个类或者模块应该有且只有一个改变的原因。bad case:IPhone类承担了协议管理(Dial、HangUp)、数据传送(Chat)。good case:里式替换原则定义:里氏代换原则(Liskov 
36680 19
设计模式(C++版)
|
存储 编译器 C语言
抽丝剥茧C语言(初阶 下)(下)
抽丝剥茧C语言(初阶 下)
|
机器学习/深度学习 人工智能 自然语言处理
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
带你简单了解Chatgpt背后的秘密:大语言模型所需要条件(数据算法算力)以及其当前阶段的缺点局限性
24757 14
|
机器学习/深度学习 弹性计算 监控
重生之---我测阿里云U1实例(通用算力型)
阿里云产品全线降价的一力作,2023年4月阿里云推出新款通用算力型ECS云服务器Universal实例,该款服务器的真实表现如何?让我先测为敬!
36660 15
重生之---我测阿里云U1实例(通用算力型)
|
SQL 存储 弹性计算
Redis性能高30%,阿里云倚天ECS性能摸底和迁移实践
Redis在倚天ECS环境下与同规格的基于 x86 的 ECS 实例相比,Redis 部署在基于 Yitian 710 的 ECS 上可获得高达 30% 的吞吐量优势。成本方面基于倚天710的G8y实例售价比G7实例低23%,总性价比提高50%;按照相同算法,相对G8a,性价比为1.4倍左右。
|
存储 算法 Java
【分布式技术专题】「分布式技术架构」手把手教你如何开发一个属于自己的限流器RateLimiter功能服务
随着互联网的快速发展,越来越多的应用程序需要处理大量的请求。如果没有限制,这些请求可能会导致应用程序崩溃或变得不可用。因此,限流器是一种非常重要的技术,可以帮助应用程序控制请求的数量和速率,以保持稳定和可靠的运行。
29838 52

热门文章

最新文章

下一篇
开通oss服务