docker概述、安装、常用命令

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: docker概述、安装、常用命令

一、概述

1、docker

之前在服务器配置一个应用的运行环境,要安装各种软件,就拿一个基本的工程项目的环境来说吧, Java/Tomcat/MySQL/JDBC驱动包等。安装和配置这些东西有多麻烦就不说了,它还不能跨平台。假如 我们是在 Windows 上安装的这些环境,到了 Linux 又得重新装。况且就算不跨操作系统,换另一台同 样操作系统的服务器,要移植应用也是非常麻烦的。

通过Docker镜像 ( images ) 将 应用程序所需要的系统环境,由下而上打包,达到应用程序跨平台间的无缝接轨运作。

Docker官网:Home - Docker

Docker中文网站:https://www.docker-cn.com

Docker Hub官网:Docker Hub (仓库)

2、和虚拟机区别

  • 传统虚拟机技术是虚拟出一套硬件后,在其上运行一个完整操作系统,在该系统上再运行所需应用进程
  • 而容器内的应用进程直接运行于宿主的内核,容器内没有自己的内核,而且也没有进行硬件虚拟。 因此容器要比传统虚拟机更为轻便。
  • 每个容器之间互相隔离,每个容器有自己的文件系统 ,容器之间进程不会相互影响,能区分计算资 源。

比vm快的原因

1、docker有着比虚拟机更少的抽象层。由亍docker不需要Hypervisor实现硬件资源虚拟化,运行在docker容器上的程序直接使用的都是实际物理机的硬件资源。因此在CPU、内存利用率上docker将会在效率上有明显优势。

2、docker利用的是宿主机的内核,而不需要Guest OS。因此,当新建一个容器时,docker不需要和虚拟机一样重新加载一个操作系统内核。仍而避免引寻、加载操作系统内核返个比较费时费资源的过程,当新建一个虚拟机时,虚拟机软件需要加载Guest OS,返个新建过程是分钟级别的。而docker由于直接利用宿主机的操作系统,则省略了返个过程,因此新建一个docker容器只需要几秒钟。

3、docker架构

  • 镜像(image):Docker镜像(Image)是一个只读的模板。镜像可以用来创建Docker容器,一个镜像可以创建很多容器。例如tomcat镜像可以创建tomcat1容器和tomcat2容器,容器与镜像的关系类似于面向对象编程中的对象与类;
  • 容器(container):Docker利用容器(Container)独立运行的一个或一组应用。容器是用镜像创建的运行实例,容器可以被启动、开始,停止、删除,每个容器都是互相隔离,保证安全的平台,可以把容器看做是一个精简版的Linux环境和运行在其中的应用程序
  • 仓库(repository):集中存放镜像文件的场所。仓库和仓库注册服务器是有区别的,仓库注册服务器上往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签(tag)。仓库分为公开仓库(Public)和私有仓库(Private)两种格式,最大的公共仓库是Docker Hub,其他的仓库包括国内的阿里云、网易云等;

总结

  • Docker 本身是一个容器运行载体或称之为管理引擎。我们把应用程序和配置依赖打包好形成一个 可交付的运行环境,这个打包好的运行环境就似乎 image镜像文件。只有通过这个镜像文件才能生 成 Docker 容器。
  • image 文件可以看作是容器的模板。Docker 根据 image 文件生成容器的实例。 同一个 image 文件,可以生成多个同时运行的容器实例。 image 文件生成的容器实例,本身也是一个文件,称为镜像文件。
  • 一个容器运行一种服务,当我们需要的时候,就可以通过docker客户端创建一个对应的运行实例, 也就是我们的容器
  • 至于仓库,就是放了一堆镜像的地方,我们可以把镜像发布到仓库中,需要的时候从仓库中拉下来 就可以了。

二、docker安装

1、安装

说明centos6和centos7安装步骤不同,Docker 运行在 CentOS 7 上,要求系统为64位、系统内核版本为 3.10 以上

[root@izj6c22bffydfp7tlrbx7fz /]# uname -r

3.10.0-514.26.2.el7.x86_64

[root@izj6c22bffydfp7tlrbx7fz /]# cat /etc/os-release

NAME="CentOS Linux"

VERSION="7 (Core)"

ID="centos"

ID_LIKE="rhel fedora"

VERSION_ID="7"

PRETTY_NAME="CentOS Linux 7 (Core)"

ANSI_COLOR="0;31"

CPE_NAME="cpe:/o:centos:centos:7"

HOME_URL="https://www.centos.org/"

BUG_REPORT_URL="https://bugs.centos.org/"


CENTOS_MANTISBT_PROJECT="CentOS-7"

CENTOS_MANTISBT_PROJECT_VERSION="7"

REDHAT_SUPPORT_PRODUCT="centos"

REDHAT_SUPPORT_PRODUCT_VERSION="7"


[root@izj6c22bffydfp7tlrbx7fz /]#

查看gcc如果提示未找到命令即表示没有安装,需要安装

yum -y install gcc

yum -y install gcc-c++

卸载旧版本

yum remove docker \

                 docker-client \

                 docker-client-latest \

                 docker-common \

                 docker-latest \

                 docker-latest-logrotate \

                 docker-logrotate \

                 docker-engine

安装需要的软件包

yum install -y yum-utils

设置镜像仓库(说明安装docker不需要再opt或者其他目录下 直接在~下执行命令即可)

# 错误的地址 不要使用国外镜像地址

yum-config-manager --add-repohttps://download.docker.com/linux/centos/docker-ce.repo

[Errno 14] curl TCP connection reset by peer

[Errno 12] curl#35 - Timeout



# 正确推荐使用国内的

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

更新yum软件包索引

yum makecache fast

安装 Docker CE(ce社区版本 ee是付费版本)

yum install docker-ce docker-ce-cli containerd.io


如果安装指定版本 使用以下命令

yum install docker-ce-<VERSION_STRING> docker-ce-cli-<VERSION_STRING> containerd.io

启动docker 以及版本查看

systemctl start docker

docker version

运行一个hello-world镜像并查看

docker run hello-world

docker images

2、卸载

systemctl stop docker

yum -y remove docker-ce docker-ce-cli containerd.io

rm-rf /var/lib/docker

3、配置国内的镜像加速服务(阿里云 网易云等)这里选择阿里云

登录阿里云 找到容器镜像服务

选择对应的版本配置

执行命令上面的四条命令即可

4、hello-word运行过程

启动hello-world

5、docker运行原理

Docker是一个Client-Server结构的系统,Docker守护进程运行在主机上,然后通过Socket连接从客户端访问,守护进程从客户端接受命令并管理运行在主机上的容器。容器,是一个运行时环境,就是我们前面说到的集装箱。

三、常用命令

1、帮助命令

docker version   # 显示 Docker 版本信息。

docker info      # 显示 Docker 系统信息,包括镜像和容器数。。

docker --help# 帮助

docker命令查看

地址

Reference documentation | Docker Documentation

2、镜像命令

2.1、查看镜像

docker images

  可加参数选项 -a 、-q 、 -aq

  docker images -a

  docker images -a

  docker images -aq

 

 

2.2、搜索镜像 docker search 某个镜像的名称对应DockerHub仓库中的镜像

docker search mysql

 可加参数

   --filter=stars=50:列出收藏数不小于指定值的镜像

2.3、下载镜像  

docker pull mysql   #不写tag,默认是latest

docker pull mysql:5.7  #下载指定版本

 

2.4、删除镜像

docker rmi -f镜像id                          # 删除单个

docker rmi -f镜像名:tag 镜像名:tag            # 删除多个

docker rmi -f$(docker images -qa)        # 删除全部

3、容器命令

说明:有镜像才能创建容器,我们这里使用 centos 的镜像来测试,就是虚拟一个 centos !

先下载镜像

docker pull centos

3.1、新建并启动容器

1、以镜像新建一个容器并启动

docker run [OPTIONS] IMAGE [COMMAND][ARG..

可选参数

  --name="Name"# 给容器指定一个名字

  -d# 后台方式运行容器,并返回容器的id!

  -i# 以交互模式运行容器,通过和 -t 一起使用

  -t# 给容器重新分配一个终端,通常和 -i 一起使用

  -P# 随机端口映射(大写)

  -p# 指定端口映射,小写的时候一般可以有四种写法  

    ip:hostPort:containerPort  

    ip::containerPort  

    hostPort:containerPort (常用)  主机端口:容器端口

    containerPor

如下已经启动了一个新的centos系统,使用centos进行用交互模式启动容器,在容器内执行/bin/bash命令!

docker run -it centos /bin/bash

命令行已经切换到容器内

[root@8c070855da83 /]# ls

bin  dev  etc  home  lib  lib64  lost+found  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

3.2、查询容器

docker ps [OPTIONS]#

常用参数说明

  -a# 列出当前所有正在运行的容器 + 历史运行过的容器

  -l# 显示最近创建的容器

  -n=?    # 显示最近n个创建的容器

  -q# 静默模式,只显示容器编号。

3.3、退出

exit# 容器停止退出

ctrl+P+Q     # 容器不停止退出

3.4、启动和停止容器

docker start (容器id or 容器名)        # 启动容器

docker restart (容器id or 容器名)      # 重启容器

docker stop (容器id or 容器名)         # 停止容器

docker kill (容器id or 容器名)         # 强制停止容器

3.4、删除容器

docker rm容器id   # 删除指定容器

docker rm-f$(docker ps -a -q) # 删除所有容器

docker ps-a-q|xargs docker rm # 删除所有容器

4、其他命令

4.1、后台启动容器

# 命令

docker run -d容器名

# 例子

docker run -d centos # 启动centos,使用后台方式启动

# 问题:使用docker ps 查看,发现容器已经退出了!

# 解释:Docker容器后台运行,就必须有一个前台进程,容器运行的命令如果不是那些一直挂起的命令,就会自动退出。# 比如,你运行了nginx服务,但是docker前台没有运行应用,这种情况下,容器启动后,会立即自杀,因为他觉得没有程序了,所以最好的情况是,将你的应用使用前台进程的方式运行启动。

4.2、查看日志

docker logs -f-t--tail容器id

-t 显示时间戳

-f 打印最新的日志

--tail 数字显示多少条!

docker logs -tf --tail 10 c8530dbbe3b

4.3、查看容器中运行的进程信息,支持 ps 命令参数

# 命令

docker top容器id

# 测试

[root@root ~]# docker top c8530dbbe3

4.4、查看容器/镜像的元数据

4.5、进入正在运行的容器

# 命令1

docker exec -it容器id bashShell

测试

docker exec -it c8530dbbe3b4 /bin/bash


# 命令2

docker attach 容器id

测试

docker attach -it c8530dbbe3b4 /bin/bash


# 区别

# exec   是在容器中打开新的终端,并且可以启动新的进程

# attach 直接进入容器启动命令的终端,不会启动新的进程

4.6、进入正在运行的容器从容器内拷贝文件到主机上

docker cp容器id:容器内路径目的主机路径

测试

docker cp c8530dbbe3b4:/home/f1 /home

4.7、查看容器的cpu内存和网络状态

docker stats 容器id

5、案例

5.1、使用docker安装nginx

某个镜像的使用方法可以直接在dockerhub里面搜索查看

1、搜索镜像

docker search nginx --filter=stars=3000


2、拉取镜像

docker pull nginx


3、以镜像nginx新建后台启动容器 并且容器名定义为nginx01(默认nginx) 并且映射主机端口为3999

docker run -d --name nginx01 -p 3999:80 nginx

 

3、测试访问

curl localhost:3999


5、进入容器

[root@izj6c22bffydfp7tlrbx7fz /]# docker exec -it nginx01 /bin/bash

root@4384a8501bb0:/# whereis nginx 寻找nginx

nginx: /usr/sbin/nginx /usr/lib/nginx /etc/nginx /usr/share/nginx

root@4384a8501bb0:/#

5.2、使用docker安装tomcat

# 1、下载tomcat镜像

docker pull tomcat#

2、启动

docker run -d-p8080:8080 --name tomcat9 tomcat

# 3、进入

tomcatdocker exec -it tomcat9 /bin/bash#

4、思考:我们以后要部署项目,还需要进入容器中,是不是十分麻烦,要是有一种技术,可以将容器内和我们Linux进行映射挂载就好了?我们后面会将数据卷技术来进行挂载操作,也是一个核心内容,这里大家先听听名词就好,我们很快就会讲到!


5.3、使用docker安装 es + kibana

# 我们启动es这种容器需要考虑几个问题1、端口暴露问题9200、93002、数据卷的挂载问题 data、plugins、conf3、吃内存-"ES_JAVA_OPTS=-Xms512m -Xmx512m"# 扩展命令docker stats 容器id    # 查看容器的cpu内存和网络状态# 1、启动es测试docker run -d--name elasticsearch -p9200:9200 -p9300:9300 -e"discovery.type=single-node" elasticsearch:7.6.2# 2、启动之后很卡,使用 docker stats 容器id 查看下cpu状态,发现占用的很大CONTAINER ID        NAME                CPU %               MEM USAGE /LIMIT     MEM %          249ae46da625        elasticsearch       0.00%               1.036GiB /1.716GiB   60.37%    # 3、测试访问[root@kuangshen data]# curl localhost:9200{"name" : "249ae46da625","cluster_name" : "docker-cluster","cluster_uuid" : "_Ho_i4fOTUesNc_II35sSA","version" : {"number" : "7.6.2","build_flavor" : "default","build_type" : "docker","build_hash" : "ef48eb35cf30adf4db14086e8aabd07ef6fb113f","build_date" : "2020-03-26T06:34:37.794943Z",

6、可视化

6.1、概述

  1. Portainer(先用这个)
  2. Rancher(CI/CD再用这个)

持续集成和发布的时候用

#安装rancher-server

docker run --name rancher-server -p 8000:8080 -v

/etc/localtime:/etc/localtime:ro -d rancher/server

#安装agent

docker run --rm --privileged -v /var/run/docker.sock:/var/run/docker.sock -v

/var/lib/rancher:/var/lib/rancher rancher/agent:v1.2.11

http://39.101.191.131:8000/v1/scripts/D3DBD43F263109BB881F:1577750400000:7M0y

BzCw4XSxJklD7TpysYIpI


6.2、Portainer

Portainer是Docker的图形化管理工具,提供状态显示面板、应用模板快速部署、容器镜像网络数据卷 的基本操作(包括上传下载镜像,创建容器等操作)、事件日志显示、容器控制台操作、Swarm集群和 服务等集中管理和操作、登录用户管理和控制等功能。功能十分全面,基本能满足中小型单位对容器管 理的全部需求。

如果仅有一个docker宿主机,则可使用单机版运行,Portainer单机版运行十分简单,只需要一条语句即 可启动容器,来管理该机器上的docker镜像、容器等数据。

docker run -d -p 8088:9000 \

--restart=always -v /var/run/docker.sock:/var/run/docker.sock --

privileged=true portainer/portainer

访问方式:http://IP:8088

首次登陆需要注册用户,给admin用户设置密码

单机版这里选择local即可,选择完毕,点击Connect即可连接到本地docker:


相关文章
|
23天前
|
存储 监控 安全
|
17天前
|
Prometheus 监控 Cloud Native
基于Docker安装Grafana和Prometheus
Grafana 是一款用 Go 语言开发的开源数据可视化工具,支持数据监控和统计,并具备告警功能。通过 Docker 部署 Grafana 和 Prometheus,可实现系统数据的采集、展示和告警。默认登录用户名和密码均为 admin。配置 Prometheus 数据源后,可导入主机监控模板(ID 8919)进行数据展示。
51 2
|
18天前
|
存储 监控 Linux
Docker技术架构概述
【10月更文挑战第22天】Docker采用CS架构,Client与Daemon交互,Compose管理多容器应用。
|
19天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
46 2
|
20天前
|
消息中间件 Linux RocketMQ
在Red Hat Enterprise Linux 9上使用Docker快速安装并部署
通过以上步骤,你可以在Red Hat Enterprise Linux 9上使用Docker快速安装并部署RocketMQ。这种方法不仅简化了安装过程,还提供了一个灵活的环境来管理和扩展消息队列系统。RocketMQ作为一款高性能的分布式消息系统,通过Docker可以实现快速部署和高效管理。
29 3
|
23天前
|
关系型数据库 MySQL Linux
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
基于阿里云服务器Linux系统安装Docker完整图文教程(附部署开源项目)
189 2
|
7天前
|
Docker 容器
【赵渝强老师】使用二进制包方式安装Docker
本文介绍了在企业生产环境中无法直接访问外网时,如何使用Docker官方提供的二进制包进行Docker的离线安装。文章详细列出了从安装wget、下载Docker安装包、解压、复制命令到启动Docker服务的具体步骤,并提供了相关命令和示例图片。最后,还介绍了如何设置Docker为开机自启模式。
|
7天前
|
缓存 Ubuntu Linux
如何安装Docker
如何安装Docker
64 0
|
6月前
|
Ubuntu 网络安全 数据安全/隐私保护
百度搜索:蓝易云【docker通过dockerfile安装sftp教程。】
现在,你已经通过 Dockerfile 成功安装了 SFTP,并且可以使用指定的用户名和公钥进行远程访问。请确保替换示例中的用户名、密码和公钥为自己的实际值。
174 1
|
消息中间件 Shell RocketMQ
百度搜索:蓝易云 ,常用环境部署—Docker安装RocketMQ教程!
通过按照上述步骤,您可以在Docker中成功安装和部署RocketMQ。请注意,上述命令仅提供了一个基本的安装和配置过程,具体配置和使用可以根据您的需求进行进一步调整。确保在执行命令之前,您已经安装并配置好Docker环境。
181 0