【docker简介】

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【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 -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
相关文章
|
8月前
|
Java Go 开发者
Docker容器技术简介及其与Go语言的结合点
【2月更文挑战第23天】本文首先概述了Docker容器技术的核心概念和优势,接着探讨了Go语言与Docker容器技术的结合点。通过阐述Docker的轻量级、可移植性和版本控制等特性,以及Go语言在容器化应用中的优势,本文旨在说明两者结合能够实现更高效、灵活的应用开发和部署。
|
SQL 关系型数据库 数据库
SQL Server 简介与 Docker Compose 部署
SQL Server 是由微软公司开发的一款强大的关系型数据库管理系统(RDBMS),广泛应用于企业级应用程序和数据存储。使用 Docker Compose,您可以轻松地将 SQL Server 实例部署到容器化环境中,并方便地进行数据库管理。在本文中,我将简要介绍 SQL Server 的基本概念,并详细阐述如何使用 Docker Compose 部署 SQL Server 容器。
478 2
SQL Server 简介与 Docker Compose 部署
|
Docker 容器
01Docker简介
01Docker简介
55 0
|
4月前
|
存储 Linux Docker
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
关于如何在CentOS 7.6上安装Docker、介绍Docker存储引擎以及服务进程关系的实战案例。
221 3
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
|
4月前
|
存储 Unix 虚拟化
Docker容器简介
Docker是一种轻量级的虚拟化技术,它通过容器化应用,提高了硬件资源利用率,简化了应用的部署、运输和运行,且与虚拟机相比,具有更快的交付速度和更低的资源消耗。
71 2
|
6月前
|
存储 Linux 虚拟化
docker 简介
docker 简介
62 6
|
6月前
|
Java Linux 虚拟化
docker(一):docker简介
docker(一):docker简介
51 1
|
Oracle 关系型数据库 数据库
Oracle 简介与 Docker Compose部署
Oracle 数据库是一款由 Oracle 公司开发的关系型数据库管理系统(RDBMS)。它被广泛应用于企业级应用程序,提供了可靠的数据存储和强大的数据管理功能。
509 1
Oracle 简介与 Docker Compose部署
|
8月前
|
Linux 应用服务中间件 nginx
docker 网络简介
docker 网络简介
|
8月前
|
Java 虚拟化 Docker
Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别
Docker简介及用途,为什么要使用Docker?Docker容器和虚拟机的区别

热门文章

最新文章