docker

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: docker

docker-compose:docker开源项目


1.定义:

   docker容器的编排工具:定义和运行多个相关联的容器(单台dockerhost上) ,简单理解:可以同时管理(增、删、改、查等)多个容器。但没有资源管理功能,需要k8s。


   官网文档地址: https://docs.docker.com/compose/overview/


    docker镜像在创建之后,往往需要自己手动pull来获取镜像,然后执行run命令来运行。当服务需要用到多种容器,容器之间又产生了各种依赖和连接的时候,部署一个服务的手动操作是令人感到十分厌烦的。


    docker-compose技术,就是通过一个 .yml 配置文件,将所有的容器的部署方法、文件映射、容器连接等等一系列的配置写在一个配置文件里,最后只需要执行docker-compose up命令就会像执行脚本一样的去一个个安装容器并自动部署他们,极大的便利了复杂服务的部署。


2.定位:

   定义和运行多个docker容器的应用,同时可以对多个容器进行编排


3.核心概念

   服务(service):一个应用的容器,服务可以存在多个

   项目(project):由一组关联的容器组成的一个完整业务单元,在“docker-compose.yml”中定义。


==========================================


###### 官方在线安装:


curl -L "https://github.com/docker/compose/releases/download/1.28.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
//验证已有docker-compose命令
docker-compose -v
//设置tab键的空格距离。
vim /root/.vimrc 
set tabstop=2
source /root/.vimrc

##### 一.docker-compose的配置文件实例


通过识别一个docker-compose.yml的配置文件,去管理容器。


vim docker-compose.yml
version: '3.2'
services:
  nginx:
    restart: always
    image: nginx:latest
    container_name: web-nginx
    ports:
      - 90:80
    volumes:
      - ./webserver:/usr/share/nginx/html

第一个部分: version: 指定语法格式的版本。


第二部分:service:定义服务,(想要运行什么样的容器)


----------------------------------

nginx:                //服务的名称 
container_name: web-nginx   //容器名称,相当于docker  run  --name 
image: nginx:latest        //使用的镜像 
restart: always     //随开机自启
ports:              //端口映射,相当于docker run  -p
  - 90:80
volumes:    //持久化挂载,相当于docker run -v
command:    //容器执行命令,相当于docker file 里的CMD
networks:    //定义网络,相当于docker run --network


------------------------------------


//运行docker-compose规定的容器,
PS:在执行这条命令的当前目录下,也需要有一个docker-compose.yml的配置文件,并且通常只有一个。
docker-compose up
PS:  docker-compose  up  之后,会显示都做了什么操作,并占用终端, 如果想要退出终端占用,加-d  选项。
//保持后台运行
docker-compose up -d 
//停止运行
docker-compose stop 
//重启
docker-compose restart

并且,在运行container的过程中,还可以支持Dockerfile


vim Dockerfile 
FROM nginx 
COPY ./webserver/index.html /usr/share/nginx/html/index.html
//修改docker-compose.yaml文件
version: '3.2'
services:
  nginx:
    build: .
    restart: always
    image: nginx-web:v1.0
    container_name: test-web
    ports:
      - 91:80
//运行docker-compose命令的时候,如果文件内有Dockerfile,可以提前 执行:docker-compose build  或者在up -d 的时候添加--build  选项。
docker-compose up -d  --build


##### 二.docker-compose管理命令介绍


1、compose具有管理应用程序整个生命周期的命令


启动,停止和重建服务

查看正在运行的服务的状态

流式传输运行服务的日志输出

在服务上运行一次性命令


2、常用命令

**#帮助信息** 
docker-compose --help
**#用来创建或重新创建服务使用的镜像** 
docker-compose build
**#用于通过容器发送SIGKILL信号强行停止服务** 
docker-compose kill nginx


PS:  kill  服务名称,默认所有服务


**#显示service的日志信息**
docker-compose logs
**#暂停和恢复服务**
docker-compose pause
docker-compose pause    #暂停服务
docker-compose unpause  #恢复被暂停的服务
**#用于查看服务中的端口与物理机的映射关系**
docker-compose port nginx 80

例如:docker-compose port nginx_web 80  #查看服务中80端口映射到物 理机上的那个端口


**#用于显示当前项目下的容器** 
docker-compose ps

注意,此命令与docker ps不同作用,此命令会显示停止后的容器(状态为 Exited),只针对某个项目。


**#用于拉取服务依赖的镜像** 
docker-compose pull
**#用于重启某个服务中的所有容器** 
docker-compose restart

例如:docker-compose restart service_name  #只有正在运行的服务可以 使用重启命令,停止的服务是不可以重启


**#删除停止的服务(服务里的容器)** 
docker-compose rm
-f    #强制删除
-v    #删除与容器相关的卷(volumes)
**#用于在服务中运行一个一次性的命令** 
docker-compose run nginx ls /

这个命令会新建一个容器,它的配置和service的配置相同。但两者之间还是有两点不同之处

1、run指定的命令会直接覆盖掉service配置中指定的命令

2、run命令启动的容器不会创建在service配置中指定的端口,如果需要指定使用--service-ports指定

**#启动/停止运行某个服务的所有容器** 
docker-compose start/stop
docker-compose start 启动运行某个服务的所有容器
docker-compose stop 停止运行某个服务的所有容器
**#指定某个服务启动的容器个数** 
vim docker-compose.yml 
version: '3.2'
services:
  nginx:
    restart: always
    image: nginx:latest
    ports:
      - 80
    volumes:
      - ./webserver:/usr/share/nginx/html
docker-compose scale nginx=2

PS: 如果需要运行多个容器,那么容器名称就不要给了,会随机生成,还有注意端口映射问题,不要冲突(docker-compose    port  字段支持仅写 一个容器暴露的端口)。


备注:

docker-compose 运行时是需要指定service名称,可以同时指定多个,也可以不指定。不指定时默认就是对配置文件中所有的service执行命令。

-f    #用于指定配置文件

-p    #用于指定项目名称


##### **三.搭建wordpress的博客**


官方文档地址:https://docs.docker.com/compose/wordpress/


按照官方文档创建一个目录,并且编辑docker-compose.yml文件,文件内容如下:


docker-compose.yml
version: '3.2'
services:
   db:
     image: mysql:5.7
     volumes:
       - db_data:/var/lib/mysql
     restart: always
     environment:
       MYSQL_ROOT_PASSWORD: somewordpress
       MYSQL_DATABASE: wordpress
       MYSQL_USER: wordpress
       MYSQL_PASSWORD: wordpress
   wordpress:
     depends_on:
       - db
     image: wordpress:latest
     ports:
       - "8000:80"
     restart: always
     environment:
       WORDPRESS_DB_HOST: db:3306
       WORDPRESS_DB_USER: wordpress
       WORDPRESS_DB_PASSWORD: wordpress
       WORDPRESS_DB_NAME: wordpress
volumes:
  db_data: 
docker-compose up -d


PS:如果没有对应的mysql和wordpress镜像,docker会自动从中央仓库下载,这里我们因为网络原因会给大家下载好的镜像,请同学们自行导入到本地。


##### 四.**docker-compose中添加应用网络**


yaml文件中使用已有网络。


docker network create --driver bridge --subnet 172.22.16.0/24 --gateway 172.22.16.1 demo1
vim docker-compose.yaml
version: '3'
services:
  nginx:
    container_name: web-nginx11
    image: nginx
    restart: always
    ports:
      - 99:80
    networks:
      demo1:
        ipv4_address: 172.22.16.23
networks:
  demo1:
    external: true


PS: external该部分表示使用外部网络demo,外部为true。


docker-compose up -d


docker inspect web-nginx 查看容器内网络是否成功分配。



作业:docker-compose文件内自定义网络


version: "3"
networks:
  test-net:
    driver: bridge
    ipam:
      config:
      - subnet: 172.46.1.0/24
services:
  nginx:
    container_name: web2
    restart: always
    image: nginx:latest
    ports:
     - 92:80
    networks:
      test-net:
        ipv4_address: 172.46.1.2
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
运维 NoSQL Redis
Docker-基本了解
Docker-基本了解
84 3
|
存储 监控 开发者
Docker详解,你知道的和不知道的都在这儿
@[TOC](目录) Docker 是一个开源的容器化平台,允许开发者将应用程序和所有其依赖项打包成一个轻量级、可移植的容器,以便在任何地方运行。Docker 采用了 Linux Namespace 和 cgroups 等技术,实现了高度的资源隔离和安全保障,使得容器化应用得以快速、高效地部署和运行。 本文将详细介绍 Docker 的架构、原理和应用,包括以下内容: 1. Docker 的架构和原理 2. Docker 的安装和使用 3. Docker 的基本命令和操作 4. Docker 的容器管理 5. Docker 的网络管理 6. Docker 的存储管理 7.
158 0
|
6月前
|
运维 持续交付 Docker
在Docker中,Docker可以用来做什么?
在Docker中,Docker可以用来做什么?
|
8月前
|
Java Linux 虚拟化
|
数据可视化 应用服务中间件 nginx
|
存储 关系型数据库 Linux
|
Linux 测试技术 API
【Docker】Docker最近这么火,它到底是什么
【Docker】Docker最近这么火,它到底是什么
|
Kubernetes Linux 持续交付
什么是Docker?
什么是Docker?
148 0
|
Linux 测试技术 API
【Docker】什么是Docker,它用来干什么
【Docker】什么是Docker,它用来干什么
377 0
|
Ubuntu NoSQL Linux
了解和理解Docker的使用
Docker背景 Docker技术是基于Linux容器 虚拟容器技术的 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。 Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的
174 0
了解和理解Docker的使用