docker-compose 服务编排及实战(五)

2024-06-16 10:38

本文主要是介绍docker-compose 服务编排及实战(五),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

docker-compose

  • docker compose 简介和安装
    • 简介
    • 安装 docker compose
  • docker compose 快速体验
  • 创建SpringBoot 项目自测
    • 项目放到容器上测试
    • 查看网络

docker compose 简介和安装

简介

官网:
https://docs.docker.com/compose/

背景:
前面我们使用 Docker 的时候,定义 Dockerfile 文件,然后使用 docker build、docker run 等命令操作容器。然而微服务架构的应用系统一般包含若干个微服务,每个微服务一般都会部署多个实例,如果每个微服务都要手动启停,那么效率之低,维护量之大可想而知。

使用 Docker Compose 可以轻松、高效的管理容器,它是一个用于定义和运行多容器 Docker 的应用程序工具。

官网的定义:
Compose是用于定义和运行多容器Docker应用程序的工具。通过Compose,您可以使用YAML文件来配置应用程序的服务。然后,使用一个命令,就可以从配置中创建并启动所有服务。

Compose的三步最佳实战:

  1. 定义自己应用的 Dockerfile 文件。可以在任何地方构建。
  2. 使用 docker-compose.yml 定义我们的服务。这一整套服务可以一起在一个隔离环境运行。
  3. 运行 docker-compose up 就可以启动整个app。

安装 docker compose

安装

sudo curl -L "https://github.com/docker/compose/releases/download/1.27.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

注意:
官网提供的安装地址非常的慢,不建议使用,用下面的方式安装。截至目前为止,官网最新版是 1.27.4 。

安装

curl -L https://get.daocloud.io/docker/compose/releases/download/1.27.4/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose

分配权限

chmod +x /usr/local/bin/docker-compose

查看信息

docker-compose --version

安装成功

docker compose 快速体验

我们用官网的示例,快速体验一下服务编排。

官方文档示例:
https://docs.docker.com/compose/gettingstarted/

准备工作:
如果要参照官网示例,先安装 python 工具包

sudo yum -y install epel-release
sudo yum install python-pip

安装相关镜像:

docker pull python:3.7-alpine
docker pull redis:alpine

1. 编写程序

创建工程目录

mkdir composetest
cd composetest

vi app.py

import timeimport redis
from flask import Flaskapp = Flask(__name__)
cache = redis.Redis(host='redis', port=6379)def get_hit_count():retries = 5while True:try:return cache.incr('hits')except redis.exceptions.ConnectionError as exc:if retries == 0:raise excretries -= 1time.sleep(0.5)@app.route('/')
def hello():count = get_hit_count()return 'Hello World! I have been seen {} times.\n'.format(count)

vi requirements.txt

flask
redis

2. 编写 Dockerfile

vi Dockerfile

FROM python:3.7-alpine
WORKDIR /code
ENV FLASK_APP=app.py
ENV FLASK_RUN_HOST=0.0.0.0
RUN apk add --no-cache gcc musl-dev linux-headers
COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt
EXPOSE 5000
COPY . .
CMD ["flask", "run"]

3. 编写 docker-compose.yml

version: '3'
services:web:build: .ports:- "5000:5000"redis:image: "redis:alpine"

上面步骤汇总

[root@localhost /]# mkdir composetest
[root@localhost /]# cd composetest/
[root@localhost composetest]# vi app.py
[root@localhost composetest]# vi requirements.txt
[root@localhost composetest]# vi Dockerfile
[root@localhost composetest]# vi docker-compose.yml
[root@localhost composetest]# ls
app.py  docker-compose.yml  Dockerfile  requirements.txt

注意:在复制粘贴时,一定要留意开头第一个英文单词是否完整,因为在 vi 编辑文件,复制进去的内容,开头第一个单词会不完整。

4. 发布

docker-compose up

效果如下:
在这里插入图片描述
总结:
a. 先执行:sudo yum -y install epel-release
b. 再执行:sudo yum install python-pip
c. 再安装两个相关镜像
d. 然后创建项目工程,按步骤创建文件
e. 最后 docker-compose up

需要注意的是,网络环境要很不错,不至于出现下载不了。

创建SpringBoot 项目自测

创建1
创建2
编写 controller:

package cn.com.controller;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RequestMapping("/")
public class controller {@AutowiredRedisTemplate redisTemplate;@GetMapping("hello")public String hello(){Long views = redisTemplate.opsForValue().increment("views");return "welcome to homepage,views" + views;}
}

编写 application.properties:

spring.redis.host=127.0.0.1
#  端口号不写,默认6379
spring.redis.port=6379

启动本地的 redis:
启动
启动 springboot 工程:
启动

项目放到容器上测试

修改 application.properties,host 改为容器名(本地就不能再运行了)。

spring.redis.host=redis
spring.redis.port=6379

新建 dockerfile

FROM java:8COPY *.jar /app.jarCMD ["--server.port=8080"]VOLUME ["/logs"]EXPOSE 8080ENTRYPOINT ["java","-jar","/app.jar"]

新建 docker-compose.yml 文件

官网上查找对应的版本
https://docs.docker.com/compose/compose-file/
官方版本

version: '3.8'
services:springboot-master:build: .ports:- "8080:8080"image: springboot-masterdepends_on:- redisredis:image: "redis:alpine"

打包工程,并上传到服务器
在这里插入图片描述
创建工程文件
在这里插入图片描述
上传文件
上传
启动测试
可以在控制台看出执行步骤

启动
启动
测试成功。
在这里插入图片描述

注意:停止用 ctrl + c,如果用 docker-compose up 启动的话会阻塞控制台,用 docker-compose up -d 后台启动的方式。

docker-compose up --help:查看帮助命令(–help 万能)

查看网络

docker network ls

查看网络
查看网络细节:
语法:docker network inspect network_id
docker network inspect dff079aa02a5

这篇关于docker-compose 服务编排及实战(五)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1066237

相关文章

Python版本信息获取方法详解与实战

《Python版本信息获取方法详解与实战》在Python开发中,获取Python版本号是调试、兼容性检查和版本控制的重要基础操作,本文详细介绍了如何使用sys和platform模块获取Python的主... 目录1. python版本号获取基础2. 使用sys模块获取版本信息2.1 sys模块概述2.1.1

Linux创建服务使用systemctl管理详解

《Linux创建服务使用systemctl管理详解》文章指导在Linux中创建systemd服务,设置文件权限为所有者读写、其他只读,重新加载配置,启动服务并检查状态,确保服务正常运行,关键步骤包括权... 目录创建服务 /usr/lib/systemd/system/设置服务文件权限:所有者读写js,其他

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

Java服务实现开启Debug远程调试

《Java服务实现开启Debug远程调试》文章介绍如何通过JVM参数开启Java服务远程调试,便于在线上排查问题,在IDEA中配置客户端连接,实现无需频繁部署的调试,提升效率... 目录一、背景二、相关图示说明三、具体操作步骤1、服务端配置2、客户端配置总结一、背景日常项目中,通常我们的代码都是部署到远程

docker 重命名镜像的实现方法

《docker重命名镜像的实现方法》在Docker中无法直接重命名镜像,但可通过添加新标签、删除旧镜像后重新拉取/构建,或在DockerCompose中修改配置文件实现名称变更,感兴趣的可以了解一下... 目录使用标签(Tagging)删除旧的php镜像并重新拉取或构建使用docker Compose在Do

docker编写java的jar完整步骤记录

《docker编写java的jar完整步骤记录》在平常的开发工作中,我们经常需要部署项目,开发测试完成后,最关键的一步就是部署,:本文主要介绍docker编写java的jar的相关资料,文中通过代... 目录all-docker/生成Docker打包部署文件配置服务A的Dockerfile (a/Docke

Oracle Scheduler任务故障诊断方法实战指南

《OracleScheduler任务故障诊断方法实战指南》Oracle数据库作为企业级应用中最常用的关系型数据库管理系统之一,偶尔会遇到各种故障和问题,:本文主要介绍OracleSchedul... 目录前言一、故障场景:当定时任务突然“消失”二、基础环境诊断:搭建“全局视角”1. 数据库实例与PDB状态2

Git进行版本控制的实战指南

《Git进行版本控制的实战指南》Git是一种分布式版本控制系统,广泛应用于软件开发中,它可以记录和管理项目的历史修改,并支持多人协作开发,通过Git,开发者可以轻松地跟踪代码变更、合并分支、回退版本等... 目录一、Git核心概念解析二、环境搭建与配置1. 安装Git(Windows示例)2. 基础配置(必

Docker多阶段镜像构建与缓存利用性能优化实践指南

《Docker多阶段镜像构建与缓存利用性能优化实践指南》这篇文章将从原理层面深入解析Docker多阶段构建与缓存机制,结合实际项目示例,说明如何有效利用构建缓存,组织镜像层次,最大化提升构建速度并减少... 目录一、技术背景与应用场景二、核心原理深入分析三、关键 dockerfile 解读3.1 Docke