cordova@11 依赖环境:

  • Java_jdk@1.8.0
  • Nodejs@12.22.9
  • android-sdk
    • Build-tools 28
    • API 28
  • apache-ant@1.10.12
  • gradle@4.10.3

1、下载docker镜像 ubuntu

docker pull ubuntu

2、创建容器,挂载 E:\Downloads 到容器

docker run -i -t -v /e/Downloads:/Downloads ubuntu:latest /bin/bash

3、分别下载以下文件到 E:\Downloads

此时目录被挂载到了容器内,可以在容器内访问下载的文件。

4、将以上文件解压到 /root/devtools/

# 创建文件夹
mkdir /root/devtools/
# 解压文件
unzip /Downloads/commandlinetools-linux-8092744_latest.zip -d /root/devtools/
unzip /Downloads/gradle-4.10.3-all.zip -d /root/devtools/
tar -xzvf /Downloads/apache-ant-1.10.12-bin.tar.gz -C /root/devtools/
tar -xzvf /Downloads/node-v12.22.9-linux-x64.tar.gz -C /root/devtools/
tar -xzvf /Downloads/jdk-8u321-linux-x64.tar.gz -C /root/devtools/

目录如下:

root
┕ devtools
└ jdk1.8.0_321
└ node-v12.22.9-linux-x64
└ apache-ant-1.10.12
└ gradle-4.10.3
└ Android
└ sdk
└ cmdline-tools
└ latest
├ NOTICE.txt
├ bin
├ lib
└ source.properties

注意:安卓目录必须按照以上示例的结构,否则安装api时会报错

5、配置环境变量

编辑profile文件 vim /etc/profile ,添加以下内容:

set java environment
JAVA_HOME=/root/devtools/jdk1.8.0_321
JRE_HOME=/root/devtools/jdk1.8.0_321/jre
NODE_PATH=/root/devtools/node-v12.22.9-linux-x64
ANT_HOME=/root/devtools/apache-ant-1.10.12
ANDROID_HOME=/root/devtools/Android/sdk
GRADLE_PATH=/root/devtools/gradle-4.10.3
CLASS_PATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib
PATH=$PATH:$JAVA_HOME/bin:$JRE_HOME/bin:$NODE_PATH/bin:$ANT_HOME/bin:$ANDROID_HOME/cmdline-tools/latest/bin:$GRADLE_PATH/bin
export JAVA_HOME JRE_HOME CLASS_PATH PATH ANDROID_HOME ANT_HOME

运行 source /etc/profile 让配置生效

如果vim输入麻烦,可以将 /etc/profile 文件 cp 到 /Downloads 目录下,在外层改完后再 cp 回去

进入容器每次都需要运行 source /etc/profile 才能让变量生效,可以在 ~/.bashrc 文件最后一行添加 source /etc/profile

6、重启容器,安装安卓 api 和 build-tools

# 添加安卓 api28 和 build-tool28
sdkmanager "build-tools;28.0.3" "platforms;android-28" "platform-tools"

7、安装cordova

npm install -g cordova@11.0.0

如果报错 sh: 1: node: Permission denied 则执行以下命令:

npm config set user 0
npm config set unsafe-perm true

8、将容器保存为 docker 镜像

退出容器 exit,执行命令:

docker commit [容器ID] cordova:1.0

9、命令行使用镜像打包apk

docker run --rm -i -t -v [APP项目根目录]:/appDir cordova:1.0 /bin/bash -c "source /etc/profile && cd /appDir && cordova build android"

这条命令首先将APP目录挂载到容器,进入容器后自动cd到APP目录下执行打包命令,打包完毕后容器会被删除。 如果重复提醒 May Cordova anonymously report usage statistics to improve the tool over time?,可以先把APP目录挂载进去运行一次打包,再提交镜像,就不会重复下载 gradle 了。

文章来源:https://www.cnblogs.com/flicat/p/16093696.html

docker搭建cordova 11环境的更多相关文章

  1. 使用Docker搭建Tomcat运行环境

    1 准备宿主系统 准备一个 CentOS 7操作系统,具体要求如下: 必须是 64 位操作系统 建议内核在 3.8 以上 通过以下命令查看您的 CentOS 内核: # uname -r 2 安装Do ...

  2. 利用Docker搭建本地https环境的完整步骤

    利用Docker搭建本地https环境的完整步骤 这篇文章主要给大家介绍了关于如何利用Docker搭建本地https环境的完整步骤,文中通过示例代码将实现的步骤介绍的非常详细,对大家的学习或者工作具有 ...

  3. Docker最全教程之使用Docker搭建Java开发环境(十七)

    前言 Java是一门面向对象的优秀编程语言,市场占有率极高,但是在容器化实践过程中,发现官方支持并不友好,同时与其他编程语言的基础镜像相比(具体见各语言镜像比较),确实是非常臃肿. 本篇仅作探索,希望 ...

  4. 怎么使用Docker搭建PHP开发环境呢?

    在Docker流行之前,要搭建开发环境通常有两种选择:一种是使用wamp.xampp.mamp等集成开发环境安装包,另外一种就是使用普通虚拟机来安装linux服务器,然后通过下载一键安装包(如:lnm ...

  5. mac下搭建cordova开发环境

    Apache Cordova 原名叫PhoneGap.是一个用基于HTML,CSS和JavaScript的,创建移动跨平台移动应用程序的快速开发平台.PhoneGap最初由Nitobi开发,2011年 ...

  6. docker 搭建 web 服务环境

    docker容器虽然早就听说过,但是本人还真的没去用过,刚好看到相关的文章,就分享了下,有机会可以实践下...... 做过开发的人对开发环境的安装.配置应该都不会太陌生,不管你做什么开发,对开发环境都 ...

  7. 在windows环境里,用Docker搭建Redis开发环境(新书第一个章节)

    大家都知道高并发分布式组件的重要性,而且如果要进大厂,这些技术不可或缺.但这些技术的学习难点在于,大多数项目里的分布式组件,都是搭建在Linux系统上,在自己的windows机器上很难搭建开发环境,如 ...

  8. 使用 Docker 搭建 Tomcat 运行环境

    转自: http://m.oschina.net/blog/616526, 版权归原作者所有. 1 Docker与虚拟机     2 搭建过程 2.1 准备宿主系统 准备一个 CentOS 7操作系统 ...

  9. 搭建Cordova开发环境

    Cordova是什么 Apache Cordova是一套设备API,允许移动应用的开发者使用JavaScript来访问本地设备的功能,比如摄像头.加速计.它可以与UI框架(如jQuery Mobile ...

随机推荐

  1. aria2 源码解析专题 —— (二) Exception 部分

    首先声明 Exception 部分的几个异常类的继承关系,如下: 这一版的 Exception 部分只有头文件,没有源文件,所以涉及到的更多的只是定义而已,没有太多实现,所以这一部分也简单说说每个类的 ...

  2. think php 富框架文本编辑器

    商品的详细描述一般都是图文混合.对于图文混合的内容,需要使用富文本编辑器来实现. Ueditor富文本编辑器的下载地址: http://ueditor.baidu.com/website/downlo ...

  3. L2Dwidget二次元前端添加人物插件

    如果想要在博客园上添加这个插件,只需要在设置的"页首html代码"中添加下面的js就行 <!-- 右下角live2d效果 --> <script src=&quo ...

  4. php 23种设计模式 - 解释器模式

    给定一个语言, 定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子.角色:环境角色(PlayContent):定义解释规则的全局信息.抽象解释器(Empress):定义了部 ...

  5. PhpStrom 好用的代码小地图插件

    类似SublimeText的Mini Map插件 ,废话不多直接上 安装 打开File -> Settings -> Plugins -> 搜索CodeGlance -> in ...

  6. 七天接手react项目 —— state&事件处理&ref

    state&事件处理&ref 在 react 起步 一文中,我们学习了 react 相关知识:jsx.组件.props.本篇将继续研究 state.事件处理和ref. state St ...

  7. LGP4216题解

    这是一种题解没有的 \(O(m\log n)\) 做法. 首先第一步转化.设这是第 \(x\) 个任务,若 \(opt\) 为 \(1\),危险值大于 \(c\) 的只有可能在第 \(x-c-1\) ...

  8. 6月6日 python复习 面向对象

    1.面向对象编程 1.面向过程编程核心是"过程"二字,过程指的是解决问题的步骤,即先干什么再干什么基于该思想编写程序就好比在编写一条流水线,是一种机械式的思维方式 优点:复杂的问题 ...

  9. 网关中间件-Nginx(二)

    网关中间件-Nginx(一) 第一部分我们主要介绍如下几点: 1.nginx的基本概念 2.nginx结合业务场景实现负载均衡 3.常见问题的举例 这一部分主要介绍Nginx中限流,缓存,动静分离,以 ...

  10. 问鼎杯预赛web writeup

    1. php的一个精度问题,具体什么精度自己查. 2017.000000000001=2017 2016.999999999999=2017 直接拿谷歌浏览器访问那个链接就可以拿到flag 2. 访问 ...