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

从 0 到 1:使用 Docker 部署个人博客系统

引言

在当今数字化时代,拥有一个个人博客来记录自己的学习、生活和见解是一件非常有意义的事情。然而,传统的博客部署方式往往涉及复杂的环境配置和依赖管理,容易让人望而却步。而 Docker 的出现,为我们提供了一种简单、高效的解决方案。本文将结合实际案例,详细介绍如何使用 Docker 部署一个基于 Python Flask 框架的个人博客系统。

案例背景

我们的目标是搭建一个简单的个人博客系统,允许用户发布文章、查看文章列表和文章详情。博客系统采用 Python Flask 框架开发,数据库使用 MySQL。为了确保博客系统在不同环境下的一致性和可移植性,我们将使用 Docker 进行部署。

步骤 1:开发博客系统

1.1 创建项目目录和虚拟环境

首先,创建一个项目目录,并在其中创建一个虚拟环境:

mkdir my-blog
cd my-blog
python3 -m venv venv
source venv/bin/activate

1.2 安装依赖库

pip install flask mysql-connector-python

1.3 编写博客系统代码

创建一个名为 app.py 的文件,编写博客系统的核心代码:

from flask import Flask, render_template, request
import mysql.connector

app = Flask(__name__)

# 连接 MySQL 数据库
mydb = mysql.connector.connect(
    host="localhost",
    user="your_username",
    password="your_password",
    database="blog_db"
)

@app.route('/')
def index():
    cursor = mydb.cursor()
    cursor.execute("SELECT * FROM posts")
    posts = cursor.fetchall()
    return render_template('index.html', posts=posts)

@app.route('/post/<int:post_id>')
def post(post_id):
    cursor = mydb.cursor()
    cursor.execute("SELECT * FROM posts WHERE id = %s", (post_id,))
    post = cursor.fetchone()
    return render_template('post.html', post=post)

@app.route('/add_post', methods=['GET', 'POST'])
def add_post():
    if request.method == 'POST':
        title = request.form['title']
        content = request.form['content']
        cursor = mydb.cursor()
        sql = "INSERT INTO posts (title, content) VALUES (%s, %s)"
        val = (title, content)
        cursor.execute(sql, val)
        mydb.commit()
        return 'Post added successfully!'
    return render_template('add_post.html')

if __name__ == '__main__':
    app.run(debug=True)

1.4 创建模板文件

在项目目录下创建一个名为 templates 的文件夹,并在其中创建 index.html、post.html 和 add_post.html 三个模板文件。以下是 index.html 的示例代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>My Blog</title>
</head>
<body>
    <h1>My Blog</h1>
    {% for post in posts %}
        <h2><a href="/post/{{ post[0] }}">{{ post[1] }}</a></h2>
        <p>{{ post[2] }}</p>
    {% endfor %}
    <a href="/add_post">Add Post</a>
</body>
</html>

步骤 2:创建 Dockerfile

为了将博客系统打包成 Docker 镜像,我们需要创建一个 Dockerfile。在项目目录下创建一个名为 Dockerfile 的文件,并添加以下内容:

# 使用官方的 Python 3.9 镜像作为基础镜像
FROM python:3.9-slim

# 设置工作目录
WORKDIR /app

# 将当前目录下的所有文件复制到容器的 /app 目录下
COPY. /app

# 安装应用所需的依赖
RUN pip install --no-cache-dir -r requirements.txt

# 暴露应用的端口
EXPOSE 5000

# 定义容器启动时执行的命令
CMD ["python", "app.py"]

同时,在项目目录下创建一个名为 requirements.txt 的文件,列出应用所需的依赖库:

flask mysql-connector-python

步骤 3:创建 MySQL 容器

3.1 拉取 MySQL 镜像
使用以下命令从 Docker Hub 拉取 MySQL 镜像:

bash
docker pull mysql:8.0
3.2 运行 MySQL 容器
运行以下命令创建并启动一个 MySQL 容器:

docker run -d --name mysql-container -e MYSQL_ROOT_PASSWORD=your_password -e MYSQL_DATABASE=blog_db -p 3306:3306 mysql:8.0

-d:以守护进程模式运行容器。
–name:为容器指定一个名称。
-e:设置环境变量,这里设置了 MySQL 的 root 密码和数据库名称。
-p:将容器的 3306 端口映射到宿主机的 3306 端口。
3.3 创建数据库表
使用以下命令进入 MySQL 容器的命令行:

docker exec -it mysql-container mysql -uroot -p

输入之前设置的 root 密码,登录到 MySQL 数据库。然后创建一个名为 posts 的表:

USE blog_db;
CREATE TABLE posts (
    id INT AUTO_INCREMENT PRIMARY KEY,
    title VARCHAR(255),
    content TEXT
);

步骤 4:构建并运行博客系统容器

4.1 构建 Docker 镜像

在项目目录下,使用以下命令构建博客系统的 Docker 镜像:

docker build -t my-blog-app.

4.2 运行博客系统容器

运行以下命令创建并启动一个博客系统容器,并将其连接到 MySQL 容器:

docker run -d --name blog-container -p 5000:5000 --link mysql-container:mysql my-blog-app

–link:将博客系统容器连接到 MySQL 容器,并为 MySQL 容器指定一个别名 mysql。

步骤 5:访问博客系统

打开浏览器,访问 http://localhost:5000,你将看到博客系统的首页。现在,你可以发布文章、查看文章列表和文章详情了。

总结

通过使用 Docker,我们成功地将一个基于 Python Flask 框架的个人博客系统部署到了容器中。Docker 的容器化技术使得博客系统的部署变得简单、高效,同时也确保了系统在不同环境下的一致性和可移植性。希望本文能够帮助你快速上手 Docker,并将其应用到实际项目中。

注意事项

  • 在实际生产环境中,建议使用更安全的方式管理 MySQL 的密码,例如使用 Docker 机密(Docker Secrets)。
  • 可以使用 Docker Compose 来管理多个容器的部署,简化部署流程。

The end.


http://www.kler.cn/a/563795.html

相关文章:

  • 【Python爬虫(88)】当Python爬虫邂逅智能硬件:解锁数据新玩法
  • git设置本地代理
  • IO 和NIO有什么区别?
  • 科技项目查新指南:流程要点与材料准备
  • 比较RPC和RESTful API的优缺点
  • 力扣1210. 穿过迷宫的最少移动次数
  • 从0到一实现React Fiber从零到一实现React Fiber
  • 【ESP32S3接入讯飞在线语音识别】
  • 大语言加持的闭环端到端自动驾驶模型 学习笔记纯干货
  • 【C++设计模式】 单例设计模式:重要常用却并非完美之选
  • Cell:临床机器学习在癌症诊断、预后和治疗方面的进展
  • DIALOGPT:大规模生成式预训练用于对话响应生成
  • 奇安信率先使用DeepSeek落地金融行业了
  • ffmpeg avformat_open_input的作用
  • Java+SpringBoot+Vue+数据可视化的音乐推荐与可视化平台(程序+论文+讲解+安装+调试+售后)
  • 新版本的idea用不习惯,怎么还原为之前版本的UI界面?idea界面还原,idea新版本ui设置
  • Qt开发⑦Qt的窗口_上_菜单栏+工具栏+状态栏
  • 剖析IO原理和零拷贝机制
  • Pi-hole v6释出
  • 表单验证和正则表达式