一、简介、安装和基础配置1、简介
包括三个基本概念:
的镜像概念类似于虚拟机里的镜像(比如.ISO文件),是一个只读的模板,一个独立的文件系统,包括运行容器所需的数据,可以用来创建新的容器。
例如:一个镜像可以包含一个完整的 操作系统环境,里面仅安装了MySQL或用户需要的其它应用程序。
这里的镜像就如下方虚拟机创建时候使用的镜像类似。这个镜像便于移动,并且这个镜像我们可以交给任何人使用,其他人使用的时候也很方便,只需要将其实例化即可。
每个容器间是相互隔离的,容器中会运行特定的应用,包含特定应用的代码及所需的依赖文件。
容器就类似与虚拟机中我们创建好的虚拟机系统,之后我们所有的操作都是在容器中进行的,我们的程序也是运行在容器中。
官方的仓库 : 他的服务器处于国外,所以下载速度较慢,不过我们可以通过换源解决。
国内仓库 : 国内也有一些优秀的商店,他和官方的仓库的区别类似与和Gitee的区别。
本文主要解决在环境下,快速上手使用的问题,主要会介绍在系统下 的安装, 基础命令,比如说下载镜像、实例化镜像、使用容器、关闭容器、删除容器镜像、使用仓库、创建镜像等模块的使用。其他系统应该除了安装外其他操作都可以通用。
2、安装 、我们先去官网下载安装包
b、安装
打开安装包加载一会后一般会弹出下面选项,提示是否创建桌面快捷方式,这里勾选上。
下一步等待安装完成,出现如下界面代表安装成功了
c、开始使用
双击桌面生成的快捷方式,进入程序主页
这里随便勾选一些,然后点击按钮【】继续
进入最后一步啦,这里可以选择登录自己的账户
3、换源
我们打开的设置
选择 ,在编辑框中输入(这里选取的是163的源,你也可以换成你觉得更快的其它源)
{
"registry-mirrors":[
"https://docker.mirrors.ustc.edu.cn",
"https://registry.docker-cn.com",
"http://hub-mirror.c.163.com",
"https://mirror.ccs.tencentyun.com"
],
"insecure-registries":[],
"debug":true,
"experimental":false
}
二、基础使用
首先我们打开cmd命令框,输入“ run hello-world”是否会出现下图所示的提示,如果出现报错,这环境配置可能出现了问题。
这行命令会让从官方仓库中拉去hello-world的镜像到本地,并且自动将其实例化成容器。
我们再去查看 的主页会出现如下记录
1、对操作
安装完成后,默认每次开机的时候都会自动启动,但我们也可以手动启动,关闭或者重启
# 启动docker
sudo service docker start
# 重启docker
sudo service docker restart
# 停止docker
sudo service docker stop
2、对镜像的基础操作a、获取当时所有镜像( )
docker image ls
# 或者
docker images
上面图的结果字段含义如下:
标签
含义
镜像所在的仓库名称
TAG
镜像标签
镜像ID
镜像的创建日期(不是获取该镜像的日期)
SIZE
镜像大小
b、拉取镜像( pull)
除了使用官方的镜像外,我们还可以在仓库中申请一个自己的账号,保存自己制作的镜像,或者拉取使用他人的镜像。
# 官方镜像
docker image pull 镜像名称
# 或简写为
docker pull 镜像名称
# 比如
docker pull ubuntu
docker pull ubuntu:16.04
# 个人镜像
docker pull 仓库名称/镜像名称
docker pull gyd/django
# 第三方仓库拉取
docker pull 第三方仓库地址/仓库名称/镜像名称
docker pull hub.c.163.com/library/mysql:latest
(默认仓库名为library,所有从官方获取镜像相当于`sudo docker image pull library/镜像名称`)
c、删除镜像( rmi)
docker image rm 镜像名或镜像ID 或 docker rmi 镜像名或镜像ID
docker image rm hello-world
docker rmi 9e64176cd8a2
删除镜像的前提是没有使用这个镜像的容器,如果有需要先删除容器(报错:Error from : : to 镜像ID (must be ) – image is being used by 容器ID则代表有容器使用了此镜像。)可以尝试先执行 rm 容器ID删除容器,如果还报错,可以看我下方删除容器的具体方法。
几条删除命令的区别:
d、加载镜像( run)
上面我们说过,镜像只是一个只读类型的文件,而我们的环境不可能只是一个这样的文件,所以我们需要把这个镜像加载成我们的环境,也就是让他变成容器
docker run [可选参数] 镜像名 [向启动容器中传入的命令]
可以启动一个系统 run -i -d -t –name=my-test-kali /kali-(这里我使用linux的一个发行版作为介绍)
或可以简写为 run -idt –name=my-test-kali /kali-
PS: 如果加载一个我们没有的镜像,会自动从官方仓库中进行拉取。
或者我们可以启动一个网站 run -dp 8080:80 –name -test /-
如果你没有下载/-的进行,这里会自动帮你下载
成功启动后,可以在浏览器中输入“:8080/” 即可看到如下页面
3、使用交互式容器
上面我们成功将镜像变成了容器,但上述的命令中我们都加入了-d,让容器在后台运行了。下面我们就来讲如何和正在运行的容器进行交互。
a、查看容器( ps)
查看容器主要会用到ps命令
# 查看当前所有正在运行的容器
docker ps
# 查看当前所有的容器
docker ps -a
# 使用过滤器(除了name外,常用的还可以指定id:id= 、所有停止的容器:status=exited,正在运行的容器:status=running 等)
docker ps -f name=指定的名字
# 显示2个上次创建的容器(2可以改变)
docker ps -n 2
# 显示最新创建的容器(包括所有状态)
docker ps -l
# 仅显示ip
docker ps -q
# 显示容器大小
docker ps -s
b、启动和关闭容器
# 停止容器
docker container stop 容器名或容器id
# 或可简写为
docker stop 容器名或容器id
# 强制关闭容器
docker container kill 容器名或容器id
# 或可简写为
docker kill 容器名或容器id
# 启动容器
docker container start 容器名或容器id
# 或可简写为
docker start 容器名或容器id
c、操作后台容器
之前我们下过一个kali并且放在了后台运行,如果没有下载可以执行下列命令( run -i -d -t –name=my-test-kali /kali-),下面我们就用下面的命令开启kali(如果你下的是其他系统,比如也可以举一反三一下)
首先我们确保我们要进入的容器是开启状态的,使用 ps -a查看其中的属性是否是Up开头,如果不是先照着上面启动容器的方法开启容器
我们开启容器后,如果需要在容器内执行命令,可以将后台切换到前台,也可能使用命令将我们需要执行的命令传入。
操作方法有很多种,这里我们介绍一些比较常用的方法
# 如果我只需要执行简单的一两条命令可以使用docker exec
# 执行单条命令 (-i: 启动并且保留交互式命令行; -t:作用是分配一个虚拟的终端; docker run )
docker exec -it 容器名或容器id 执行的命令
# 比如
docker exec -it my-test-kali whoami
# 用这种方法,我们还可以启动命令行,根据Linux的特性,系统程序会在/bin中,linux中常用的Shell有多个,其中大部分用的Linux默认的为bash
# 所以我们启动命令可以自行如下命令(除了/bin/bash外,linux一般还会带/bin/sh、/bin/rbash、/bin/dash等,具体区别可以自行百度)
docker exec -it 容器名或容器id /bin/bash
# 比如
docker exec -it my-test-kali /bin/bash
# 除了exec外还有attach可以使用,但它有个弊端,多终端启动attach后,都会会同步显示。如果有一个窗口阻塞了,那么其他窗口也无法再进行操作。
docker attach 容器名或容器id
# 比如
docker attach my-test-kali
除了上述方法外,在进入容器后,我们还可以尝试安装SSH或者尝试登陆,不过这两种方法都先进入容器安装后才能使用
但并不建议在 容器中运行 ssh
# nsenter安装步骤
wget https://www.kernel.org/pub/linux/utils/util-linux/v2.24/util-linux-2.24.tar.gz
tar -xzvf util-linux-2.24.tar.gz
cd util-linux-2.24/
./configure --without-ncurses
make nsenter
sudo cp nsenter /usr/local/bin
d、删除容器( rm)
如我我们需要删除一个容器,首先需要确保这个容器已经停止了,因为正在运行的容器是无法直接删除。
我们可以运行一下 ps -a,如果发现没有停止,可以使用 stop停止(下已开头则是停止的)
# 使用rm删除容器
docker rm 容器名或容器id
# 列如
docker rm docker-test
如果报错Error from : You a 容器ID. Stop the or force 则代表这个容器已经启动,需要执行 stop 容器id,停止此容器。
e、容器制作成镜像
我们为什么要把容器制作成镜像?
# 将容器制作成镜像
docker commit 容器名 镜像名
# 镜像打包备份(打包备份的文件会自动存放在当前命令行的路径下,如果想让保存的文件可以打开,可以加.tar后缀)
docker save -o 保存的文件名 镜像名
# 镜像解压
docker load -i 文件路径/备份文件
我们将打包备份的镜像可以通过网络发送到其他设备上,使用镜像解压即可直接使用你的环境。
三、 ( 仪表板)
仪表板的主要作用为:快速访问容器日志,启动容器的 shell,并轻松管理容器生命周期(停止、删除等)。
点击小鲸鱼图标后,选择
直接点击一个容器,我们可以进入容器的交互界面,其中能看到容器的log,参数,
四、示例-部署安装mysql程序
image pull mysql
容器名是mysql,自定义。
第一次执行,需要先创建容器并启动(容器名是mysql): run –name mysql -d -p 6666:3306 -e =1234 mysql
后续 直接执行 start 容器名即可: start mysql
进入mysql 交互环境,使用创建容器时设置的账户密码登录mysql环境
docker exec -it mysql /bin/bash
mysql -u root -p
接下来可以愉快的执行mysql相关命令啦! 比如查看数据库 show 、创建数据库 ; 创建表 table等。
———END———
限 时 特 惠: 本站每日持续更新海量各大内部创业教程,永久会员只需109元,全站资源免费下载 点击查看详情
站 长 微 信: nanadh666