当前位置: 首页 > article >正文

别再手动配置了!用Docker Compose一键部署你的第一个Web应用(附完整YAML文件)

别再手动配置了用Docker Compose一键部署你的第一个Web应用附完整YAML文件想象一下这样的场景你刚完成了一个简单的Web应用开发准备部署到服务器上。传统方式可能需要手动安装Nginx、配置反向代理、设置环境变量……繁琐的步骤让人望而生畏。而今天我要带你体验一种完全不同的部署方式——只需一个配置文件敲入一行命令你的应用就能自动运行起来。这就是Docker Compose的魅力所在。对于刚接触容器技术的开发者来说Docker Compose就像是一把打开新世界的钥匙。它不仅能帮你摆脱重复配置的烦恼更能让你轻松管理多容器应用的复杂依赖关系。本文将以一个实际的Web应用为例手把手教你编写完整的docker-compose.yml文件体验一键部署的畅快感。1. 环境准备与基础概念在开始之前确保你的系统已经安装了Docker和Docker Compose。可以通过以下命令检查版本docker --version docker-compose --version如果尚未安装可以参考官方文档进行安装。这里假设你已经具备基本的Docker知识了解镜像(Image)和容器(Container)的概念。Docker Compose的核心是一个YAML格式的配置文件它定义了多个容器如何协同工作。与直接使用Docker命令相比Compose有以下优势声明式配置所有服务、网络、卷的定义都在一个文件中一键启停无需记住复杂的docker run参数环境隔离不同项目的配置互不干扰依赖管理自动处理服务间的启动顺序2. 项目结构与基础服务让我们从一个最简单的静态网站开始。假设项目目录结构如下my-webapp/ ├── docker-compose.yml └── html/ └── index.htmlindex.html可以是一个简单的HTML文件!DOCTYPE html html head title我的第一个Docker Compose应用/title /head body h1欢迎使用Docker Compose!/h1 /body /html接下来我们创建docker-compose.yml文件version: 3.8 services: web: image: nginx:alpine ports: - 8080:80 volumes: - ./html:/usr/share/nginx/html这个配置定义了一个名为web的服务使用轻量级的nginx:alpine镜像将主机的8080端口映射到容器的80端口挂载本地html目录到Nginx的默认网站目录启动服务只需运行docker-compose up -d访问http://localhost:8080就能看到你的网站了3. 添加数据库服务现在让我们扩展这个应用加入一个数据库服务。假设我们开发的是一个简单的博客系统需要PostgreSQL数据库。更新后的docker-compose.ymlversion: 3.8 services: web: build: . ports: - 5000:5000 depends_on: - db environment: - DATABASE_URLpostgresql://user:passworddb:5432/blog db: image: postgres:13 environment: - POSTGRES_USERuser - POSTGRES_PASSWORDpassword - POSTGRES_DBblog volumes: - postgres_data:/var/lib/postgresql/data volumes: postgres_data:这个配置有几个关键变化多服务定义现在有两个服务 -web和db构建自定义镜像web服务使用当前目录的Dockerfile构建服务依赖depends_on确保数据库先启动环境变量用于配置数据库连接数据卷持久化数据库数据提示在生产环境中应该使用更安全的方式管理密码如Docker secrets或环境变量文件4. 网络配置与服务发现默认情况下Compose会为你的应用创建一个专用网络服务之间可以通过服务名互相访问。这就是为什么在DATABASE_URL中我们可以直接使用db作为主机名。如果需要更复杂的网络配置可以显式定义networks: app_network: driver: bridge services: web: networks: - app_network db: networks: - app_network这种配置方式特别适合微服务架构你可以隔离不同项目的网络配置自定义网络驱动控制服务间的通信方式5. 生产环境优化建议虽然上面的配置适合开发环境但生产环境需要考虑更多因素。以下是一些优化建议镜像优化使用多阶段构建减小镜像体积选择特定版本标签而非latest定期更新基础镜像# 多阶段构建示例 FROM python:3.9-slim as builder COPY requirements.txt . RUN pip install --user -r requirements.txt FROM python:3.9-slim COPY --frombuilder /root/.local /root/.local COPY . . CMD [python, app.py]资源限制services: web: deploy: resources: limits: cpus: 0.5 memory: 512M健康检查healthcheck: test: [CMD, curl, -f, http://localhost:5000/health] interval: 30s timeout: 10s retries: 36. 常见问题排查即使配置正确有时也会遇到问题。以下是一些常见场景及解决方法服务启动失败docker-compose logs [service_name]端口冲突ports: - 宿主机端口:容器端口卷权限问题volumes: - ./data:/var/lib/mysql:z # SELinux上下文缓存导致构建问题docker-compose build --no-cache7. 进阶技巧当你熟悉基础用法后可以尝试这些进阶功能扩展配置# docker-compose.override.yml services: web: environment: - DEBUG1多环境管理docker-compose -f docker-compose.yml -f docker-compose.prod.yml up变量替换environment: - DATABASE_URL${DB_URL}然后在.env文件中定义DB_URLpostgresql://user:passworddb:5432/blog在实际项目中我发现最实用的技巧是合理组织docker-compose.yml文件结构。将不同服务分模块定义使用YAML的锚点和引用功能可以减少重复配置x-logging: default-logging options: max-size: 10m max-file: 3 services: web: logging: *default-logging db: logging: *default-logging

相关文章:

别再手动配置了!用Docker Compose一键部署你的第一个Web应用(附完整YAML文件)

别再手动配置了!用Docker Compose一键部署你的第一个Web应用(附完整YAML文件) 想象一下这样的场景:你刚完成了一个简单的Web应用开发,准备部署到服务器上。传统方式可能需要手动安装Nginx、配置反向代理、设置环境变量…...

5步精通OpenPose:从环境评估到人体姿态检测全流程

5步精通OpenPose:从环境评估到人体姿态检测全流程 【免费下载链接】openpose 项目地址: https://gitcode.com/gh_mirrors/op/openpose 环境评估:系统兼容性与硬件要求 在开始OpenPose的安装之旅前,需要确保你的系统环境满足以下条件…...

对于对话中的文本简化,OpenClaw 的压缩比和可读性如何平衡?

关于文本简化中压缩比与可读性的平衡,这其实是一个在工程实践中经常遇到的核心矛盾。OpenClaw 的处理方式,仔细推敲起来,背后反映的是一种偏向实用主义的权衡思路。 压缩比高,通常意味着文本被大幅度精简,只保留最核心…...

Fluent Bit源码解析:KISS原则如何打造轻量级日志处理神器

Fluent Bit源码解析:KISS原则如何打造轻量级日志处理神器 【免费下载链接】fluent-bit Fast and Lightweight Logs and Metrics processor for Linux, BSD, OSX and Windows 项目地址: https://gitcode.com/GitHub_Trending/fl/fluent-bit 在当今云原生时代&…...

DLSS Swapper:游戏性能优化的版本管理解决方案

DLSS Swapper:游戏性能优化的版本管理解决方案 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper 在3A游戏日益复杂的图形渲染需求下,玩家常常面临画质与帧率的平衡难题。NVIDIA的DLSS技术通过AI超…...

Z-Image-Turbo-辉夜巫女效果展示:四季主题(春樱/夏祭/秋枫/冬雪)辉夜巫女系列作品

Z-Image-Turbo-辉夜巫女效果展示:四季主题(春樱/夏祭/秋枫/冬雪)辉夜巫女系列作品 1. 模型简介 Z-Image-Turbo-辉夜巫女是基于Z-Image-Turbo模型的Lora版本,专门用于生成具有辉夜巫女风格的艺术图片。这个模型经过特殊训练&…...

Mermaid图表绘制终极指南:用Markdown代码快速创建专业图表

Mermaid图表绘制终极指南:用Markdown代码快速创建专业图表 【免费下载链接】mermaid mermaid-js/mermaid: 是一个用于生成图表和流程图的 Markdown 渲染器,支持多种图表类型和丰富的样式。适合对 Markdown、图表和流程图以及想要使用 Markdown 绘制图表和…...

Visual C++运行时组件故障解决完全指南:从问题定位到能力提升

Visual C运行时组件故障解决完全指南:从问题定位到能力提升 【免费下载链接】vcredist AIO Repack for latest Microsoft Visual C Redistributable Runtimes 项目地址: https://gitcode.com/gh_mirrors/vc/vcredist Visual C运行时组件(Microsof…...

WeKnora镜像免配置教程:支持知识库版本管理与灰度问答切换机制

WeKnora镜像免配置教程:支持知识库版本管理与灰度问答切换机制 1. 引言:告别AI幻觉,让知识问答精准可控 你有没有遇到过这种情况?你给AI看了一份产品说明书,然后问它一个具体参数,结果它回答得头头是道&a…...

Nextcloud Android文件同步革命:实现跨设备无缝数据访问的完整指南 [特殊字符]

Nextcloud Android文件同步革命:实现跨设备无缝数据访问的完整指南 📱 【免费下载链接】android 📱 Nextcloud Android app 项目地址: https://gitcode.com/gh_mirrors/andr/android Nextcloud Android应用是一款功能强大的开源云存储…...

破局与重构:基于“智慧大脑”的企业全面数据化经营深度解构(PPT)

“在数字时代,企业最大的风险不是数据的匮乏,而是决策依然依赖经验直觉而非数据驱动。” —— 这份《数字化建设企业经营解决方案》文档,不仅是一份技术蓝图,更是对传统企业经营管理模式的一次彻底颠覆。它描绘了一个从“人治”迈…...

5个快速排查Goss测试失败的高效调试技巧

5个快速排查Goss测试失败的高效调试技巧 【免费下载链接】goss Goss是一个开源的Go语言测试框架,用于简化Go应用程序的测试和验证。它提供了一系列的测试断言和测试工具,可以帮助开发者编写更加简洁和可维护的测试代码。 项目地址: https://gitcode.co…...

5个颠覆性智能测试提升技巧:Claude Code自动化测试生成全解析

5个颠覆性智能测试提升技巧:Claude Code自动化测试生成全解析 【免费下载链接】claude-code Claude Code is an agentic coding tool that lives in your terminal, understands your codebase, and helps you code faster by executing routine tasks, explaining …...

Windows 10终极清理指南:5步让系统飞起来的完整教程

Windows 10终极清理指南:5步让系统飞起来的完整教程 【免费下载链接】Debloat-Windows-10 A Collection of Scripts Which Disable / Remove Windows 10 Features and Apps 项目地址: https://gitcode.com/gh_mirrors/de/Debloat-Windows-10 你是否感觉Windo…...

3大核心技术构建ESP32智能语音交互系统:从离线唤醒到物联网控制的完整实现方案

3大核心技术构建ESP32智能语音交互系统:从离线唤醒到物联网控制的完整实现方案 【免费下载链接】xiaozhi-esp32 Build your own AI friend 项目地址: https://gitcode.com/GitHub_Trending/xia/xiaozhi-esp32 在物联网和智能硬件快速发展的今天,如…...

5步构建适合你的Yuzu版本管理系统:写给模拟器玩家的效率指南

5步构建适合你的Yuzu版本管理系统:写给模拟器玩家的效率指南 【免费下载链接】yuzu-downloads 项目地址: https://gitcode.com/GitHub_Trending/yu/yuzu-downloads 还在为Yuzu模拟器版本选择而困惑?为什么新游戏在最新版模拟器上反而卡顿&#x…...

终极Ponzu数据迁移指南:快速掌握内容导入导出和批量操作技巧

终极Ponzu数据迁移指南:快速掌握内容导入导出和批量操作技巧 【免费下载链接】ponzu Headless CMS with automatic JSON API. Featuring auto-HTTPS from Lets Encrypt, HTTP/2 Server Push, and flexible server framework written in Go. 项目地址: https://git…...

Python量化投资数据接口实战指南:通达信数据获取与策略开发全流程

Python量化投资数据接口实战指南:通达信数据获取与策略开发全流程 【免费下载链接】mootdx 通达信数据读取的一个简便使用封装 项目地址: https://gitcode.com/GitHub_Trending/mo/mootdx 在量化投资领域,数据获取的效率与质量直接决定了策略的有…...

Video2X:让你的老旧视频焕发新生的AI魔法工具

Video2X:让你的老旧视频焕发新生的AI魔法工具 【免费下载链接】video2x A lossless video/GIF/image upscaler achieved with waifu2x, Anime4K, SRMD and RealSR. Started in Hack the Valley II, 2018. 项目地址: https://gitcode.com/GitHub_Trending/vi/video…...

开源工具OptiScaler:突破显卡限制的跨平台上采样解决方案

开源工具OptiScaler:突破显卡限制的跨平台上采样解决方案 【免费下载链接】OptiScaler DLSS replacement for AMD/Intel/Nvidia cards with multiple upscalers (XeSS/FSR2/DLSS) 项目地址: https://gitcode.com/GitHub_Trending/op/OptiScaler OptiScaler是…...

高效解决消息撤回问题的RevokeMsgPatcher完整指南

高效解决消息撤回问题的RevokeMsgPatcher完整指南 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址: https://gitcode.com/GitHub_Trendi…...

微信数据库密钥自动获取:从手动繁琐到一键提取的技术革新

微信数据库密钥自动获取:从手动繁琐到一键提取的技术革新 【免费下载链接】PyWxDump 获取微信账号信息(昵称/账号/手机/邮箱/数据库密钥/wxid);PC微信数据库读取、解密脚本;聊天记录查看工具;聊天记录导出为html(包含语音图片)。支…...

GoAccess源码深度解析:从main函数到核心模块调用链的完整指南

GoAccess源码深度解析:从main函数到核心模块调用链的完整指南 【免费下载链接】goaccess allinurl/goaccess: 是一个开源的 Web 日志分析工具,用于分析访问日志并生成报告。它可以帮助开发者快速了解网站流量、访问者等信息,优化网站性能。特…...

特征选择新思路:Laplacian Score与PCA/Lasso对比实验报告

特征选择方法深度对比:Laplacian Score在真实数据集中的突围表现 当面对高维数据时,特征选择就像是在嘈杂的市场中寻找真正有价值的声音。传统的PCA和Lasso方法已经服务了我们多年,但Laplacian Score带来的图论视角正在悄然改变游戏规则。本文…...

AI专著生成速达秘籍:高性价比工具剖析,助力快速创作

创新是学术专著所需的核心元素,也是写作的一道高门槛。一部合格的学术专著,不能仅仅是对已有研究成果的机械拼凑,而应当展示贯穿全书的独特见解、理论模型或研究方法。在浩如烟海的学术文献中,识别尚未探索的研究空白并不是一件容…...

Faster-Whisper架构解析:基于CTranslate2的高性能语音识别优化方案

Faster-Whisper架构解析:基于CTranslate2的高性能语音识别优化方案 【免费下载链接】faster-whisper plotly/plotly.js: 是一个用于创建交互式图形和数据可视化的 JavaScript 库。适合在需要创建交互式图形和数据可视化的网页中使用。特点是提供了一种简单、易用的 …...

PyTorch模型参数与元数据安全存储:safetensors实战解析

1. 为什么需要safetensors存储模型参数? 在深度学习项目中,模型参数的保存和加载是最基础也最频繁的操作。传统PyTorch开发者习惯使用torch.save和torch.load这对黄金组合,直到某天我在分布式训练集群上遇到了一个诡异的问题:一个…...

JavaScript快速入门:10个基础概念让你轻松掌握编程核心

JavaScript快速入门:10个基础概念让你轻松掌握编程核心 【免费下载链接】You-Dont-Know-JS 📗📒 (PT-Br translation) JS Book Series. 项目地址: https://gitcode.com/gh_mirrors/you/You-Dont-Know-JS JavaScript作为现代Web开发的基…...

【限时解密】某汽车Tier1工厂拒绝公开的Python网关冗余切换配置——双网口+心跳检测+自动故障转移(含Wireshark抓包验证截图)

第一章:工业Python网关冗余架构设计背景与合规边界在现代工业自动化系统中,Python因其丰富的生态、快速迭代能力及对OPC UA、Modbus、MQTT等协议的成熟支持,正被广泛用于边缘网关开发。然而,将通用编程语言应用于高可用性&#xf…...

噪声系数测试中的Y因子:为什么ENR超噪比是你的关键指标?

噪声系数测试中的Y因子:为什么ENR超噪比是你的关键指标? 在无线通信系统的设计与验证中,噪声系数(Noise Figure)是衡量接收机灵敏度的核心参数之一。而Y因子法作为噪声系数测试的黄金标准,其准确度很大程度…...