Linux下 Docker容器引擎基础(1)

简述:

Docker的容器技术可以在一台主机上轻松为任何应用创建一个轻量级的、可移植的、自给自足的容器。通过这种容器打包应用程序,意味着简化了重新部署、调试这些琐碎的重复工作,极大的提高了工作效率。例如:项目从腾讯云迁移阿里云,如果采用了Docker容器技术,迁移只需要在新的云服务器上启动项目需要的容器即可。

随着云计算DevOps生态圈的蓬勃发展,产生了大量优秀的系统和软件。软件开发人员可以自由选择各种软件应用环境。但同时带来的问题就是需要维护一个非常庞大的开发(Dev)、测试(Test)、预上线(UAT)和生产环境(Pro)。面对这种情况,Docker容器技术横空出世、提供了简单、灵活、高效的解决方案,不需要过多地改变现有的使用习惯,就可以和已有的工具进行整合。因此,掌握Docker相关技术也是途径云计算的必经之路。

Docker是在Linux容器里运行应用的开源容器管理工具,可以理解为轻量级的“虚拟机”。它诞生于 2013 年初,最初是 DotCloud 公司内部商业版项目,后来更换架构师,此架构师将Docker进行了开源,导致Docker使用人员增多。基于 Google公司推出的 Go(Golang) 语言开发。该项目后来加入了Linux基金会,遵从了Apache 2.0协议进行推广,项目代码在 GitHub(https://github.com/docker)上进行维护。

Docker 自开源后受到广泛的业内人士及社区的关注,以至于DotCloud公司后来都改名为 Docker Inc。RedHat系列系统从 RHEL6.5 版本开始支持 Docker;Google 也在其 PaaS 产品中广泛应用。

官方网站:Docker: Accelerated, Containerized Application Development

环境:选择虚拟化引擎

 关闭防火墙规则

[root@localhost ~]# iptables -F

[root@localhost ~]# setenforce 0

[root@localhost ~]# systemctl stop firewalld

yum安装docker

[root@localhost yum.repos.d]# yum -y install docker

启动并设置开机启动

[root@localhost yum.repos.d]#  systemctl start docker

[root@localhost yum.repos.d]#  systemctl enable docker

Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.

[root@localhost yum.repos.d]# docker version

Client:

 Version:         1.13.1

 API version:     1.26

 Package version: docker-1.13.1-209.git7d71120.el7.centos.x86_64

 Go version:      go1.10.3

 Git commit:      7d71120/1.13.1

 Built:           Wed Mar  2 15:25:43 2022

 OS/Arch:         linux/amd64

Server:

 Version:         1.13.1

 API version:     1.26 (minimum version 1.12)

 Package version: docker-1.13.1-209.git7d71120.el7.centos.x86_64

 Go version:      go1.10.3

 Git commit:      7d71120/1.13.1

 Built:           Wed Mar  2 15:25:43 2022

 OS/Arch:         linux/amd64

 Experimental:    false

 安装docker-ce

[root@localhost yum.repos.d]# wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

--2023-07-31 13:39:06--  http://mirrors.aliyun.com/repo/Centos-7.repo

正在解析主机 mirrors.aliyun.com (mirrors.aliyun.com)... 42.202.211.87, 42.202.211.96, 124.238.244.137, ...

正在连接 mirrors.aliyun.com (mirrors.aliyun.com)|42.202.211.87|:80... 已连接。

已发出 HTTP 请求,正在等待回应... 200 OK

长度:2523 (2.5K) [application/octet-stream]

正在保存至: “/etc/yum.repos.d/CentOS-Base.repo”

100%[=============================================================>] 2,523       --.-K/s 用时 0s      

2023-07-31 13:39:06 (257 MB/s) - 已保存 “/etc/yum.repos.d/CentOS-Base.repo” [2523/2523])

[root@localhost yum.repos.d]# yum -y install yum-utils device-mapper-persistent-data lvm2

[root@localhost yum.repos.d]# yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

[root@localhost yum.repos.d]# ll

-rw-r--r--. 1 root root 2081 7月  31 13:43 docker-ce.repo

[root@localhost yum.repos.d]# yum -y install docker-ce

[root@localhost yum.repos.d]# systemctl start docker

[root@localhost yum.repos.d]# systemctl enable docker

 阿里云镜像加速

[root@localhost yum.repos.d]#  cat << END > /etc/docker/daemon.json

> {

>         "registry-mirrors":[ "https://nyakyfun.mirror.aliyuncs.com" ]

> }

> END

[root@localhost yum.repos.d]# vim /etc/docker/daemon.json

{

        "registry-mirrors":[ "https://nyakyfun.mirror.aliyuncs.com" ]

}

[root@localhost yum.repos.d]# systemctl daemon-reload

[root@localhost yum.repos.d]# systemctl restart docker

查看基本信息

[root@localhost yum.repos.d]# docker version

Client:

 Version:         1.13.1

 API version:     1.26

 Package version: docker-1.13.1-209.git7d71120.el7.centos.x86_64

 Go version:      go1.10.3

 Git commit:      7d71120/1.13.1

 Built:           Wed Mar  2 15:25:43 2022

 OS/Arch:         linux/amd64

Server:

 Version:         1.13.1

 API version:     1.26 (minimum version 1.12)

 Package version: docker-1.13.1-209.git7d71120.el7.centos.x86_64

 Go version:      go1.10.3

 Git commit:      7d71120/1.13.1

 Built:           Wed Mar  2 15:25:43 2022

 OS/Arch:         linux/amd64

 Experimental:    false

查看详细信息

[root@localhost yum.repos.d]# docker info

Containers: 0

 Running: 0

 Paused: 0

 Stopped: 0

Images: 0

Server Version: 1.13.1

Storage Driver: overlay2

 Backing Filesystem: xfs

 Supports d_type: true

 Native Overlay Diff: true

Logging Driver: journald

Cgroup Driver: systemd

Plugins:

 Volume: local

 Network: bridge host macvlan null overlay

Swarm: inactive

Runtimes: docker-runc runc

Default Runtime: docker-runc

Init Binary: /usr/libexec/docker/docker-init-current

containerd version:  (expected: aa8187dbd3b7ad67d8e5e3a15115d3eef43a7ed1)

runc version: 8891bca22c049cd2dcf13ba2438c0bac8d7f3343 (expected: 9df8b306d01f59d3a8029be411de015b7304dd8f)

init version: fec3683b971d9c3ef73f284f176672c44b448662 (expected: 949e6facb77383876aeff8a6944dde66b3089574)

Security Options:

 seccomp

  WARNING: You're not using the default seccomp profile

  Profile: /etc/docker/seccomp.json

 selinux

Kernel Version: 3.10.0-1160.92.1.el7.x86_64

Operating System: CentOS Linux 7 (Core)

OSType: linux

Architecture: x86_64

Number of Docker Hooks: 3

CPUs: 1

Total Memory: 3.682 GiB

Name: localhost.localdomain

ID: U54H:7JJ6:COSW:UIMR:LSNL:FP7H:NANJ:NJPQ:K6FZ:3DMR:J26D:LWRR

Docker Root Dir: /var/lib/docker

Debug Mode (client): false

Debug Mode (server): false

Registry: https://index.docker.io/v1/

Experimental: false

Insecure Registries:

 127.0.0.0/8

Registry Mirrors:

 https://nyakyfun.mirror.aliyuncs.com

Live Restore Enabled: false

Registries: docker.io (secure)

Docker镜像操作

搜索镜像  命令格式:docker search 关键字

 下载nginx镜像

 

 

[root@localhost ~]# docker pull nginx

Using default tag: latest

Trying to pull repository docker.io/library/nginx ...

latest: Pulling from docker.io/library/nginx

a2abf6c4d29d: Pull complete

a9edb18cadd1: Pull complete

589b7251471a: Pull complete

186b1aaa4aa6: Pull complete

b4df32aa5a72: Pull complete

a0bcbecc962e: Pull complete

Digest: sha256:0d17b565c37bcbd895e9d92315a05c1c3c9a29f762b011a10c54a66cd53c9b31

Status: Downloaded newer image for docker.io/nginx:latest

下载centos镜像

[root@localhost ~]#  docker pull centos

Using default tag: latest

Trying to pull repository docker.io/library/centos ...

latest: Pulling from docker.io/library/centos

a1d0c7532777: Pull complete

Digest: sha256:a27fd8080b517143cbbbab9dfb7c8571c40d67d534bbdee55bd6c473f432b177

Status: Downloaded newer image for docker.io/centos:latest

查看所有镜像信息

[root@localhost ~]#   docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

docker.io/nginx     latest              605c77e624dd        19 months ago       141 MB

docker.io/centos    latest              5d0da3dc9764        22 months ago       231 MB

查看指定镜像信息   命令格式:docker inspect 镜像名或镜像ID

为镜像添加标签(类似软连接)

[root@localhost ~]# docker tag nginx nginx:ttt

[root@localhost ~]# docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

docker.io/nginx     latest              605c77e624dd        19 months ago       141 MB

nginx               ttt                 605c77e624dd        19 months ago       141 MB

docker.io/centos    latest              5d0da3dc9764        22 months ago       231 MB

删除

[root@localhost ~]# docker rmi nginx:ttt

Untagged: nginx:ttt

Untagged: docker.io/nginx@sha256:0d17b565c37bcbd895e9d92315a05c1c3c9a29f762b011a10c54a66cd53c9b31

[root@localhost ~]# docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

docker.io/nginx     latest              605c77e624dd        19 months ago       141 MB

docker.io/centos    latest              5d0da3dc9764        22 months ago       231 MB

 把镜像存到本地文件

命令格式:docker save -o 存出镜像为本地文件 镜像名

[root@localhost ~]# docker save -o nginx-images nginx

[root@localhost ~]# ls

anaconda-ks.cfg  nginx-images

 验证

[root@localhost ~]# docker rmi nginx

Untagged: nginx:latest

Deleted: sha256:605c77e624ddb75e6110f997c58876baa13f8754486b461117934b24a9dc3a85

Deleted: sha256:b625d8e29573fa369e799ca7c5df8b7a902126d2b7cbeb390af59e4b9e1210c5

Deleted: sha256:7850d382fb05e393e211067c5ca0aada2111fcbe550a90fed04d1c634bd31a14

Deleted: sha256:02b80ac2055edd757a996c3d554e6a8906fd3521e14d1227440afd5163a5f1c4

Deleted: sha256:b92aa5824592ecb46e6d169f8e694a99150ccef01a2aabea7b9c02356cdabe7c

Deleted: sha256:780238f18c540007376dd5e904f583896a69fe620876cabc06977a3af4ba4fb5

Deleted: sha256:2edcec3590a4ec7f40cf0743c15d78fb39d8326bc029073b41ef9727da6c851f

[root@localhost ~]# docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

docker.io/centos    latest              5d0da3dc9764        22 months ago       231 MB

[root@localhost ~]# docker load<nginx-images

2edcec3590a4: Loading layer 83.86 MB/83.86 MB

e379e8aedd4d: Loading layer    62 MB/62 MB

b8d6e692a25e: Loading layer 3.072 kB/3.072 kB

f1db227348d0: Loading layer 4.096 kB/4.096 kB

32ce5f6a5106: Loading layer 3.584 kB/3.584 kB

d874fd2bc83b: Loading layer 7.168 kB/7.168 kB

Loaded image: docker.io/nginx:latest

[root@localhost ~]# docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

docker.io/nginx     latest              605c77e624dd        19 months ago       141 MB

docker.io/centos    latest              5d0da3dc9764        22 months ago       231 MB

Docker 容器操作

容器是Docker 的另一个核心概念,简单说,容器是镜像的一个运行实例,是独立运行

的一个或一组应用以及它们所必需的运行环境,包括文件系统、系统类库、shell 环境等。

镜像是只读模板,而容器会给这个只读模板一个额外的可写层。

下面将具体介绍围绕容器的具体操作。

1、创建容器与运行容器

Docker 的创建就是将镜像加载到容器的过程,Docker 的容器十分轻量级,用户可以随

时创建或者删除。新创建的容器默认处于停止状态,不运行任何程序,需要在其中发起一个

进程来启动容器,这个进程是该容器的唯一进程,所以当该进程结束的时候,容器也会完全

停止。停止的容器可以重新启动并保留原来的修改。可以使用docker create 命令新建一个容器。

命令格式:docker create [选项]… 镜像运行的程序

常用选项:

  • -i 让容器的输入保持打开
  • -t 让Docker 分配一个伪终端
  • -d 守护进程形式运行

 创建容器

[root@localhost ~]# docker create -it centos /bin/bash

98f68500e69567459fa7125cfcddbe309f18a51ba125ac3af6bb657103b89048

查看容器运行状态

使用docker create 命令创建新容器后会返回一个唯一的ID。a代表所有容器

[root@localhost ~]# docker ps -a

CONTAINER ID        IMAGE               COMMAND             CREATED             STATUS              PORTS               NAMES

98f68500e695        centos              "/bin/bash"         26 seconds ago      Created                                 suspicious_franklin

启动容器
                 

 

[root@localhost ~]# docker start 98f68500e695  

98f68500e695

创建容器并执行一条shell命令

[root@localhost ~]# docker run centos /bin/bash -c ls /

bin

dev

etc

home

lib

lib64

lost+found

media

mnt

opt

proc

root

run

sbin

srv

sys

tmp

usr

var

[root@localhost ~]# docker ps -a

CONTAINER ID        IMAGE               COMMAND               CREATED             STATUS                      PORTS               NAMES

9497f8c130be        centos              "/bin/bash -c ls /"   36 seconds ago      Exited (0) 35 seconds ago                       romantic_williams

98f68500e695        centos              "/bin/bash"           3 minutes ago       Up About a minute                               suspicious_franklin

后台运行容器

[root@localhost ~]# docker run -d nginx /bin/bash -c "while true;do echo hello;done"

71dd7c6aad86aa4d2c69e1e175729c59f706e21c28ff340edfd7a7784d02c327

查看容器状态 -a是所有  -q只看容器id

[root@localhost ~]# docker ps -a

CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                   

71dd7c6aad86        nginx               "/docker-entrypoin..."   27 seconds ago      Up 25 seconds            

9497f8c130be        centos              "/bin/bash -c ls /"      3 minutes ago       Exited (0) 3 minutes ago

98f68500e695        centos              "/bin/bash"              5 minutes ago       Up 4 minutes          

查看容器输出 运行

[root@localhost ~]# docker logs 71dd7c6aad86

hello

hello

hello

hello

hello

hello

hello

hello

hello

hello

hello

hello

停止容器

[root@localhost ~]#  docker stop  71dd7c6aad86

71dd7c6aad86

查看

[root@localhost ~]# docker ps -a

CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                        PORTS               NAMES

71dd7c6aad86        nginx               "/docker-entrypoin..."   3 minutes ago       Exited (137) 11 seconds ago                       trusting_sammet

9497f8c130be        centos              "/bin/bash -c ls /"      6 minutes ago       Exited (0) 6 minutes ago                          romantic_williams

98f68500e695        centos              "/bin/bash"              8 minutes ago       Up 7 minutes                                      suspicious_franklin

进入容器

需要进入容器进行相应操作时,可以使用docker exec 命令或者docker attach命令进入运行着的容器。

命令格式:docker exec -it 容器ID/名称/bin/bash

其中,-i 选项表示让容器的输入保持打开;

-t 选项表示让Docker 分配一个伪终端。

[root@localhost ~]#  docker exec -it 71dd7c6aad86 /bin/bash

root@71dd7c6aad86:/# exit

exit

保证容器后台运行

[root@localhost ~]# docker attach 容器id

容器的导出与导入

用户可以将任何一个Docker 容器从一台机器迁移到另一台机器。在迁移过程中,首先需要将已经创建好的容器导出为文件,可以使用docker export 命令实现,无论这个容器是处于运行状态还是停止状态均可导出。导出之后可将导出文件传输到其他机器,通过相应的导入命令实现容器的迁移。

命令格式:docker export 容器ID/名称>文件名

导出31328ac9cd33容器到文件centos-exp:

[root@localhost ~]# docker run -it centos /bin/bash
[root@31328ac9cd33 /]# touch crushilnux
[root@31328ac9cd33 /]# exit
exit
[root@localhost ~]# docker export 31328ac9cd33>centos-exp

查看
[root@localhost ~]# ls -l centos-exp
-rw-r--r--. 1 root root 238594048 7月  31 14:26 centos-exp

导出的文件从A 机器拷贝到B 机器,之后使用docker import 命令导入,成为镜像。

命令格式:cat 文件名| docker import – 生成的镜像名称:标签

例如,导入文件centos7.tar成为本地镜像:

[root@localhost ~]# cat centos-exp | docker import - centos:exp

sha256:c85e59d0ca2f97e3dce46185d92708f22839501bf7126e64929c243b5d65fd83

[root@localhost ~]# docker images

REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE

centos              exp                 c85e59d0ca2f        19 seconds ago      231 MB

docker.io/nginx     latest              605c77e624dd        19 months ago       141 MB

docker.io/centos    latest              5d0da3dc9764        22 months ago       231 MB

 文件复制

将主机文件  拷贝到31328ac9cd33:/tmp  目录下

[root@localhost ~]# docker cp /root/anaconda-ks.cfg  31328ac9cd33:/tmp  

[root@localhost ~]# docker start 31328ac9cd33

31328ac9cd33

[root@localhost ~]# docker attach 31328ac9cd33

[root@31328ac9cd33 /]# ls /tmp

anaconda-ks.cfg  ks-script-4luisyla  ks-script-o23i7rc2  ks-script-x6ei4wuu

查看容器资源使用率

[root@localhost ~]# docker stats

CONTAINER           CPU %               MEM USAGE / LIMIT     MEM %               NET I/O             BLOCK I/O           PIDS

71dd7c6aad86        3.37%               268 KiB / 3.682 GiB   0.01%               2.62 kB / 656 B     0 B / 0 B           1

98f68500e695        0.00%               528 KiB / 3.682 GiB   0.01%               4.68 kB / 656 B     0 B / 0 B           1

查看容器进程状态

[root@localhost ~]#  docker top 71dd7c6aad86

UID                 PID                 PPID                C                   STIME               TTY                 TIME                CMD

root                9539                9525                7                   14:18               ?                   00:02:16            /bin/bash -c while true;do echo hello;done

更新容器配置

在docker服务重启时自动启动容器

[root@localhost ~]# docker update --restart=always 31328ac9cd33

31328ac9cd33

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/52556.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

医药化工企业洁净厂房改造消防防爆安全的重要性

设计 【摘要】&#xff1a;近年来&#xff0c;我国医药化工企业规模不断扩大。医药化工企业的情况复杂&#xff0c;稍有不慎将发生火灾或者爆炸&#xff0c;对人员生命以及财产安全造成巨大的损害&#xff0c;酿成悲剧。所以&#xff0c;“三同时”原则的落实&#xff0c;如何…

Filebeat+ELK 部署

Node1节点&#xff08;2C/4G&#xff09;&#xff1a;node1/192.168.8.10 Elasticsearch Kibana Node2节点&#xff08;2C/4G&#xff09;&#xff1a;node2/192.168.8.11 Elasticsearch Apache节点&#xff1a;apache/192.168.8.13 …

【51单片机】晨启科技,7针OLED显示驱动程序,STC89C52RC

文章目录 原理图oled.coled.hmain.c 原理图 sbit OLED_SCLP4^3;//SCL-D0 sbit OLED_SDAP4^1;//SDA-D1 sbit OLED_RES P3^6;//RES sbit OLED_DC P3^7;//DC sbit OLED_CSP2^7; //CS oled.c #include "OLED.h"//******************************说明*******************…

Android 9-- 源码角度: Home键的监听和拦截

在做应用层APP需求的过程中&#xff0c;HOME键的监听&#xff0c;Back键的监听&#xff0c;这都是很常见的问题&#xff0c;那你有试过&#xff0c;去拦截HOME键的事件吗&#xff0c;有去了解过如何处理吗&#xff0c;流程如何 首先大家应该先了解一种情况&#xff0c;就是Andr…

spring-boot-maven-plugin使用

spring-boot-maven-plugin这个插件有7个目标&#xff1a; spring-boot:build-image 使用构建包将应用程序打包到OCI映像中。 spring-boot:build-info 根据当前MavenProject spring-boot:help 显示有关spring-boot-maven插件的帮助信息。 调用mvn-spring-boot:help-Ddetailtr…

Vue前端框架入门

文章目录 Vue快速入门Vue指令生命周期 Vue 经过一小段时间学习 我认为vue就是在原js上进行的一个加强 简化JS中的DOM操作 vue是分两个层的 一个叫做视图层(View)&#xff0c;你可以理解为展现出来的前端页面 一个叫数据模型层(Model),包含数据和一些数据的处理方法 MVVM就是实…

P14 电路定理——巧妙-灵性-智慧

1、替代定理 图示表示&#xff1a; 叠加定理和齐性定理只能用于线性电路&#xff0c;但是替代定理无论线不线性都可以用。 常见的&#xff1a;线性电路将某复杂支路等效成电压源或电流源之后&#xff0c;就可以使用叠加原理了。 引入两个相互抵消的电压源&#xff0c;拿其中一…

【ARM64 常见汇编指令学习 13 -- ARM 汇编 ORG 伪指令学习】

文章目录 ARM ORG 指令介绍UEFI 中对 ORG 指令的使用 ARM ORG 指令介绍 在ARM汇编中&#xff0c;"org"是一个汇编器伪指令&#xff0c;用于设置下一条指令的装入地址。"org"后面跟着的是一个表达式&#xff0c;这个表达式的值就是下一条指令的装入地址。如…

Linux 系统编程 开篇/ 文件的打开/创建

从本节开始学习关于Linux系统编程的知识&#xff01; 学习Linux的系统编程有非常多的知识点&#xff0c;在应用层面&#xff0c;很重要的一点就是学习如何“用代码操作文件来实现文件创建&#xff0c;打开&#xff0c;编辑等自动化执行” 那如何自动化实现对文件的创建&#…

SSL 证书过期巡检脚本 (Python 版)

哈喽大家好&#xff0c;我是咸鱼 之前写了个 shell 版本的 SSL 证书过期巡检脚本 &#xff08;文章&#xff1a;《SSL 证书过期巡检脚本》&#xff09;&#xff0c;后台反响还是很不错的 那么今天咸鱼给大家介绍一下 python 版本的 SSL 证书过期巡检脚本 &#xff08;完整代码…

MATLAB | 如何绘制这样的描边散点图?

part.-1 前前言 最近略忙可能更新的内容会比较简单&#xff0c;见谅哇&#xff0c;今日更新内容&#xff1a; part.0 前言 看到gzhBYtools科研笔记(推荐大家可以去瞅瞅&#xff0c;有很多有意思的图形的R语言复现&#xff01;&#xff01;)做了这样一张图&#xff1a; 感觉很…

Opencv-C++笔记 (16) : 几何变换 (图像的翻转(镜像),平移,旋转,仿射,透视变换)

文章目录 一、图像平移二、图像旋转2.1 求旋转矩阵2.2 求旋转后图像的尺寸2.3手工实现图像旋转2.4 opencv函数实现图像旋转 三、图像翻转3.1左右翻转3.2、上下翻转3.3 上下颠倒&#xff0c;左右相反 4、错切变换4.1 实现错切变换 5、仿射变换5.1 求解仿射变换5.2 OpenCV实现仿射…