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编写一个功能强大的端口扫描器脚本,实现快速扫描目标主机的开放端口和服务,感兴趣的小伙伴可以了解下... 目录功能介绍场景应用1. 网络安全审计2. 系统管理维护3. 网络故障排查4. 合规性检查报错处理1.

python项目打包成docker容器镜像的两种方法实现

《python项目打包成docker容器镜像的两种方法实现》本文介绍两种将Python项目打包为Docker镜像的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目录简单版:(一次成功,后续下载对应的软件依赖)第一步:肯定是构建dockerfile,如下:第二步

Python + Streamlit项目部署方案超详细教程(非Docker版)

《Python+Streamlit项目部署方案超详细教程(非Docker版)》Streamlit是一款强大的Python框架,专为机器学习及数据可视化打造,:本文主要介绍Python+St... 目录一、针对 Alibaba Cloud linux/Centos 系统的完整部署方案1. 服务器基础配置(阿里

Java 队列Queue从原理到实战指南

《Java队列Queue从原理到实战指南》本文介绍了Java中队列(Queue)的底层实现、常见方法及其区别,通过LinkedList和ArrayDeque的实现,以及循环队列的概念,展示了如何高效... 目录一、队列的认识队列的底层与集合框架常见的队列方法插入元素方法对比(add和offer)移除元素方法

Spring Boot基于 JWT 优化 Spring Security 无状态登录实战指南

《SpringBoot基于JWT优化SpringSecurity无状态登录实战指南》本文介绍如何使用JWT优化SpringSecurity实现无状态登录,提高接口安全性,并通过实际操作步骤... 目录Spring Boot 实战:基于 JWT 优化 Spring Security 无状态登录一、先搞懂:为什

C++11中的包装器实战案例

《C++11中的包装器实战案例》本文给大家介绍C++11中的包装器实战案例,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录引言1.std::function1.1.什么是std::function1.2.核心用法1.2.1.包装普通函数1.2.

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

Spring IOC核心原理详解与运用实战教程

《SpringIOC核心原理详解与运用实战教程》本文详细解析了SpringIOC容器的核心原理,包括BeanFactory体系、依赖注入机制、循环依赖解决和三级缓存机制,同时,介绍了SpringBo... 目录1. Spring IOC核心原理深度解析1.1 BeanFactory体系与内部结构1.1.1

nacos服务无法注册到nacos服务中心问题及解决

《nacos服务无法注册到nacos服务中心问题及解决》本文详细描述了在Linux服务器上使用Tomcat启动Java程序时,服务无法注册到Nacos的排查过程,通过一系列排查步骤,发现问题出在Tom... 目录简介依赖异常情况排查断点调试原因解决NacosRegisterOnWar结果总结简介1、程序在

Redis 命令详解与实战案例

《Redis命令详解与实战案例》本文详细介绍了Redis的基础知识、核心数据结构与命令、高级功能与命令、最佳实践与性能优化,以及实战应用场景,通过实战案例,展示了如何使用Redis构建高性能应用系统... 目录Redis 命令详解与实战案例一、Redis 基础介绍二、Redis 核心数据结构与命令1. 字符