Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2289906
  • 博文数量: 297
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 2200
  • 用 户 组: 普通用户
  • 注册时间: 2014-03-31 14:30
个人简介

自己慢慢积累。

文章分类

全部博文(297)

分类: 虚拟化

2024-11-14 13:37:41

参考文章1:https://blog.csdn.net/2401_86454590/article/details/141922794
参考文章2:docker run 命令常用参数详解 - 明月, - 博客园
参考文章3:Docker容器的重启策略及docker run的--restart选项详解-CSDN博客



1. linux 系统安装docker

点击(此处)折叠或打开

  1. # 更新 yum 到{BANNED}{BANNED}{BANNED}{BANNED}{BANNED}{BANNED}最佳佳佳佳佳佳新版,Complete完成
  2. yum update

  3. # 安装需要的依赖包
  4. yum install -y yum-utils device-mapper-persistent-data lvm2

  5. # 设置yum源
  6. yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

  7. # 安装docker
  8. yum install -y docker-ce

  9. # 验证是否安装成功(查看docker版本)
  10. docker -v
2. 配置镜像加速器
Docker默认的镜像网站太慢,需要配置成阿里云的镜像加速器。

点击(此处)折叠或打开

  1. # 1、创建docker目录
  2. mkdir -p /etc/docker
  3. # 2、配置镜像地址
  4. tee /etc/docker/daemon.json <<-'EOF'
  5. {
  6. "registry-mirrors": ["https删掉我://rm2pgssp.mirror.aliyuncs.com"]
  7. }
  8. EOF
  9. # 3、重新加载
  10. systemctl daemon-reload
  11. # 4、重启docker服务
  12. systemctl restart docker
3. 
Docker服务命令
启动/关闭/重启docker服务
systemctl start/stop/restart docker

开机启动docker服务
systemctl enable docker

取消开机启动docker服务
systemctl disable docker

查看是否设置开机自启(enable:开启,disable:关闭)
systemctl list-unit-files | grep docker

4、Docker镜像命令
镜像内部是一个精简的操作系统,里面包含应用运行所必须的文件和依赖包。
镜像可以理解为Docker中安装的软件,Docker会把需要安装的软件和以来环境打包成镜像

查看镜像:本地有哪些镜像
docker images

搜索镜像:从网络中搜索可用的镜像
docker search 镜像名称

拉取镜像:从Docker仓库下载镜像
docker pull 镜像名称
docker pull 镜像名称:版本

删除镜像:删除本地的镜像,删除镜像前,需要先删除对应的容器(如果有的话),否则删除镜像会失败。
docker rmi 镜像名称
docker rmi 镜像名称:版本

实例1:安装redis镜像

  1. # 1、查看Docker中有哪些镜像(当前未安装redis镜像)
  2. docker images
  3. # 2、安装redis镜像(默认版本)
  4. docker pull redis
  5. # 3、再次查看镜像,多出来一个redis镜像
  6. docker images

实例2:安装指定版本的redis镜像
docker pull redis:5.0

实例3:删除redis镜像
docker rmi redis

实例4:删除 redis 5.0 版本的镜像
docker rmi redis:5.0


5、Docker容器命令
容器就是镜像物理文件运行出来的实例
镜像和容器可以理解为"软件"的两种不同状态:下载的"软件"不运行时叫镜像;"软件"运行后变成容器。

查看容器
docker ps # 查看正在运行的容器
docker ps -a # 查看所有创建的容器

(创建容器)运行镜像
docker run -id --name=c1 redis:5.0

+ -i:保持容器运行
+ -d:守护模式(创建的容器在后台运行)
+ -t:分配一个伪终端,通常与-i同时使用
+ –name:为创建的容器命名

点击(此处)折叠或打开

  1. # 进入容器
  2. docker exec -it c1 bash

  3. + c1:容器的名字
  4. + bash:指定容器使用的shell

  5. # 退出容器
  6. exit

  7. # 停止容器
  8. docker stop c1
  9. # 查看容器信息
  10. docker inspect c1

  11. # 删除容器
  12. docker rm c1

  13. # 复制文件到docker中
  14. docker cp text.txt main:/opt/test

实例1:创建一个容器,进入/退出容器后,停止容器

点击(此处)折叠或打开

  1. # 1、查看docker中有没有安装redis镜像(没有则需要下载)
  2. docker images
  3. # 2、查看docker有没有运行redis容器(未运行)
  4. docker ps
  5. # 3、运行redis 5.0版本镜像(创建容器),指定容器名为c1
  6. docker run -id --name=c1 redis:5.0
  7. # 4、查看docker有没有运行redis容器(STATUS字段为Up时,表示运行中)
  8. docker ps
  9. # 5、进入redis容器(指定容器名c1,指定使用的shell为bash)
  10. docker exec -it c1 bash
  11. # 6、退出容器
  12. exit
  13. # 7、停止redis容器(根据容器名c1)
  14. docker stop c1
  15. # 8、查看docker有没有运行redis容器(已停止运行)
  16. docker ps

实例2:删除刚才创建的容器

点击(此处)折叠或打开

  1. # 1、查看已经创建的容器(STATUS字段为Exited时,表示未运行)
  2. docker ps -a
  3. # 2、删除容器(根据容器名c1)
  4. docker rm c1
  5. # 3、再次查看容器,确认已经删除
  6. docker ps -a



Docker容器的重启策略
Docker容器的重启策略是面向生产环境的一个启动策略,在开发过程中可以忽略该策略。
Docker容器的重启都是由Docker守护进程完成的,因此与守护进程息息相关。
Docker容器的重启策略如下:
no,默认策略,在容器退出时不重启容器
on-failure,在容器非正常退出时(退出状态非0),才会重启容器
on-failure:3,在容器非正常退出时重启容器,{BANNED}{BANNED}{BANNED}{BANNED}{BANNED}{BANNED}最佳佳佳佳佳佳多重启3次
always,在容器退出时总是重启容器
unless-stopped,在容器退出时总是重启容器,但是不考虑在Docker守护进程启动时就已经停止了的容器

示例:

点击(此处)折叠或打开

  1. docker run -d --restart=always ba-208
  2. docker run -d --restart=on-failure:10 ba-208

  3. # 查看容器重启次数
  4. docker inspect -f "{{ .RestartCount }}" ba-208
  5. # 查看容器{BANNED}{BANNED}{BANNED}{BANNED}{BANNED}{BANNED}最佳佳佳佳佳佳后一次的启动时间
  6. docker inspect -f "{{ .State.StartedAt }}" ba-208
要停止一个设置为restart=always策略的容器,
可以使用docker update命令将容器的重启策略更改为no,然后使用docker stop来停止容器。
以下是具体步骤的命令:
  1. 更新容器的重启策略为no:
  2. docker update --restart=no <container_name_or_id>
  3. 停止正在运行的容器:
  4. docker stop <container_name_or_id>

六、Docker容器数据卷
数据卷本质上就是文件映射,把容器中的路径映射到宿主机的路径。
比如:把容器的/data目录映射到宿主机的/data目录,容器中的数据发生变化时,宿主机的数据也会同步变化;反之亦然。
数据卷有什么用?
容器数据持久化:即使容器被删除,宿主机中仍然可以保留容器中的数据,
外部机器和容器通信:Docker容器采用沙箱机制隔离,无法直接与外部机器交换文件,配置数据卷后,可以将文件放到宿主机的映射目录下,然后自动同步到容器中。
PS:如果不是很理解,可以做完这一章节的实例后,再回来看一遍。

创建容器时,使用 -v 参数 配置数据卷
docker run -id --name=c1 -v 宿主机目录:容器内目录 redis bash
# 退出容器后,查看挂载的目录
docker inspect -f '{{ .Mounts }}' 容器name

提示:
目录必须是绝对路径
如果目录不存在,会自动创建
实例:创建redis容器时,配置数据卷,观察宿主机中创建的文件,是否会同步到容器内

  1. # 1、创建redis容器,把容器的/root/data目录映射到宿主机的/root/data目录
  2. docker run -id --name=c1 -v /root/data:/root/data redis bash
  3. # 2、在宿主机的映射目录中,创建文件 a.txt
  4. touch /root/data/a.txt
  5. # 3、查看宿主机的文件是否创建成功
  6. ls /root/data
  7. # 4、进入redis容器(根据容器名c1)
  8. docker exec -it c1 bash
  9. # 5、查看容器的映射目录中,是否同步创建了文件a.txt
  10. ls /root/data
  11. # 退出容器后,查看挂载的目录
  12. docker inspect -f '{{ .Mounts }}' tomcat
七、Docker部署应用
在Docker上安装那些常见的应用软件,比如tomcat、mysql等。
Docker上安装应用非常简单,只需要四步:
1. 搜索镜像
2. 拉取镜像
3. 创建容器
4. 操作容器中的应用
举例 : 部署Tomcat

  1. [root@iZ2zegb4fb3y8fmnh5ugxaZ ~]# docker pull tomcat
  2. Using default tag: latest
  3. latest: Pulling from library/tomcat
  4. docker.io/library/tomcat:latest

  5. [root@iZ2zegb4fb3y8fmnh5ugxaZ ~]# docker run -id --name tomcat -p 8888:8080 -v /root/tomcat:/usr/local/tomcat/webapps tomcat
  6. 0925c479e365d89667a774122a208aa74e2f4d35c9c39a5c555a8c5def599727

  7. [root@iZ2zegb4fb3y8fmnh5ugxaZ ~]# docker ps
  8. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  9. 0925c479e365 tomcat "catalina.sh run" 5 seconds ago Up 3 seconds 0.0.0.0:8888->8080/tcp, :::8888->8080/tcp tomcat

  10. [root@iZ2zegb4fb3y8fmnh5ugxaZ ~]# netstat -antp|grep 8888
  11. tcp 0 0 0.0.0.0:8888 0.0.0.0:* LISTEN 14999/docker-proxy
  12. tcp6 0 0 :::8888 :::* LISTEN 15003/docker-proxy
2)创建Tomcat容器,创建容器后,Tomcat服务会自动启动
3)访问Web,,显示404,因为Tomcat容器创建后,webapps目录下没有任何文件
     页面报错:404
4)编写首页文件,创建/root/tomcat/ROOT/index.html文件。
    随便写一个Html文件,报错后,刷新浏览器页面,可以成功展示

docker port 命令可以让我们快捷地查看端口的绑定情况

	
  1. [root@iZ2zegb4fb3y8fmnh5ugxaZ ROOT]# docker port tomcat
  2. 8080/tcp -> 0.0.0.0:8888
  3. 8080/tcp -> [::]:8888

阅读(75) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~