docker容器部署-凯发app

    凯发app-凯发天生赢家 >关于创龙 > 新闻资讯 > 技术文章

    联系凯发app

    contact us

    公司总机:020-8998-6280

    技术热线:020-3893-9437

    技术邮箱:support@tronlong.com

    销售邮箱:sales@tronlong.com

    docker容器部署-以ti am335x平台为例

    2021/12/20

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

    docker容器适用于ti am335x、am437x、am570x、am5728等平台,本文基于ti am3352/54/59平台为您讲解docker的安装及运行测试。


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



    图 1

    产品资料(用户手册、核心板硬件资料、产品规格书)

    请点击链接或扫描长按识别下方二维码获取:





    1、docker架构

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





    图 2


    更多详情请可参考docker凯发app官网链接:


    2、docker安装

    2.1 安装方法

    (1) 安装依赖包

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

    host#  sudo apt-get update




    图 3


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


    图 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


     图 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






    图 6



    (4) 安装docker

    host#  sudo apt-get update

    host#  sudo apt-get install docker-ce



     图 7



    图 8

    (5) 验证docker

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

    host#  sudo docker run hello-world


    图 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”,用于存放镜像数据。

     图 10



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

    host#  sudo docker ps


    图 11


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


    图 12


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


    3、构建镜像

    请在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/

    图 13



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

    host#  gedit dockerfile


    图 14



    图 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 -t 192.168.0.84:5000/tl_led_flash:v1.0 .//注意命令最后含有“.”

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

    参数说明:

    192.168.0.84:ubuntu的ip地址;

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


    图 16


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

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


    图 17


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

    host#  sudo vi /etc/docker/daemon.json


    图 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

     图 19



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


    图 20


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


    图 21


    4、下载镜像并运行容器

    (1) 下载镜像。

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

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

    target#  docker images


     图 22

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


    图 23


    target#  vi /etc/docker/daemon.json

    target#  systemctl restart docker.socket//重启docker服务



    图 24


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

    {

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

    }

    (2) 创建并启动容器。

    target#  docker run -d --name tl_led_flash -v /sys/:/sys 0a4ece7276bb

    参数说明:

    -d: 后台运行容器;

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

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

    0a4ece7276bb:镜像id,以实际"image id"为准。

     

    图 25


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

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


    图 26


    (3) 容器的基本操作

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

    target#  docker ps -a

    target#  docker exec -it 085b59f6c76e /bin/bash

    参数说明:

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

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

    085b59f6c76e:容器id,以实际“container id”为准;

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


     图 27


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

    bash#  exit

    图 28



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

    target#   docker stop 085b59f6c76e

     

    图 29


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

    target#  docker start 085b59f6c76e


     图 30



    联系创龙

    公司总机:020-8998-6280

    技术热线:020-3893-9734

    技术邮箱:support@tronlong.com

    销售邮箱:sales@tronlong.com



    创龙官方微信公众号

    凯发app copyright © 2013~2021 广州创龙电子科技有限公司 all rights reserved  |

    网站地图