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

【经验分享】Docker容器部署方法说明

[复制链接]

该用户从未签到

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

EDA365欢迎您登录!

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

x
                          $ T& z, z  F$ L( v! F; M
前 言
* y" E# ?4 |% O. k 本案例适用开发环境:
" P; R$ p0 N9 J5 f5 M/ M4 [8 ~( h Windows开发环境:Windows 7 64bit、Windows 10 64bit- B6 X+ c& _( ^' M) C
Linux开发环境:Ubuntu 18.04.4 64bit
- w) i+ }( `) H3 W6 k 虚拟机:VMware15.1.0
4 j, L8 c9 W5 i4 `* H Docker是一个开源的应用容器引擎,让开发者可打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的Linux或Windows机器上,亦可实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。使用Docker,可像管理应用程序一样管理基础结构。通过利用Docker的快速发布、测试和部署代码的方法,可显著减少产品开发时间。7 J9 j$ @/ J' ?; o1 s0 O2 ^. H
   
图1
( r+ q9 U2 f0 A: O+ ^3 s  ]& R
1 Docker架构 Docker使用客户端——服务器(C/S)体系结构。Docker客户端与Docker守护进程进行通信,后者执行构建、运行和分发Docker容器的繁重工作。Docker客户端和守护进程可在同一个系统上运行,亦可将Docker客户端连接至远程Docker守护进程。Docker客户端和守护进程使用REST API、UNIX套接字或网络接口进行通信。
; v5 }: F# Y3 f" x+ @* ?) m  安装方法; F$ R3 ^" [: E- C, [3 C$ C
(1) 安装依赖包- N2 ^+ U2 j  T9 Y8 E1 B  Y
打开Ubuntu,确保Ubuntu可正常访问互联网,执行如下命令进行安装Docker依赖包。5 D7 J- {. _( y
Host# sudo apt-get update2 ]: q6 l# m/ e% o& z

" G4 j6 q; F4 A2 _" Q$ @

& m. {. u3 r6 c4 |3 b   
* Y- T9 }! D) h
图 2
2 [+ t" o( @' P" `
Host# sudo apt-get install apt-transport-https ca-certificates curl gnupg lsb-release
) ?" J8 j' ~( `: r6 d, P
" R* c% l& d0 Z4 U7 [

) n2 }5 i6 G6 D" K% u  
* _8 F: K( D6 y/ P% T
图 3
" s1 R4 v) ^5 w! K6 i: s4 ]! R
(2) 添加Docker官方GPG密钥
, D* |$ X- J7 x" g9 ^ Host# curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --deARMor -o /usr/share/keyrings/docker-archive-keyring.gpg  w4 I, E+ x& S% S2 K4 L3 b# F
' x+ T3 B7 W! S3 U
5 D* N  O* |, s) q5 n4 }
  

5 z/ S2 D+ J8 ^
图 4

0 R) Q7 O* z( k' `. L
(3) 设置Docker Stable存储库
; Y- O* \5 f6 D: J/ K 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) P2 p4 u$ I! B+ y  t- n
6 L7 t- B2 _+ x
( B0 L# S! l/ X( L5 v. P% ~
  

' ^8 ], e% |4 n, Z& y  r
图 5

8 z  T1 k! h& J: j+ H
(4) 安装Docker
$ b# v3 @( x) B/ [! ]7 i+ ~, K' L Host# sudo apt-get update
$ D$ o* f. ?' x5 U/ n/ ~5 X Host# sudo apt-get install docker-ce
- e" r* S; ~6 V/ E) A+ S: j4 l/ D& k/ ?5 D, n  [/ V
: B4 {1 Y; L2 f/ j$ S0 S
  

6 A' ~5 h& g* V
图 6

& |9 \9 U( d2 H: X& m

: _3 p: N* H  x- i
图 7
! u* k2 V4 K/ \& [
(5) 验证Docker. {* Y8 e) o6 t7 y9 j6 h8 r
执行如下命令,通过运行Docker自带的hello-world镜像来验证是否已安装成功。程序运行后,输出如下内容则表示Docker安装成功。
" P& p- B& Z, s$ @, d# ^+ e  ^ Host# sudo docker run hello-world' M/ v, t  g  i, ^

) ~1 i$ b# R7 x
7 V4 @( k3 w3 C9 {
  

! i! ~* D8 X% W0 I+ U3 l% `9 o
图 8

4 B6 q0 N# e% M/ Z# i  C5 x
2搭建本地镜像仓库
( I7 Q  E7 p# A0 n3 |1 ~8 _ Docker用Registry来保存用户构建的镜像。Registry分为公共和私有两种。Docker公司运营的公共Registry叫做Docker Hub,用户可在Docker Hub注册账号,分享并保存自己的镜像。Docker公司的公共镜像仓库提供了庞大的镜像集合供用户使用。一个Docker Registry中可包含多个仓库,每个仓库可包含多个标签(Tag),每个标签对应一个镜像。通常,一个仓库会包含同一个软件不同版本的镜像,而标签对应该软件的各个版本。用户可通过“[<仓库名>:<标签>]”的格式来指定具体是某个软件某个版本的镜像。如未给出标签,将以[latest]作为默认标签。9 {3 ^+ I$ W; v4 p3 K( Z0 I
本次使用的镜像是registry:2,请执行如下命令自动下载并启动。
1 z3 T, [5 I) R. r4 v' N Host# mkdir -p /home/tronlong/docker/myregistry
( U$ p7 n3 F' [+ G  `! V  Q" t Host# sudo docker run -d -p 5000:5000 -v /home/tronlong/docker/myregistry:/var/lib/registry registry:2
8 l% C0 ?+ I8 w- h7 c1 I 参数说明:/ o& F) r9 f% `) Y- R' i4 d5 @6 I
-d:后台启动容器。
/ }+ h* R7 U5 [% v0 N, n* P7 k, S -p:将容器的5000端口映射至Ubuntu的5000端口(5000是registry服务端口)。
3 C8 L, C3 G+ A* V -v:将容器"/var/lib/registry"目录映射至Ubuntu的"/home/tronlong/docker/myregistry",用于存放镜像数据。
3 ^' m( P8 |+ L) i! n5 s4 `
$ \$ M8 ]! y$ c9 V. @) \, i9 j

7 J# i3 g$ W4 S* p8 f  

& `" p  U, |7 F9 i1 n" W7 k
图 9

. J8 O1 T7 B! r. r3 g, p0 t4 x! u
请执行如下命令,查看容器是否已启动,出现如下内容说明容器已正常启动。9 l" D* |8 k- J% q, z! h7 ?
Host# sudo docker ps3 w7 G. m( d: @

  y$ K5 O" z. e2 I
2 U2 X  G5 p7 W6 O5 v7 e% P
  

  e. d4 C" y5 R2 ^4 S
图 10
# Z0 p, s5 f: p  ~: n! L
请通过浏览器访问"http://192.168.0.40:5000/v2/_catalog",如返回如下内容则说明registry已经成功启动,192.168.0.40为Ubuntu的IP。
5 H0 Z0 w# @9 f$ t
9 w( M& U7 h1 v; v
2 Y; ]* X/ u& W* N: F, L1 c! o1 X
  
/ s( [& K5 Y  r% c" D
图11

9 N3 `( ]6 U8 J/ O6 F' C
由于刚建立运行,故里面无任何镜像内容。至此,Docker环境安装完成。! {+ L& g3 Y4 _) _- ~
% F6 `, x# \) T. U' z. R" ?

* ]& f, d& w( L* X8 t 3 构建镜像 请在Ubuntu上新建工作目录"/home/tronlong/docker/dockeRFile/",并将产品资料“4-软件资料\Linux\Filesystem\docker\”目录下的文件系统压缩包和产品资料“4-软件资料\Demo\base-demos\led_flash\bin\”目录下的可执行文件拷贝至Ubuntu共享目录下,再执行如下命令拷贝至Docker工作目录。
! K/ F! j& Z: M4 B+ f+ t/ i. f9 H Host# mkdir /home/tronlong/docker/dockerfile
/ e" ]0 Y5 l+ y Host# cp /mnt/hgfs/SharedFolders/led_flash /home/tronlong/docker/dockerfile/
6 C$ c; ^3 ?; }; v$ ~% w$ H3 b5 Y; R Host# cp /mnt/hgfs/SharedFolders/rootfs-v1.2-gcbfe5f3.tar.gz /home/tronlong/docker/dockerfile/
/ D/ q2 ~7 i( V- o
5 X2 V% T+ k3 g1 L9 N4 z

! |; B% o' l" }$ i/ L3 i  

9 r) ]6 O7 Z4 a& _8 b) E( t+ z6 _% `
图 12

$ b5 D* X$ _" u, w+ }: s0 v
在"/home/tronlong/docker/dockerfile/"目录下,创建Dockerfile文件,并编写如下内容。2 C3 W! y: P, i5 d
Host# cd /home/tronlong/docker/dockerfile7 \4 x  m, J1 ~' W. F  x
Host# gedit Dockerfile
& x( i6 n  L2 j
2 L' x! X( J2 _. [

& y" k. x/ f( E5 c% o  

8 ?0 O& J2 I% g# q. W+ u% H
图 13

' d& t; y" U& N/ b9 `

( S7 ]& a: `+ c; K9 t
图 14
! t. _9 k6 r9 ]! C
Dockerfile文件内容如下:
4 Z' n( K" T! y9 C" N' u+ _: Q FROM scratch #基于空的基础镜像构建新的镜像  B: R% q: n% u2 Q& x  ]' W
# Set work directory
' O& z, {) E7 C- n- m3 B WORKDIR /root #为CMD、COPY和AND设置工作目录; B4 H9 \4 q3 S0 q
# Decompress the file system
+ M; L2 L2 L% [ ADD rootfs-v1.2-gcbfe5f3.tar.gz / #解压文件系统
+ M8 x6 f& D0 d6 {! X* O9 p% z2 | # Copy file to image  Q. ^9 w! J* R: g9 h2 T( a# ^$ l
COPY led_flash . #拷贝可执行文件至镜像的"/home/root/"目录下
+ M& z2 |. Z, N; i. U" l$ Y # Shell command executed when the container is started. d( U4 w. |* t3 ~7 X! [
# CMD ["executable","param1","param2"]
, N5 ^" g' G- R CMD ["./led_flash", "-n 2"] #容器启动时执行的shell命令,此处为执行LED闪烁程序的命令
* i) G$ Y) A5 Q7 `+ k) j 在Dockerfile文件所在的目录下执行如下命令,进行构建镜像。
7 B" i, @/ y, I! j6 u6 z Host# sudo docker build -t 192.168.0.40:5000/led_flash:v1.0 . //注意命令最后含有"."
7 u( K" R+ C& \ Host# sudo docker images //查看已构建的镜像8 W: \- c( w* p
参数说明:4 ]0 f9 ?; _: y& L: M
192.168.0.40:Ubuntu的IP地址;
6 |! P  I0 H, s5 T -t:指定镜像的名字及标签(name:tag)。
, K  S) r+ q& `& W8 ]3 H" s0 n/ |4 _/ A

( f: w. k7 \" S/ t" P/ C; t

' L9 b# O7 g" W
图 15

/ ]+ k0 y2 i" y5 ]7 t5 q
请执行如下命令,将镜像推送至本地仓库Registry。
- V# d! e  I! K6 ^! P% g Host# sudo docker push 192.168.0.40:5000/led_flash:v1.09 w8 a4 `5 ^7 a6 j

+ f1 d+ z7 Z! F. W3 N7 m% z  s
  l& Y/ P5 d, y" _2 ^1 T
  
2 Y; m" ?  Y- y# n9 Y! @  w
图 16

: K" U" C! e, p/ _3 d7 \- l
Docker版本从1.3.X之后,与Docker Registry交互默认使用https,然而前面搭建的私有仓库仅提供http服务,因此当与私有仓库交互时将出现上面的错误提示。可通过修改"/etc/docker/daemon.json"文件来解决该问题,请执行如下命令,192.168.0.40为Ubuntu的IP。3 w* c0 T2 m; O6 d' q* c) @+ m
Host# sudovi /etc/docker/daemon.json7 M/ I* O: o6 ~2 L* [; j0 V

& j2 l0 y. j4 l6 W

, \- X5 e2 k4 N  

4 F0 X# z" S7 \7 l) `5 a; x/ U! ?$ V
图 17

% x% E) f. w* g% S& A8 F, x
请在daemon.json中添加如下配置内容:/ W" F, J5 p. r$ k* p# ]3 `' m
{ "insecure-registries": ["192.168.0.40:5000"]}:9 ?9 t! Z: C" {7 Z3 q4 E
执行如下命令,重新启动Docker、Registry容器(通过指定ID),并重新推送镜像至本地Registry。  [( g0 \; C- \2 C; {, [$ B, Z' L' U
Host# sudo /etc/init.d/docker restart
' ^4 P3 `8 ~9 i/ F Host# sudo docker ps -a* g7 Y% e  C( p3 f) ^
Host# sudo docker start b898d3391bb9 //以查询得到的CONTAINER ID为准
+ l2 p- ~/ q" U( |/ ~( ` Host# sudo docker push 192.168.0.40:5000/led_flash:v1.0
8 r( \% v$ N4 |- `4 X* }, P6 c' R5 Q* |

: V" l  s$ J: O$ Z! o' Z) j  
1 p2 x# o! p( C5 o# h( x+ K: p: ]
图 18
( `' o$ A! \* R) `5 l; U( B% ]" @
通过浏览器访问"http://192.168.0.40:5000/v2/_catalog",即可看到当前仓库里已有的镜像。
+ v) ]$ [% e) B3 T5 C3 T0 @4 R! f9 M  }2 B$ S& z

" p' M: O. t0 n: n  
9 }' R3 O& o/ g0 n3 t' S# d
图 19
. K! B% r) T+ C
4 下载镜像并运行容器 (1) 请使用网线将评估板RGMII ETH网口连接至路由器,并确保和Ubuntu处于同一网络下,评估板上电启动,执行如下命令启动dockerd守护进程。执行命令后,将会打印警告信息,不影响功能正常使用,请忽略。, L5 g2 ~% N- l; n
Target# dockerd --storage-driver=vfs &
/ {' T. J; g/ p# E. }
% z7 B% d' P: G) \. g: c, z

9 D# G0 L# m3 R% u0 F+ @  i5 N- i  

1 f; j3 q6 H9 r. s0 w, i
图 20
) b7 i& G. _' G, A* @4 d
(2) 执行如下命令下载镜像并列举出下载后的镜像。下载镜像过程中将会打印警告和错误信息,不影响功能正常使用,请忽略。
' [! D# t$ D6 w5 ] Target# docker pull 192.168.0.40:5000/led_flash:v1.0 //下载镜像
. k  w, e9 n2 P4 C: c0 a6 T( { Target# docker images //列举已下载的镜像+ b. ?3 s. ~1 n' U# r: a, i7 ]

% l* \3 B$ c9 ]8 f, B. R, y( `

( \. j  C  q& J- I  
0 U& Q! g+ F$ n* X
图 21
+ p( ?4 `2 y; k. v  ]
若出现如下错误,请执行如下命令,通过修改"/etc/docker/daemon.json"文件来解决此问题,修改保存后,重新启动dockerd守护进程。! M( k+ G. D, {1 W

/ \) {  N0 y. V/ X
: e( h- m6 S6 p5 X
  
/ a/ j9 A- y9 O6 U3 y) ^
图 22
8 ^$ r6 c' }. B0 x1 t
Target# vi /etc/docker/daemon.json) ]1 L; f6 {& b" n% j% b! }' B
) h5 }' b' C7 y0 E3 q" l, I
) A. d  X) `1 L
  
2 I# w8 m! N# ^' p! E! U$ ], i
图 23

8 y" e7 M1 d9 q  N* |
请在daemon.json中添加如下配置内容:5 J8 u  c) N% D2 q9 B- O% L" \
{ "insecure-registries": ["192.168.0.40:5000"]}3 L! n# R! y# T: a  R# K0 G2 T# _
Target# killall -9 dockerd //终止进程
+ K/ R. ~9 w: W: u/ r# b Target# dockerd --storage-driver=vfs & //重启dockerd守护进程
5 O0 z3 y7 ]; [: S" T) c8 [2 ~' s6 w7 I" i

+ G) t8 b$ @. E( h, C  e- n  

3 y" n( A! J$ {8 g! \
图 24
6 e$ G( R, g% V
(3) 创建并启动容器。由于Docker使用VFS存储驱动程序,当创建容器时,需要先创建容器层,该容器层需要对上一层进行“深拷贝”,因此完成创建并启动容器整个过程需要耗时约1min,请耐心等待。8 d7 n5 _3 m% W: U
Target# docker run -d --name led_flash -v /sys/:/sys 97c8b410ef97
& r- I6 A; E: I9 Y6 U! T/ O) a- K, f# T7 l 参数说明:* l, e9 z; M# e; I
-d:后台运行容器;8 t9 O* Z8 e# Y1 t  \& R
--name:为容器指定一个名称;
" P' p4 M3 U; c$ D1 k! m9 L -v:映射卷(将主机的目录"/sys"映射至容器的"/sys");
5 `( x8 ?7 z/ x$ W  f2 u  m 97c8b410ef97:镜像ID,以docker images命令列举的"IMAGE ID"为准。2 t8 e% Y$ ~$ L6 H% @& V5 D& H: x

5 e- R  A2 a; {5 F

4 V; N0 N4 O8 `! X7 i0 p1 d  r: ~  

2 I, a. Q2 o' [8 @. S& v0 h) X8 a
图 25
. s; y/ @6 P9 g) M% Y0 G
容器启动完成后,评估底板的2个用户LED灯同时闪烁。
0 @9 E6 X3 [" A! ]8 d; \7 K1 b$ P) N (4) 容器的基本操作4 H6 R7 j: A* `( ^! A0 N
执行如下命令,查看正在运行的容器并进入容器。
6 I1 |  W0 A" f. v' S+ G9 q Target# docker ps -a& ?  V4 R% R. b+ K+ v
Target# docker exec -it d5e56fbbd1a8 /bin/bash2 B5 o* J2 f3 X$ V3 j
参数说明:
( H5 F9 |+ S9 Q; _# d" s+ m( @ -i:以交互模式运行容器,通常与-t同时使用;
0 q( S& O. `& X# x; O9 J -t:为容器重新分配一个伪输入终端,通常与-i同时使用;
9 D- r2 m& p, G& C! ?, R d5e56fbbd1a8:容器ID,以实际"CONTAINER ID"为准;
4 g/ y8 s) ]. k1 [& ?( n1 M: ]& q /bin/bash:在容器内执行"/bin/bash"命令。* [, R/ k' G4 B5 Q1 a; b
1 M! l  M/ F" Q9 V. K; j

, h. E/ a) v" k5 W  

0 K& A( k$ e, @. D* p& M$ s
图 26
' N, p* P7 K! p( y9 g" K5 T5 e
执行如下命令,退出容器。
2 [9 x! T% j, e, n8 a Bash# exit
! |  i& e2 R7 K
6 n2 |6 ?* L0 A
! U$ r9 I7 O3 J! v/ n
  

7 J9 C1 |6 ?, |! E* S5 }8 t
图 27
2 O- S4 P6 P3 N/ l! o9 V' k
执行如下命令,停止容器。此时,评估底板的2个用户LED灯不再闪烁。' G" l, @2 m# N; u" I, z
Target# docker stop d5e56fbbd1a8
: x  i8 M0 |3 C1 r- @7 C
* I1 i0 ~$ o9 _( Q: K6 e6 t

$ f# L5 }' `1 c- |. |  

3 o: D' o: X1 l  a6 w
图 28
8 A$ F: k( V1 E/ ?
执行如下命令,启动容器。此时,评估底板的2个用户LED灯同时闪烁。
& G+ L' x: f) q: {0 U- }0 x Target# docker start d5e56fbbd1a8
% l+ M8 g3 E) X, r" O
+ G2 i2 @: R4 i# t4 I9 a0 M

: P. w. `& Y. J8 X! W$ x  
# `% N% I2 w+ a5 ~1 ^9 b
图 29

: a# d" y2 `, |# D
备注:若运行Docker时,出现"x509: certificate has expired or is not yet valid"类似警告信息(如下图),请执行date命令同步系统时间即可。该警告信息是由于评估板系统时间与实际时间不同步导致。5 z* N& d9 T$ |
: L$ d# z* n6 e9 e8 `
. @$ D# Z$ c9 ^4 Y+ I6 f' m% l
  
% [% w% S9 \4 S0 Q8 _; y
图 30
) @- u. ?( |7 ]  E" Y. x  b: H
如果你还想了解更多嵌入式应用的相关知识,欢迎关注Tronlong创龙科技~
: \7 z3 t8 D3 o! G' ^+ V
8 ]* @* A: Q7 O6 R$ Q1 t; v

该用户从未签到

2#
发表于 2024-7-24 18:17 | 只看该作者
有开发板吗

点评

有的,您有想了解的方面可以随时到我们微信公众号或官网咨询专业客服  详情 回复 发表于 2024-7-25 09:30

该用户从未签到

3#
 楼主| 发表于 2024-7-25 09:30 | 只看该作者
Getaway 发表于 2024-7-24 18:17
& K7 }' Z* `1 H( _4 l1 A有开发板吗
; H" c/ p9 K  Z& c6 O2 w
有的,您有想了解的方面可以随时到我们微信公众号或官网咨询专业客服
3 i) u! h' T' a6 I* K
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

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

EDA365公众号

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

GMT+8, 2025-11-23 13:15 , Processed in 0.187500 second(s), 26 queries , Gzip On.

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

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

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