Docker入门:快速部署你的第一个Web应用

在云原生时代,Docker已成为标配。根据Stack Overflow的2023开发者调查,超过70%的开发者使用容器技术。 如果你是新手,不妨跟着这篇文章,一步步上手Docker,部署一个简单的Web应用。整个过程只需30分钟!

1. 什么是Docker?为什么它这么火?

Docker是一种轻量级的容器化平台,它允许你将应用及其依赖打包成一个"镜像"(Image),然后在任何支持Docker的环境中运行。简单说,它解决了"在我电脑上跑得好好的,为什么到服务器就出问题了?"的经典痛点。

  • 优势一

    :隔离性强,每个容器独立运行,不会互相干扰。

  • 优势二

    :镜像可复用,一次构建,到处运行。

  • 优势三

    :启动速度快,几秒钟就能上线应用。

想象一下:你用Docker部署一个Node.js应用,只需一个命令,就能让它在本地、云服务器甚至朋友的机器上完美运行。酷毙了!

2. 安装Docker:从零开始

首先,确保你的系统是Windows、macOS或Linux。访问Docker官网下载安装包。

步骤:

  1. 下载与安装

    :选择对应平台的安装程序,一路Next即可。安装后,重启终端。

  2. 验证安装

    :打开命令行,输入docker --version,看到版本号如"Docker version 24.0.7"就成功了!

  3. 运行Hello World

    :输入docker run hello-world,Docker会拉取一个测试镜像并运行,输出欢迎信息。

如果遇到权限问题(Linux用户常见),运行sudo usermod -aG docker $USER并重启终端。

3. 动手实践:构建一个简单Web应用

我们用Python Flask创建一个"Hello World" Web应用,然后用Docker打包部署。

第一步:创建应用代码

新建一个文件夹myapp,里面创建app.py

复制代码
from flask import Flaskapp = Flask(__name__)
@app.route('/')def hello():    return '<h1>Hello, Docker World!</h1>'
if __name__ == '__main__':    app.run(host='0.0.0.0', port=5000)

安装Flask:pip install flask。

本地运行:python app.py,浏览器访问http://localhost:5000,看到标题就OK!

第二步:编写Dockerfile

在myapp文件夹下创建Dockerfile(无扩展名):​​​​​​​

复制代码
# 使用Python官方镜像作为基础FROM python:3.9-slim
# 设置工作目录WORKDIR /app
# 复制requirements.txt(如果有)或直接安装FlaskRUN pip install flask
# 复制应用代码COPY . .
# 暴露端口EXPOSE 5000
# 运行应用CMD ["python", "app.py"]

第三步:构建与运行

  1. 构建镜像:docker build -t my-flask-app .(点表示当前目录)。

  2. 运行容器:docker run -p 5000:5000 my-flask-app(端口映射:主机5000到容器5000)。

浏览器访问http://localhost:5000,你的Docker化应用就上线了!

4. 进阶:推送镜像到Docker Hub

想分享你的镜像?注册Docker Hub账号,然后:

  1. 登录:docker login

  2. 打标签:docker tag my-flask-app yourusername/my-flask-app

  3. 推送:docker push yourusername/my-flask-app

现在,别人也能用docker pull yourusername/my-flask-app拉取你的镜像。团队协作从未如此简单!

结语:Docker,开启你的容器之旅

相关推荐
天河归来2 小时前
本地windows环境升级dify到1.11.1版本
java·spring boot·docker
eason_fan2 小时前
从一则内存快照看iframe泄漏:活跃与Detached状态的回收差异
前端·性能优化
狗头大军之江苏分军2 小时前
年底科技大考:2025 中国前端工程师的 AI 辅助工具实战盘点
java·前端·后端
编程修仙3 小时前
第三篇 Vue路由
前端·javascript·vue.js
么么...3 小时前
在 Ubuntu 上安装 Docker 并部署 MySQL 容器
linux·运维·经验分享·笔记·mysql·ubuntu·docker
比老马还六3 小时前
Bipes项目二次开发/硬件编程-设备连接(七)
前端·javascript
掘金一周3 小时前
前端一行代码生成数千页PDF,dompdf.js新增分页功能| 掘金一周 12.25
前端·javascript·后端
张就是我1065924 小时前
漏洞复现指南:利用 phpinfo() 绕过 HttpOnly Cookie 保护
前端
学Linux的语莫4 小时前
kompose、docker转k8s
docker·容器·kubernetes
Kagol4 小时前
🎉TinyVue v3.27.0 正式发布:增加 Space 新组件,ColorPicker 组件支持线性渐变
前端·vue.js·typescript