docker 容器部署

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker 容器 :   容器是Docker又一核心的概念,简单来说,容器是独立运行的一个或一组应用,以及它们的运行态环境。对应的,虚拟机可以理解为模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用。

Docker 容器 :

   容器是Docker又一核心的概念,简单来说,容器是独立运行的一个或一组应用,以及它们的运行态环境。对应的,虚拟机可以理解为模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和跑在上面的应用。

接下来具体介绍如何管理一个容器,包括创建、启动和停止等。


启动容器有两种方式:

         (1.) 第一种是基于镜像新建一个容器并启动。

  所需要的命令主要为docker run   

实例:

     wKiom1kuavKyFmxRAABMaqcvciE995.jpg-wh_50

     -t:让docker分配一个为终端(paseudo-tty)并绑定到容器的标准输入上

     -i:让容器的标准输入保持打开(即交互式),可以使用-name给容器起个形象的名称。


在交互模式下,用户可以通过所创建的终端来输入命令

例如:

   wKiom1kubK6TaKkzAAB8rZanXeE979.jpg-wh_50

容器的核心为所执行的应用程序,所需要的资源都是应用程序运行所必需的。除此之外,并没有其它的资源。可以在伪终端中利用ps或top来查看进程信息。

 wKioL1kubl_zfhpLAABaE8SJClI586.jpg-wh_50

可见,容器中仅允许了指定的bash应用。这种特点使得Docker对资源利用率极高,是货真价实的轻量级虚拟化。


退出容器的方式:

       logout

       exit

       Ctrl+d

       Ctrl+c

       Ctrl -p  + Ctrl -q


下面的命令是输出一个hello world 消息,终止容器。

wKiom1kuc4CBfpWzAAER59Uprng529.jpg-wh_50


当利用docker run 来创建容器时 ,Docker在后台运行的标准操作包括:

 1.检查本地是否存在指定的镜像,不存在就从公有仓库下载

 2.利用镜像创建并启动一个容器

 3.分配一个文件系统,并在只读的镜像层外面挂载一层可读写层

 4.从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去

 5.从地址池配置一个IP地址给容器

 6.执行用户指定的应用程序

 7.执行完毕后容器被终止


查看容器:

wKioL1kuezCjnQGtAADI4MMJrAc782.jpg-wh_50


  (2.)第二种是将在终止状态(stoped)的容器重新启动。


 可以利用docker start 命令,直接将一个已经终止的容器启动运行

wKiom1kugGeBh3O-AACrWAFX91o366.jpg-wh_50


可以使用docker stop 来终止一个运行的容器。此外,当docker容器中指定的应用终结时,容器也自动

终止。终止状态的容器可以用docker ps -a  命令看到。


wKioL1kugqrzKfPUAAF8e_PNF1c959.jpg-wh_50

重启一个容器:

 

  wKioL1kug26DczrUAAEgMyBFDmA197.jpg-wh_50


二、守护进程方式去运行docker


  1.    更多的时候,需要让docker容器在后台以守护态(Daemonized)形式运行。此时,可以通过添加 -d 参数来实现。

    例如:

       wKioL1kuhZ7yGeXkAAEl6Xo5DOI257.jpg-wh_50

    或者

    wKioL1kuhhGhTovdAAE6TGWkNqM216.jpg-wh_50


容器启动后会返回一个唯一的ID值,也可以通过docker ps 命令来查看容器信息


1.docker卡 run -d  运行提个新的容器,我们通过-d 命令来查看容器信息。

2.centos:centos6 是一个我们想要在内部运行命令的镜像。

3./bin/sh -c 是我们想要在容器内部运行的命令

4.while true;do echo hello weibo;sleep 1; done这是一个简单的脚本,我们仅仅是每秒打印一

次 hello world 一直到我们结束它。


2.用 docker inspect查看容器的信息

wKiom1kuiD-zIU84AAEUFuLCDtE953.jpg-wh_50

用docker inspect 查看容器的IP地址


wKiom1kui6WgPNIfAABhG5id2tc083.jpg-wh_50

用docker inspect 查看容器执行的程序

wKiom1kujCWyhIuPAABdj1ZRdMQ117.jpg-wh_50


3.进入容器:


    在使用-d参数时,容器启动后会进入后台。某些时候需要进入容器进行操作,有很多种方法,包括使

用docker attach命令或nsenter命令。


  (1.) 使用docker attach进入容器:

   wKiom1kujfPRIuYYAABDzE281kg435.jpg-wh_50

  

   wKiom1kukNuTPycCAABwZaWut3o474.jpg-wh_50

   1.docker attache 允许我们进入后台进程


   2.--sig-proxy=false 不使用容器转发信号,允许我们使用Ctrl -c来退出,执行docker ps查看在后台运行。

   但是使用 attache 命令有时候并不方便。当多个窗口同时attach到同一个容器的时候,所有窗口都会

同步显示。当某个窗口因命令阻塞时,其他窗口也无法执行操作了。


  3.也可以执行docker exec进入运行的容器

  wKioL1kukpCjr2gdAAB9nYfMjcE651.jpg-wh_50


(2.)使用nsenter进入容器:


     安装:nsenter工具在util-Linux包2.23版本后包含。如果系统中util-Linux包没有该命令,可以按照

下面的方法从源码安装

   #wgethttps://www.kernel.org/pub/utils/util-linux/v2.24/util-linux-2.24.tar.gz

   #tar util-linux-2.24.tar.gz

   #cd  util-linux-2.24

   # ./configure  --without-ncurses&& make nsenter

   # cp nsenter /usr/local/bin

  

注意:nsenter可以访问另一个进程的名字空间。nsenter要正常工作需要有root权限。

庆幸的是centos7使用的是util-linux-2.23,所以就直接使用系统提供的util-linux包了。

 

wKioL1kulOChxpVfAABPeIDO3c8071.jpg-wh_50

为了使用nsenter命令工具连接到容器,还需要找到容器的第一个进程的pid,可以通过下面的命令获取到。

wKiom1kumBijf_H5AAF6_5vyuCU796.jpg-wh_50

附:更简单的,建议大家下载 .bashrc_docker,并将内容放到 .bashrc中

#wget  ~https://github.com/yeasy/docker_practice/raw/master/_local/.bashrc_docker

#echo "[-f ~/.bashrc_docker] && ~/.bashrc_docker">>~/.bashrc

#source ~/.bashrc


这个文件中定义了很多方便使用Docker的命令,例如docker-pid可以获取某个容器的pid;而docker-

enter 可以进入容器或直接在容器内执行命令。

 echo $(docker-pid<container>)

docker-enter<container>ls


三、容器的导入和导出以及删除容器


 (1.)导出容器

  如果要导出本地某个容器,可以 使用docker export命令。

  wKioL1ku1Nux1JbFAACGuyRzza0324.jpg-wh_50

(2.)导入容器

可以使用docker import 从容器快照文件中再导入为镜像

wKiom1ku1c3xgn6WAAD9C9fse0A079.jpg-wh_50


 除此之外,也可以通过指定URL或者某个目录来导入。例如:

#docker import http://example.com/exampleimage.tgzexample/imagerepo


注意:

docker load 和 docker import 的区别 :


用户既可以使用docker load 来导入镜像存储文件到本地镜像库,也可以使用docker import来导入一个

容器快照到本地镜像库。这两者的区别在于容器快照文件将丢弃所有的历史记录和元数据信息(即仅保

存容器当时的快照状态),而镜像存储文件将保存完整记录,体积也要大。此外,从容器快照文件导入

时可以重新指定标签等元数据信息。


删除容器:


可以使用 docker rm来删除一个处于终止状态的容器


如果要删除一个运行中的容器,可以添加 -f 参数。docker会发送SIGKILL信号给容器。


wKioL1ku2ffRCWHyAABC_eGFmMU214.jpg-wh_50

批量删除多个容器:

  wKiom1ku2njgXZNRAACDubBPe3o936.jpg-wh_50


目录
相关文章
|
2天前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
139 93
|
1月前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
236 77
|
5天前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
52 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
3天前
|
监控 Java 应用服务中间件
tomcat相关概念与部署tomcat多实例-zabbix监控(docker部署)
通过上述步骤,您可以在Ubuntu系统上成功编译并安装OpenCV 4.8。这种方法不仅使您能够定制OpenCV的功能,还可以优化性能以满足特定需求。确保按照每一步进行操作,以避免常见的编译问题。
41 25
|
16天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
90 35
|
3天前
|
数据库 Docker 容器
docker容器为啥会开机自启动
通过配置适当的重启策略,Docker容器可以在主机系统重启后自动启动。这对于保持关键服务的高可用性和自动恢复能力非常有用。选择适合的重启策略(如 `always`或 `unless-stopped`),可以确保应用程序在各种情况下保持运行。理解并配置这些策略是确保Docker容器化应用可靠性的关键。
29 17
|
15天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
4天前
|
运维 Java 虚拟化
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
《docker基础篇:1.Docker简介》,包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
54 12
|
21天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
108 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
5天前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
43 10