找回密码
 注册
关于网站域名变更的通知
查看: 330|回复: 1
打印 上一主题 下一主题

ARM平台实现Docker容器技术

[复制链接]

该用户从未签到

跳转到指定楼层
1#
 楼主| 发表于 2024-3-7 16:55 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

EDA365欢迎您登录!

您需要 登录 才可以下载或查看,没有帐号?注册

x
本帖最后由 Tronlong123 于 2024-3-7 17:08 编辑 0 e  r4 J+ _& T4 C9 }1 ?+ d

5 [# I) V1 V; ?( {7 P3 O
什么是Docker?
(1)Docker架构
Docker是一个开源的应用容器引擎,让开发者可打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的Linux或Windows机器上,亦可实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。使用Docker,可像管理应用程序一样管理基础结构。通过利用Docker的快速发布、测试和部署代码的方法,可显著减少产品开发时间。
Docker使用客户端——服务器(C/S)体系结构。Docker客户端与Docker守护进程进行通信,后者执行构建、运行和分发Docker容器的繁重工作。Docker客户端和守护进程可在同一个系统上运行,亦可将Docker客户端连接至远程Docker守护进程。Docker客户端和守护进程使用REST API、UNIX套接字或网络接口进行通信。

3 {' j: H7 j7 d: w# U& i
图1

! I9 {: ~' {8 a( C
2Docker的作用
更高效的利用系统资源:Docker对系统资源的利用率更高,无论是应用执行速度,内存损耗或者文件存储速度,都要比传统虚拟机技术更高效。因此,相比虚拟机技术,一个相同配置的主机往往可以运行更多数量的应用。
更快速的启动时间:传统的虚拟机技术启动应用服务往往需要数分钟,而Docker容器应用,由于直接运行于宿主内核,无需启动完整的操作系统,因此可以做到秒级,甚至毫秒级的启动时间,大大的节约了开发测试,部署的时间。
一致的运行环境:开发过程中常见的一个问题是环境一致问题,由于开发环境,测试环境,生产环境不一致,导致有些bug并未在开发过程中发现。而Docker的镜像提供了除内核外完整的运行时环境,确保环境一致性,从而不会在出现“这段代码在我机器上没问题”这类问题。
持续支付和部署:对开发和运维人员来说,最希望就是一次创建和部署,可以在任意的地方运行。(定制应用镜像来实现集成、持续支付、部署。开发人员可以通过dockeRFile来进行镜像构建,并结合持续集成系统进行集成测试,而运维人员则可直接在生产环境中快速部署该镜像,甚至结合持续部署系统进行自动部署)。而且使用dockerfile使镜像构建透明化,不仅仅开发团队可理解应用运行环境,也方便运维团队理解应用运行所需条件,帮助更好的生产环境中部署该镜像。
更轻松的迁移:由于Docker确保了执行环境的一致性,使得应用的迁移更加的容易。Docker可在很多平台上运行,无论是物理机、虚拟机、公有云、私有云、甚至是笔记本、其运行结果是一致的。因此用户可很轻易的将在一个平台上运行的应用,迁移到另一个平台上,而不用担心运行环境的变化导致应用无法正常运行的情况。
更轻松的维护和拓展:Docker使用的分层存储以及镜像的技术,使得应用重复部分的复用更为容易,也使得应用的维护更新更加简单,基于基础镜像进一步扩展镜像也变得十分简单。此外,Docker团队同各个开源项目团队一起维护了一大批高质量的官网镜像,既可直接在生产环境使用,又可作为基础进一步定制,大大的降低了应用服务的镜像制作成本。

) _0 b, [# [0 q5 S% w6 w' \1 o/ {! K
Docker容器技术应用场景
Docker的应用场景十分广泛,涵盖工业网关、储能EMS、通讯管理机、电力RTU、电力录波器、汽车充电桩等领域。而由创龙科技推出的双核Cortex-A7@1.2GHz含税79元超强性价比全志T113-i工业核心板在支持Docker后,其性价比还将进一步提升!
图2

, }9 @: n9 {, j8 r
基于T113-i平台实现Docker容器技术
如下为基于全志T113-i工业平台,演示Docker安装、构建镜像以及下载镜像并运行容器的方法。

" a) R- F) S; z. n+ P
1 Docker安装1.1 安装方法
" @" z$ j# L; H# w" L( \(1)安装依赖包
* r. H7 t) e/ ~  X% y
打开Ubuntu,确保Ubuntu可正常访问互联网,执行如下命令安装Docker依赖包。! w# E, h( a% }  p
Host#sudo apt-get update
0 L& {. z9 |+ u4 L% n* q) {& q
图3

# N( E+ D4 N6 C8 m# q
Host#sudo apt-get install ca-certificates curl gnupg lsb-release
( l% f/ g/ E# Y* {* S
图4
(2)添加Docker官方GPG密钥
Host#sudo mkdir -m 0755 -p /etc/apt/keyrings
Host#curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --deARMor -o /etc/apt/keyrings/docker.gpg
图5
7 C3 x8 f3 y% z& i0 W* A" r1 W- t
(3)设置Docker Stable存储库

. _, ]5 ~4 e3 ~: K3 g
Host#echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
; H7 M7 l  R# E0 n/ r' k3 M7 U
图6
1 q9 n" j1 j+ T. l8 K) x) c
(4)安装Docker8 U3 N7 G4 h9 t  a& m
Host#sudo apt-get updateHost#sudo apt-get install docker-ce docker-ce-cli containerd.io# l: P1 t: E8 \6 r9 ]
图7
& q, c5 m6 Z% I- Q% n* E3 k% s; C+ J
图8
5 r- L+ s, [( E% {3 M: o5 L4 O$ b
(5)验证Docker
执行如下命令,通过运行Docker自带的hello-world镜像来验证是否已安装成功。程序运行后,输出如下内容则表示Docker安装成功。
Host#sudo docker run hello-world
图9
0 @. g5 B" U- X# s& ]
更多参考信息,请查阅官方手册:https://docs.docker.com/engine/install/ubuntu
1.2 搭建本地镜像仓库
1 V" [8 f0 F8 h0 C- m& E
Docker用Registry来保存用户构建的镜像。Registry分为公共和私有两种。Docker公司运营的公共Registry叫做Docker Hub,用户可在Docker Hub注册账号,分享并保存自己的镜像。Docker公司的公共镜像仓库([color=var(--weui-LINK)]https://hub.docker.com)提供了庞大的镜像集合供用户使用。一个Docker Registry中可包含多个仓库,每个仓库可包含多个标签(Tag),每个标签对应一个镜像。通常,一个仓库会包含同一个软件不同版本的镜像,而标签对应该软件的各个版本。用户可通过“[<仓库名>:<标签>]”的格式来指定具体是某个软件某个版本的镜像。如未给出标签,将以[latest]作为默认标签。本次使用的镜像是registry:2,请执行如下命令自动下载并启动。' q+ P+ Y- K6 S) F, P# c6 P% I: x
Host#mkdir -p /home/tronlong/docker/myregistryHost#sudo docker run -d -p 5000:5000 -v /home/tronlong/docker/myregistry:/var/lib/registry registry:2
% F4 T9 o6 A2 B5 d2 w* A! s
参数说明:-d:后台启动容器。-p:将容器的5000端口映射至Ubuntu的5000端口(5000是registry服务端口)。-v:将容器"/var/lib/registry"目录映射至Ubuntu的"/home/tronlong/docker/myregistry",用于存放镜像数据。
- W8 U. X# F3 h2 G, c+ V: a4 {, {
图10

! [* a' H4 f; }$ |
请执行如下命令,查看容器是否已启动,出现如下内容说明容器已正常启动。
/ K1 {. i. @$ u; D  Q' j0 y# R
Host#sudo docker ps
5 b9 X- }# ^7 c
图11
( c4 }. O* v) Z/ e  i
请通过浏览器访问"http://192.168.10.101:5000/v2/_catalog",若返回如下内容则说明registry已经成功启动,192.168.10.101为Ubuntu的IP。

  e$ u; C& P: O: F1 U0 x& l) s5 E

3 n% n2 [4 ]0 v  V
图12
因为Docker刚建立运行,所以里面无任何镜像内容。至此,Docker环境安装完成。
2 构建镜像

9 V5 o# i1 l$ X0 \2 C- `
请在Ubuntu上新建工作目录"/home/tronlong/docker/dockerfile/",并将产品资料“4-软件资料\Linux\Filesystem\docker\”目录下的文件系统压缩包和产品资料“4-软件资料\Demo\base-demos\led_flash\bin\”目录下的可执行文件拷贝至Ubuntu共享目录下,再执行如下命令拷贝至Docker工作目录。
Host#mkdir /home/tronlong/docker/dockerfile
Host#cp /mnt/hgfs/SharedFolders/led_flash /home/tronlong/docker/dockerfile/
Host#cp /mnt/hgfs/SharedFolders/rootfs.tar /home/tronlong/docker/dockerfile/

0 J2 P! ?8 ]+ M1 D
图13

1 i! y' K! D7 x# z2 b' `
在"/home/tronlong/docker/dockerfile/"目录下,创建Dockerfile文件,并编写如下内容。
Host#cd /home/tronlong/docker/dockerfile
Host#gedit Dockerfile
图14

0 w+ n: Y0 M3 N. E! T5 X  j. b1 K
图15
Dockerfile文件内容如下:
FROM scratch #基于空的基础镜像构建新的镜像
# Set work directory
WORKDIR /root #为CMD、COPY和AND设置工作目录
# Decompress the file system
ADD rootfs.tar / #解压文件系统
# Copy file to image
COPY led_flash . #拷贝可执行文件至镜像的"/home/root/"目录下
# Shell command executed when the container is started
# CMD ["executable","param1","param2"]
CMD ["./led_flash", "-n 1"] #容器启动时执行的shell命令,此处为执行LED闪烁程序的命令
在Dockerfile文件所在的目录下执行如下命令,进行构建镜像。
/ h; J! O" Q! @; [
Host#sudo docker build -t 192.168.10.101:5000/led_flash:v1.0 .//注意命令最后含有"."
Host#sudo docker images //查看已构建的镜像
参数说明:
192.168.10.101:Ubuntu的IP地址;
-t:指定镜像的名字及标签(name:tag)。

: Q, p1 ]* E7 Z0 F+ j, |5 L
图16

6 y* Z% d8 _' v- x$ C
请执行如下命令,将镜像推送至本地仓库Registry。
Host#sudo docker push 192.168.10.101:5000/led_flash:v1.0
图17
Docker版本从1.3.X之后,与Docker Registry交互默认使用https,然而前面搭建的私有仓库仅提供http服务,因此当与私有仓库交互时将出现上面的错误提示。可通过修改"/etc/docker/daemon.json"文件来解决该问题,请执行如下命令,192.168.10.101为Ubuntu的IP。
Host#sudovi /etc/docker/daemon.json
图18

0 f* K6 k6 Q* k7 n: ~8 e
请在daemon.json中添加如下配置内容:{"insecure-registries": ["192.168.10.101:5000"]}执行如下命令,重新启动Docker、Registry容器(通过指定ID),并重新推送镜像至本地Registry。
2 s* {; L0 ?3 G: r- D3 L
Host#sudo /etc/init.d/docker restartHost#sudo docker ps -aHost#sudo docker start 0833de1304d9//以查询得到的CONTAINER ID号为准Host#sudo docker push 192.168.10.101:5000/led_flash:v1.0
& a6 E' O3 ]2 W; F' ~! ]
图19
1 x% J  P# p/ {1 {) W
通过浏览器访问"http://192.168.10.101:5000/v2/_catalog",即可看到当前仓库里已有的镜像。

' {' K: K% ?7 f5 |- d
图20

& C) d7 s" m( H' }  ~& e# r
3 下载镜像并运行容器
(1)请使用网线将创龙科技T113-i评估板ETH0(RGMII)网口连接至路由器,并确保和Ubuntu处于同一网络下,评估板上电启动,执行如下命令下载镜像并列举出下载后的镜像。下载镜像过程中将会打印警告和错误信息,不影响功能正常使用,请忽略。
Target#docker pull 192.168.10.101:5000/led_flash:v1.0 //下载镜像
Target#docker images //列举已下载的镜像
) v, s9 s. b+ ?/ l6 r
图21

. J) @) {, c# b4 {3 a# g
若出现如下错误,请执行如下命令,通过修改"/etc/docker/daemon.json"文件来解决此问题,修改保存后,重新启动dockerd守护进程。
% _4 D' v; i) l5 M4 h( ^
图22
Target#vi /etc/docker/daemon.json
1 N' j2 c& Q  x5 ~" Q
图23
) N9 R+ Z' K, H/ ^5 f. Q
请在daemon.json中添加如下配置内容:{"insecure-registries": ["192.168.10.101:5000"]}Target#/etc/init.d/S60dockerd restart
$ a4 B9 w  ~: N, v" G; I

# `. v* z4 W- P. t4 w$ Q" y" g
图24

2 b5 t+ T+ M/ W# A
(2)创建并启动容器。由于Docker使用VFS存储驱动程序,当创建容器时,需要先创建容器层,该容器层需要对上一层进行“深拷贝”,因此完成创建并启动容器整个过程需要耗时约1min,请耐心等待。
5 N9 m5 i6 N5 G8 @
Target#docker run -d --name led_flash -v /sys/:/sys 2d17af57ec7e
8 v; Z) G! e6 ~6 E2 q
参数说明:-d:后台运行容器;--name:为容器指定一个名称;-v:映射卷(将主机的目录"/sys"映射至容器的"/sys");2d17af57ec7e:镜像ID,以docker images命令列举的"IMAGE ID"为准。: X( N% s; W- C; T6 W# O# G
图25
容器启动完成后,评估底板的用户可编程指示灯闪烁。
(3)容器的基本操作
执行如下命令,查看正在运行的容器并进入容器。
Target#docker ps -a
Target#docker exec -it 2d7c23bd13c0 /bin/bash
参数说明:
-i:以交互模式运行容器,通常与-t同时使用;
-t:为容器重新分配一个伪输入终端,通常与-i同时使用;
2d7c23bd13c0:容器ID,以实际"CONTAINER ID"为准;
/bin/bash:在容器内执行"/bin/bash"命令。
图26
执行如下命令,退出容器。
Bash#exit

3 N9 H0 T9 F* W6 H
图27
% Y& a& n  i: Y8 d: h* ?
执行如下命令,停止容器。此时,评估底板的用户可编程指示灯不再闪烁。
Target#docker stop 2d7c23bd13c0
# x, m* ?; B% i& X
]
图28

# v( Z+ K: R2 h1 n6 N0 P; C) d2 p
执行如下命令,启动容器。此时,评估底板的用户可编程指示灯闪烁。
Target#docker start 2d7c23bd13c0
图29

4 H* ?2 ^5 V$ t! G
备注:若运行Docker时,出现"x509: certificate signed by unknown authority"类似警告信息(如下图),可通过修改/etc/docker/daemon.json文件解决。该警告是由于本机没有远程仓库的证书文件导致。
图30
修改内容:
{
"registry-mirrors": ["https://registry-1.docker.io"],
"insecure-registries": ["https://registry-1.docker.io"]
}
- c5 R: Z8 {! f9 W5 L, p- {
图31
% H; N  L* \  j: e$ S
修改完成后,重新运行Docker。

% E5 A# F- h) r: A& o5 F! J4 ]
( Q- @) n) B" w# U) D8 e

9 [9 O! P6 i. {* `" \# b

该用户从未签到

2#
发表于 2024-3-7 18:01 | 只看该作者
用什么开发板?
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

EDA365公众号

关于我们|手机版|EDA365电子论坛网 ( 粤ICP备18020198号-1 )

GMT+8, 2025-9-10 21:21 , Processed in 0.156250 second(s), 26 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表