0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

Docker容器部署-以TI AM335x平台为例

Tronlong创龙科技 2021-12-20 15:16 次阅读

前言:Docker是一个开源的应用容器引擎,让开发者可打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的Linux或Windows机器上,亦可实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。使用Docker,可像管理应用程序一样管理基础结构。通过利用Docker的快速发布、测试和部署代码的方法,可显著减少产品开发时间。

Docker容器适用于TI AM335x、AM437x、AM570x、AM5728等平台,本文基于TI AM3352/54/59平台为您讲解Docker的安装及运行测试。


点击图片/图注即可查看该产品资料↓↓↓

pYYBAGHAKeKAVTh7AAeBGDly7bA427.png

图 1


01

Docker架构


Docker使用客户端——服务器(C/S)体系结构。Docker客户端与Docker守护进程进行通信,后者执行构建、运行和分发Docker容器的繁重工作。Docker客户端和守护进程可在同一个系统上运行,亦可将Docker客户端连接至远程Docker守护进程。Docker客户端和守护进程使用REST API、UNIX套接字或网络接口进行通信。

poYBAGHAKeKAeBIrAAS1VEB19Yg033.png

图 2

更多详情请可参考Docker官网链接:https://docs.docker.com/get-started/overview。


02

Docker安装


2.1安装方法

(1)安装依赖包

打开Ubuntu,确保Ubuntu可正常访问互联网,执行如下命令进行安装Docker依赖包。

Host# sudo apt-get update

poYBAGHAKeGAf8xfAACLgEudyi4621.png

图 3

Host# sudo apt-get install apt-transport-https ca-certificates curl gnupg lsb-release

pYYBAGHAKeGAR_AFAADBVkJo-w4074.png

图 4

(2)添加Docker官方GPG密钥

Host# curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

af7ffdf4-5e82-11ec-a27f-dac502259ad0.png

图 5

(3)设置Docker Stable存储库

Host# echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

afc16f8c-5e82-11ec-a27f-dac502259ad0.png

图 6

(4)安装Docker

Host# sudo apt-get update

Host# sudo apt-get install docker-ce

afe77cb8-5e82-11ec-a27f-dac502259ad0.png

图 7

b035fc08-5e82-11ec-a27f-dac502259ad0.png

图 8

(5)验证Docker

执行如下命令,通过运行Docker自带的hello-world镜像来验证是否已安装成功。程序运行后,输出如下内容则表示Docker安装成功。

Host# sudo docker run hello-world

b06add42-5e82-11ec-a27f-dac502259ad0.png

图 9

更多参考信息,请查阅官方手册:https://docs.docker.com/engine/install/ubuntu。

2.2搭建本地镜像仓库

Docker用Registry来保存用户构建的镜像。Registry分为公共和私有两种。Docker公司运营的公共Registry叫做Docker Hub,用户可在Docker Hub注册账号,分享并保存自己的镜像。Docker公司的公共镜像仓库(https://hub.docker.com)提供了庞大的镜像集合供用户使用。一个Docker Registry中可包含多个仓库,每个仓库可包含多个标签(Tag),每个标签对应一个镜像。通常,一个仓库会包含同一个软件不同版本的镜像,而标签对应该软件的各个版本。用户可通过“[<仓库名>:<标签>]”的格式来指定具体是某个软件某个版本的镜像。如未给出标签,将以[latest]作为默认标签。

本次使用的镜像是registry:2,请执行如下命令自动下载并启动。

Host# mkdir -p /home/tronlong/docker/myregistry

Host# sudo docker run -d -p 5000:5000 -v/home/tronlong/docker/myregistry:/var/lib/registry registry:2

参数说明:

-d:后台启动容器。

-p:将容器的5000端口映射至Ubuntu的5000端口(5000是registry服务端口)。

-v:将容器“/var/lib/registry”目录映射至Ubuntu的“/home/tronlong/docker/myregistry”,用于存放镜像数据。

b0a9258e-5e82-11ec-a27f-dac502259ad0.png

图 10

请执行如下命令,查看容器是否已启动,出现如下内容说明容器已正常启动。

Host# sudo docker ps

b0e79864-5e82-11ec-a27f-dac502259ad0.png

图 11

请通过浏览器访问“http://192.168.0.84:5000/v2/_catalog”,如返回如下内容则说明registry已经成功启动,192.168.0.84为Ubuntu的IP。

b10959d6-5e82-11ec-a27f-dac502259ad0.png

图 12

由于刚建立运行,故里面无任何镜像内容。至此,Docker环境安装完成。


03

构建镜像

请在Ubuntu上新建工作目录“/home/tronlong/docker/dockerfile/”,并将产品资料“4-软件资料\Linux\Filesystem\”目录下的文件系统压缩包rootfs-processor-sdk-04.03.00.05-54428dd3-v2.1-docker.tar.gz和产品资料“4-软件资料\Demo\tl-linux-application\base-demos\tl_led_flash\bin\”目录下的可执行文件拷贝至Ubuntu共享目录下,再执行如下命令拷贝至工作目录。

Host# mkdir /home/tronlong/docker/dockerfile

Host# cp /mnt/hgfs/SharedFolders/tl_led_flash /home/tronlong/docker/dockerfile/

Host# cp /mnt/hgfs/SharedFolders/rootfs-processor-sdk-04.03.00.05-54428dd3-v2.1-docker.tar.gz /home/tronlong/docker/dockerfile/

b1295b5a-5e82-11ec-a27f-dac502259ad0.png

图 13

在工作目录“/home/tronlong/docker/dockerfile/”下,新建Dockerfile文件。

Host# gedit Dockerfile

b17e7b58-5e82-11ec-a27f-dac502259ad0.png

图 14

b1ad61c0-5e82-11ec-a27f-dac502259ad0.png

图 15

Dockerfile文件内容如下:

FROM scratch#基于空的基础镜像构建新的镜像

# Set work directory

WORKDIR /home/root#为CMD、COPY和AND设置工作目录

# Decompress the file system

ADD rootfs-processor-sdk-04.03.00.05-54428dd3-v2.1-docker.tar.gz /#解压文件系统

# Copy file to image

COPY tl_led_flash .#拷贝可执行文件至镜像的"/home/root/"目录下

# Shell command executed when the container is started

# CMD ["executable","param1","param2"]

CMD ["./tl_led_flash", "-n 3"]#容器启动时执行的shell命令,此处为执行LED闪烁程序的命令

在Dockerfile文件所在的目录下执行如下命令,进行构建镜像。

Host# sudo docker build -t192.168.0.84:5000/tl_led_flash:v1.0 .//注意命令最后含有“.”

Host# sudo docker images//查看已构建的镜像


参数说明:

192.168.0.84:Ubuntu的IP地址;

-t:指定镜像的名字及标签(name:tag)。

b1db1d7c-5e82-11ec-a27f-dac502259ad0.png

图 16

请执行如下命令,将镜像推送至本地仓库Registry。

Host# sudo docker push 192.168.0.84:5000/tl_led_flash:v1.0

b231884c-5e82-11ec-a27f-dac502259ad0.png

图 17

Docker版本从1.3.X之后,与Docker Registry交互默认使用https,然而前面搭建的私有仓库仅提供http服务,因此当与私有仓库交互时将出现上面的错误提示。可通过修改“/etc/docker/daemon.json”文件来解决该问题,请执行如下命令,192.168.0.84为Ubuntu的IP。

Host# sudovi/etc/docker/daemon.json

b284a6e4-5e82-11ec-a27f-dac502259ad0.png

图 18

请在daemon.json中添加如下配置内容:

{

"insecure-registries": ["192.168.0.84:5000"]

}

执行如下命令,重新启动Docker、Registry容器(通过指定ID),并重新推送镜像至本地Registry。

Host# sudo /etc/init.d/docker restart

Host# sudo docker ps -a

Host# sudo docker start 4b0a821ec816//以查询得到的ID号为准

Host# sudo docker push 192.168.0.84:5000/tl_led_flash:v1.0

b2b0d728-5e82-11ec-a27f-dac502259ad0.png

图 19

备注:若出现如下错误,可执行"sudo service docker restart"重启Docker。

b2e12630-5e82-11ec-a27f-dac502259ad0.png

图 20

通过浏览器访问“http://192.168.0.84:5000/v2/_catalog”,即可看到当前仓库里已有的镜像。

b33abb46-5e82-11ec-a27f-dac502259ad0.png

图 21


04

下载镜像并运行容器

(1)下载镜像。

请使用网线将评估板网口连接至路由器,并确保和Ubuntu处于同一网络下,评估板上电启动,执行如下命令下载镜像。

Target# docker pull 192.168.0.84:5000/tl_led_flash:v1.0

Target# docker images

b353b74a-5e82-11ec-a27f-dac502259ad0.png

图 22

若出现如下错误,可通过修改“/etc/docker/daemon.json”文件来解决此问题,请执行如下命令。

b3863b20-5e82-11ec-a27f-dac502259ad0.png

图 23

Target# vi /etc/docker/daemon.json

Target# systemctl restart docker.socket//重启Docker服务

b3b262fe-5e82-11ec-a27f-dac502259ad0.png

图24

请在daemon.json中添加如下配置内容:

{

"insecure-registries": ["192.168.0.84:5000"]

}

(2)创建并启动容器。

Target# docker run -d --name tl_led_flash -v /sys/:/sys0a4ece7276bb


参数说明:

-d: 后台运行容器;

--name: 为容器指定一个名称;

-v: 映射卷(将主机的目录"/sys"映射至容器的"/sys");

0a4ece7276bb:镜像ID,以实际"IMAGE ID"为准。

b3e45fc0-5e82-11ec-a27f-dac502259ad0.png

图 25

容器启动完成后,评估底板的3个用户LED灯同时闪烁。

备注:若出现如下错误,需先创建“/etc/resolv.conf”文件,再进行创建容器操作。

b433ed88-5e82-11ec-a27f-dac502259ad0.png

图 26

(3)容器的基本操作

执行如下命令,查看正在运行的容器并进入容器。

Target# dockerps -a

Target# docker exec -it085b59f6c76e/bin/bash


参数说明:

-i:以交互模式运行容器,通常与-t同时使用;

-t:为容器重新分配一个伪输入终端,通常与-i同时使用;

085b59f6c76e:容器ID,以实际“CONTAINER ID”为准;

/bin/bash:在容器内执行“/bin/bash”命令。

b46c4502-5e82-11ec-a27f-dac502259ad0.png

图 27

执行如下命令,退出容器。

Bash# exit

b4995182-5e82-11ec-a27f-dac502259ad0.png

图 28

执行如下命令,停止容器。此时,评估底板的3个用户LED灯不再闪烁。

Target# docker stop 085b59f6c76e

b4c26d56-5e82-11ec-a27f-dac502259ad0.png

图 29

执行如下命令,启动容器。此时,评估底板的3个用户LED灯同时闪烁。

Target# docker start085b59f6c76e

b4fe0c3a-5e82-11ec-a27f-dac502259ad0.png

图 30

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 嵌入式
    +关注

    关注

    5082

    文章

    19104

    浏览量

    304797
  • Linux
    +关注

    关注

    87

    文章

    11292

    浏览量

    209323
  • 硬件开发
    +关注

    关注

    3

    文章

    156

    浏览量

    24165
收藏 人收藏

    评论

    相关推荐

    AM335x和AMIC110 Sitara™处理器技术参考手册

    电子发烧友网站提供《AM335x和AMIC110 Sitara™处理器技术参考手册.pdf》资料免费下载
    发表于 11-14 15:07 0次下载
    <b class='flag-5'>AM335x</b>和AMIC110 Sitara™处理器技术参考手册

    am335x evm板音频播放正常,但是无法录音,怎么解决?

    am335x evm板音频播放正常,但是无法录音。使用amixer各种配置测试都不行。录的音频很小声而且听不清,只有对麦克风吹气才能听到吹气的声音。听不到说话的声音。会不会是硬件问题?参数配置配置需要怎么配置?
    发表于 10-31 06:45

    适用于AM335x TRF7970A的neard(Linux NFC)构建说明

    电子发烧友网站提供《适用于AM335x TRF7970A的neard(Linux NFC)构建说明.pdf》资料免费下载
    发表于 10-26 11:00 0次下载
    适用于<b class='flag-5'>AM335x</b> TRF7970A的neard(Linux NFC)构建说明

    AM335x功耗估算工具

    电子发烧友网站提供《AM335x功耗估算工具.pdf》资料免费下载
    发表于 10-12 11:46 0次下载
    <b class='flag-5'>AM335x</b>功耗估算工具

    PLC应用中的AM335x可靠性注意事项

    电子发烧友网站提供《PLC应用中的AM335x可靠性注意事项.pdf》资料免费下载
    发表于 10-12 11:33 0次下载
    PLC应用中的<b class='flag-5'>AM335x</b>可靠性注意事项

    AM335x硬件设计指南

    电子发烧友网站提供《AM335x硬件设计指南.pdf》资料免费下载
    发表于 09-19 11:05 0次下载
    <b class='flag-5'>AM335x</b>硬件设计指南

    AM335xAM43xx Sitara处理器USB布局指南

    电子发烧友网站提供《AM335xAM43xx Sitara处理器USB布局指南.pdf》资料免费下载
    发表于 09-19 11:05 0次下载
    <b class='flag-5'>AM335x</b>和<b class='flag-5'>AM</b>43xx Sitara处理器USB布局指南

    AM335x原理图核对表

    电子发烧友网站提供《AM335x原理图核对表.pdf》资料免费下载
    发表于 09-19 11:03 0次下载
    <b class='flag-5'>AM335x</b>原理图核对表

    AM335x Sitara™处理器数据表

    电子发烧友网站提供《AM335x Sitara™处理器数据表.pdf》资料免费下载
    发表于 08-08 13:07 0次下载
    <b class='flag-5'>AM335x</b> Sitara™处理器数据表

    ARM平台实现Docker容器技术

    性价比全志T113-i工业核心板在支持Docker后,其性价比还将进一步提升! 图2基于T113-i平台实现Docker容器技术 如下为基于全志T113-i工业
    发表于 07-25 14:36

    ARM平台实现Docker容器技术

    T113-i工业核心板在支持Docker后,其性价比还将进一步提升!图2基于T113-i平台实现Docker容器技术 如下为基于全志T113-i工业
    发表于 07-17 11:05

    GPMC并口多通道AD采集案例,基于TI AM62x四核处理器平台

    GPMC并口简介 GPMC(General Purpose Memory Controller)是TI处理器特有的通用存储器控制器接口,是AM62xAM64xAM437x
    的头像 发表于 07-09 10:58 418次阅读
    GPMC并口多通道AD采集案例,基于<b class='flag-5'>TI</b> <b class='flag-5'>AM62x</b>四核处理器<b class='flag-5'>平台</b>!

    没抢到?米尔AM62x开发板限量5折又来了

    AM62x替代AM335x处理器上次米尔AM62x开发板的5折活动没抢到,今天又来了!!!精彩不容错过,限量30PCSSitara作为TI处理器经典系列,曾推出众多优秀处理器型号(如
    的头像 发表于 05-17 08:01 501次阅读
    没抢到?米尔<b class='flag-5'>AM62x</b>开发板限量5折又来了

    TLT507-Docker容器部署方法说明

    TLT507-Docker容器部署方法说明
    的头像 发表于 01-26 09:49 466次阅读
    TLT507-<b class='flag-5'>Docker</b><b class='flag-5'>容器</b><b class='flag-5'>部署</b>方法说明

    RK3568-Docker容器部署方法说明

    RK3568-Docker容器部署方法说明
    的头像 发表于 01-22 10:12 1368次阅读
    RK3568-<b class='flag-5'>Docker</b><b class='flag-5'>容器</b><b class='flag-5'>部署</b>方法说明