百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

Docker容器基于国产平台T3的入门部署方法说明——(3)构建镜像

nanshan 2024-12-28 14:31 22 浏览 0 评论

本次主要是基于100%国产方案的全志T3/A40i平台为您讲解Docker的安装及运行测试

创龙科技TLT3-EVM是一款基于全志科技T3处理器设计的4核ARM Cortex-A7高性能低功耗国产评估板,每核主频高达1.2GHz,由核心板和评估底板组成,评估板接口资源丰富。

构建镜像

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

Host# mkdir /home/tronlong/docker/dockerfile

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

Host# cp /mnt/hgfs/SharedFolders/rootfs-v1.2-gcbfe5f3.tar.gz /home/tronlong/docker/dockerfile/

图 12

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

Host# cd /home/tronlong/docker/dockerfile

Host# gedit Dockerfile

图 13

图 14

Dockerfile文件内容如下:

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

# Set work directory

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

# Decompress the file system

ADD rootfs-v1.2-gcbfe5f3.tar.gz / #解压文件系统

# 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 2"] #容器启动时执行的shell命令,此处为执行LED闪烁程序的命令

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

Host# sudo docker build -t 192.168.0.40:5000/led_flash:v1.0 . //注意命令最后含有"."

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

参数说明:

192.168.0.40:Ubuntu的IP地址;

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

图 15

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

Host# sudo docker push 192.168.0.40:5000/led_flash:v1.0

图 16

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

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

图 17

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

{

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

}:

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

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

Host# sudo docker ps -a

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

Host# sudo docker push 192.168.0.40:5000/led_flash:v1.0

图 18

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

图 19

下载镜像并运行容器

  1. 请使用网线将评估板RGMII ETH网口连接至路由器,并确保和Ubuntu处于同一网络下,评估板上电启动,执行如下命令启动dockerd守护进程。执行命令后,将会打印警告信息,不影响功能正常使用,请忽略。

Target# dockerd --storage-driver=vfs &

图 20

  1. 执行如下命令下载镜像并列举出下载后的镜像。下载镜像过程中将会打印警告和错误信息,不影响功能正常使用,请忽略。

Target# docker pull 192.168.0.40:5000/led_flash:v1.0 //下载镜像

Target# docker images //列举已下载的镜像

图 21

若出现如下错误,请执行如下命令,通过修改"/etc/docker/daemon.json"文件来解决此问题,修改保存后,重新启动dockerd守护进程。

图 22

Target# vi /etc/docker/daemon.json

图 23

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

{

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

}

Target# killall -9 dockerd //终止进程

Target# dockerd --storage-driver=vfs & //重启dockerd守护进程

图 24

  1. 创建并启动容器。由于Docker使用VFS存储驱动程序,当创建容器时,需要先创建容器层,该容器层需要对上一层进行“深拷贝”,因此完成创建并启动容器整个过程需要耗时约1min,请耐心等待。

Target# docker run -d --name led_flash -v /sys/:/sys 97c8b410ef97

参数说明:

-d:后台运行容器;

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

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

97c8b410ef97:镜像ID,以docker images命令列举的"IMAGE ID"为准。

图 25

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

  1. 容器的基本操作

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

Target# docker ps -a

Target# docker exec -it d5e56fbbd1a8 /bin/bash

参数说明:

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

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

d5e56fbbd1a8:容器ID,以实际"CONTAINER ID"为准;

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

图 26

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

Bash# exit

图 27

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

Target# docker stop d5e56fbbd1a8

图 28

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

Target# docker start d5e56fbbd1a8

图 29

备注:若运行Docker时,出现"x509: certificate has expired or is not yet valid"类似警告信息(如下图),请执行date命令同步系统时间即可。该警告信息是由于评估板系统时间与实际时间不同步导致。

图 30

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: