关于docker:Mu教程系列Docker一初识

42次阅读

共计 3530 个字符,预计需要花费 9 分钟才能阅读完成。

Docker 基本概念

Windows 装置 Docker

  • 下载
  • 注册

关上 CMDPowershell就能够欢快的游玩 Docker 了

Ubuntu 装置 Docker

// Ubuntu 自带 docker.io 源
sudo apt install docker.io -y

常用命令

// 根本
docker version // 查看版本详情
docker -v      // 查看版本简略版

// 搜寻
docker search ubuntu

// 拉取
docker pull ubuntu:latest // tag:最新版
docker images             // 查看本地镜像

// 创立(相似装置零碎)
docker run -it -p 8080:8080 ubuntu /bin/bash  // -it 示意关上并放弃 stdout,并调配一个终端(pseudo-tty)docker run -d -p 80:80 --name [myname] nginx

// 退出
exit                     // 容器敞开,状态为:Exit
快捷键 ctrl+p ctrl+q     // 后盾运行,状态为:Up
docker ps -a             // 查看状态

// 操作容器
docker start CONTAINERID              // 启动
docker stop CONTAINERID               // 进行
docker restart CONTAINERID            // 重启
docker attach CONTAINERID             // 进入
docker exec -it CONTAINERID /bin/bash // 进入(如创立时未 it)// 提交镜像到本地仓库
docker commit -m "msg" -a "Author" CONTAINERID 用户名 / 仓库名:tag

// 删除镜像
docker rm CONTAINERID  // 必须先删除所有容器
docker rmi IMAGESID    // 接着删除镜像

// 提交镜像到 hub
docker push 用户名 / 仓库名:tag

Dockerfile 罕用参数

FROM        // 指定构建镜像的根底源镜像
MAINTAINER  // 维护者的信息
RUN         // 在以后镜像根底上执行指定命令
CMD         // 启动容器时提供一个默认的命令执行选项
EXPOSE      // 服务端容器对外映射的本地端口
ENV         // 指定一个环节变量,会被后续 RUN 指令应用,并在容器运行时保留
ADD         // 复制本地主机文件、目录或者近程文件 URLS 从并且增加到容器指定门路中,反对正则含糊匹配
COPY        // 复制新文件或者目录从并且增加到容器指定门路中 
VOLUME      // 创立一个能够从本地主机或其余容器挂载的挂载点
WORKDIR     // 为后续的 RUN、CMD、ENTRYPOINT 指令配置工作目录。能够使  用多个 WORKDIR 指令,后续命令如果参数是相对路径,则会基于之前命令指  定的门路

// 构建镜像
docker build -t name 目录 // 当前目录用 `.` 示意

WSL 相干问题

关上PowerShell, 运行:

ubuntu config --default-user root  // 默认 root 登录

// 进入 ubuntu 零碎,设置默认连贯 windows 的守护过程
vi ~/.bashrc                               // 关上
export DOCKER_HOST=tcp://127.0.0.1:2375    // 最初一行增加
source ~/.bashrc                           // 运行下

docker-compose.yml 罕用参数

version: "3"
services:
  web:                              # 自定义服务名叫 web
    image: username/repo:tag
    deploy:
      replicas: 5                   # 运行 5 个实例作为一个服务
      resources:
        limits:
          cpus: "0.1"               # 每个实例最多应用 10%CPU
          memory: 50M               # 每个实例最多应用 50MB 的 RAM
      restart_policy:
        condition: on-failure       # 如果容器出错,立刻重启
    ports:
      - "4000:80"
    networks:
      - webnet                      # 负载平衡网络
networks:
  webnet:

Swarm 常用命令

// 根本
docker swarm init                                // 初始化 swarm
docker stack deploy -c docker-compose.yml name   // 部署新堆栈或更新现有堆栈

docker stack ls                                 // 列呈现有堆栈
docker service ls                               // 查看服务
docker service ps name                          // 查看实例
docker container ls -q                          // 查看所有容器 id
docker stack rm name                            // 退出程序
docker swarm leave --force                      // 退出 swarm
systemctl restart docker                        // 重启 swarm

应用 UI 工具 – Portainer

# 初始化 swarm 集群  
docker swarm init --advertise-addr [IP 地址] 

# 创立 portainer 挂载目录
mkdir -p /home/portainer

# 以 swarm service 建设 portainer 治理 
docker service create \
--name portainer \
--publish 9000:9000 \
--replicas=1 \
--constraint 'node.role == manager' \
--mount type=bind,src=//var/run/docker.sock,dst=/var/run/docker.sock \
--mount type=bind,src=//home/portainer,dst=/data \
portainer/portainer-ce \
-H unix:///var/run/docker.sock

应用阿里云镜像库

# 登陆
docker login --username=master@bingblue.com registry.cn-shanghai.aliyuncs.com

# 提交
docker tag [ImageId] registry.cn-shanghai.aliyuncs.com/bingblue/[镜像名]:[镜像版本号]
docker push registry.cn-shanghai.aliyuncs.com/bingblue/[镜像名]:[镜像版本号]

Docker images 版本辨别

  • alpine: linux 发行版, 只有 5M, 简直无软件仓库反对
  • stretch: Debian 9 的代号,2017 年发行
  • jessie: Debian 8 的代号,2015 年发行
  • wheezy: Debian 7 的代号,2013 年发行
  • slim: 瘦身版, 比方 xxx-jessie-slim 就是基于 jessie 的瘦身版
  • perl: nginx 反对 perl 模块的版本
  • mainline: nginx 目前主力在做的版本, 能够说是开发版
  • stable: 稳定版
  • chakracore: 基于 Edge 浏览器的 ChakraCore 引擎的 node 版本

总结:举荐应用alpine,其次举荐slim

实战:我的项目部署

一、编写 docker-compose.yml 文件

version: '3.6'
services:
  # nginx 略...
  # mysql 略...
  # xbjh_admin 略...
  # xbjh 略...
networks:
  bingblue:
    driver: overlay
    ipam:
      driver: default
      config:
        - subnet: 10.88.0.0/16

而后上传到服务器,目录/root/yml/docker-compose.yml

二、部署

# 初始化 Swarm 集群
docker swarm init --advertise-addr [IP 地址]

# 创立目录
mkdir nginx             // 并在此目录下上传 Nginx 配置文件 default.conf
mkdir mysql
mkdir xbjh_admin
mkdir xbjh_admin/file
mkdir xbjh_admin/log

# 登陆阿里云公有库账号
docker login --username=master@bingblue.com registry.cn-shanghai.aliyuncs.com

# 进入 yml 目录
cd /root/yml

# 部署新堆栈或更新现有堆栈
docker stack deploy -c docker-compose.yml [堆栈名称] --with-registry-auth

三、我的项目更新

# 批改 docker-compose.yml 并上传
cd /root/yml

# 更新现有堆栈
docker stack deploy -c docker-compose.yml xbjh --with-registry-auth

# 独自重启某个 Service
docker service update --force [Service ID]

四、注意事项

  • ✅ 记得阿里云配置平安组入方向规定
  • ✅ 配置 HTTPS 和 CDN 时要设置: 协定追随回源

正文完
 0