# HelloDjango-blog-tutorial **Repository Path**: randolf/HelloDjango-blog-tutorial ## Basic Information - **Project Name**: HelloDjango-blog-tutorial - **Description**: No description available - **Primary Language**: Unknown - **License**: GPL-3.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-08-05 - **Last Updated**: 2020-12-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README


HelloDjango-blog-tutorial
完全免费、开源的 HelloDjango 系列教程之博客开发
基于 django 2.2,带你从零开始一步步创建属于自己的博客网站。

WeiXin GitHub stars Sina Weibo

**特别说明**:本项目不仅仅是教程用的演示项目!我们的目标是开发一个功能完善、测试充分、可用于生产环境的开源博客系统。和其他开源博客系统不同点在于,我们以教程的形式详细记录项目从 0 到 1 的开发过程。 ## 分支说明 master 分支为项目的主分支,每一步关键功能的开发都对应一篇详细的教程,并和历史提交以及标签一一对应。例如第一篇教程对应第一个 commit,对应标签为 step1,依次类推。 ## 资源列表 - [成品在线预览](https://hellodjango-blog-tutorial-demo.zmrenwu.com/) - 教程首发 HelloGitHub 微信公众号和 [追梦人物的博客](https://www.zmrenwu.com/),在线学习地址:[HelloDjango - Django博客教程(第二版)](https://zmrenwu.com/courses/hellodjango-blog-tutorial/) - 项目 [源码仓库](https://github.com/HelloGitHub-Team/HelloDjango-blog-tutorial) - 项目 [前端模板源码仓库](https://github.com/zmrenwu/django-blog-tutorial-templates) ## 本地运行 可以使用 Virtualenv、Pipenv、Docker 等在本地运行项目,每种方式都只需运行简单的几条命令就可以了。 > **注意:** > > 因为博客全文搜索功能依赖 Elasticsearch 服务,如果使用 Virtualenv 或者 Pipenv 启动项目而不想搭建 Elasticsearch 服务的话,请先设置环境变量 `ENABLE_HAYSTACK_REALTIME_SIGNAL_PROCESSOR=no` 以关闭实时索引,否则无法创建博客文章。如果关闭实时索引,全文搜索功能将不可用。 > > Windows 设置环境变量的方式:`set ENABLE_HAYSTACK_REALTIME_SIGNAL_PROCESSOR=no` > > Linux 或者 macOS:`export ENABLE_HAYSTACK_REALTIME_SIGNAL_PROCESSOR=no` > > 使用 Docker 启动则无需设置,因为会自动启动一个包含 Elasticsearch 服务的 Docker 容器。 无论采用何种方式,先克隆代码到本地: ```bash $ git clone https://github.com/HelloGitHub-Team/HelloDjango-blog-tutorial.git ``` ### Virtualenv 1. 创建虚拟环境并激活虚拟环境,具体方法可参考:[开始进入 django 开发之旅:使用虚拟环境](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/59/#%E4%BD%BF%E7%94%A8%E8%99%9A%E6%8B%9F%E7%8E%AF%E5%A2%83) 2. 安装项目依赖 ```bash $ cd HelloDjango-blog-tutorial $ pip install -r requirements.txt ``` 3. 迁移数据库 ```bash $ python manage.py migrate ``` 4. 创建后台管理员账户 ```bash $ python manage.py createsuperuser ``` 具体请参阅 [创作后台开启,请开始你的表演](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/65/)。 5. 运行开发服务器 ```bash $ python manage.py runserver ``` 6. 浏览器访问 http://127.0.0.1:8000/admin,使用第 4 步创建的管理员账户登录后台发布文章,如何发布文章可参考:[创作后台开启,请开始你的表演](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/65/)。 或者执行 fake 脚本批量生成测试数据: ```bash $ python -m scripts.fake ``` > 批量脚本会清除全部已有数据,包括第 4 步创建的后台管理员账户。脚本会再默认生成一个管理员账户,用户名和密码都是 admin。 9. 浏览器访问:http://127.0.0.1:8000,可进入到博客首页 ### Pipenv 1. 安装 Pipenv(已安装可跳过) ```bash $ pip install pipenv ``` 2. 安装项目依赖 ```bash $ cd HelloDjango-blog-tutorial $ pipenv install --dev ``` 关于如何使用 Pipenv,参阅:[开始进入 django 开发之旅](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/59/) 的 Pipenv 创建和管理虚拟环境部分。 3. 迁移数据库 在项目根目录运行如下命令迁移数据库: ```bash $ pipenv run python manage.py migrate ``` 4. 创建后台管理员账户 在项目根目录运行如下命令创建后台管理员账户 ```bash $ pipenv run python manage.py createsuperuser ``` 具体请参阅 [创作后台开启,请开始你的表演](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/65/)。 5. 运行开发服务器 在项目根目录运行如下命令开启开发服务器: ```bash $ pipenv run python manage.py runserver ``` 6. 浏览器访问 http://127.0.0.1:8000/admin,使用第 4 步创建的管理员账户登录后台发布文章,如何发布文章可参考:[创作后台开启,请开始你的表演](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/65/)。 或者执行 fake 脚本批量生成测试数据: ```bash $ pipenv run python -m scripts.fake ``` > 批量脚本会清除全部已有数据,包括第 4 步创建的后台管理员账户。脚本会再默认生成一个管理员账户,用户名和密码都是 admin。 7. 在浏览器访问:http://127.0.0.1:8000/,可进入到博客首页。 ### Docker 1. 安装 Docker 和 Docker Compose 3. 构建和启动容器 ```bash $ docker-compose -f local.yml build $ docker-compose -f local.yml up ``` 4. 创建后台管理员账户 ```bash $ docker exec -it hellodjango_blog_tutorial_local python manage.py createsuperuser ``` 其中 hellodjango_blog_tutorial_local 为项目预定义容器名。 4. 浏览器访问 http://127.0.0.1:8000/admin,使用第 3 步创建的管理员账户登录后台发布文章,如何发布文章可参考:[创作后台开启,请开始你的表演](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/65/)。 或者执行 fake 脚本批量生成测试数据: ```bash $ docker exec -it hellodjango_blog_tutorial_local python -m scripts.fake ``` > 批量脚本会清除全部已有数据,包括第 3 步创建的后台管理员账户。脚本会再默认生成一个管理员账户,用户名和密码都是 admin。 5. 为 fake 脚本生成的博客文章创建索引,这样就可以使用 Elasticsearch 服务搜索文章 ```bash $ docker exec -it hellodjango_blog_tutorial_local python manage.py rebuild_index ``` > 通过 admin 后台添加的文章会自动创建索引。 6. 在浏览器访问:http://127.0.0.1:8000/,可进入到博客首页。 ### 线上部署 线上部署的详细文档请参考下方教程目录索引中的 **部署篇** 部分,如果不想了解细节或已了解细节,使用 Docker 仅需以下几个简单步骤就可以上线运行: > **小贴士:** > > 国内服务器请设置好镜像加速,否则 Docker 构建容器的过程会非常缓慢!具体可参考 **部署篇** Docker 部署 django 中线上部署部分的内容。 1. 克隆代码到服务器 ```bash $ git clone https://github.com/HelloGitHub-Team/HelloDjango-blog-tutorial.git ``` 2. 创建环境变量文件用于存放项目敏感信息 ```bash $ cd HelloDjango-blog-tutorial $ mkdir .envs $ touch .envs/.production ``` 3. 在 .production 文件写入下面的内容并保存 ``` # django 用于签名和加密等功能的密钥,泄露会严重降低网站的安全性 # 推荐使用这个工具生成:https://miniwebtool.com/django-secret-key-generator/ DJANGO_SECRET_KEY=0p72%e@r3qr$bq%%&bxj#_bem+na2t^0(#((fom6eewrg)gyb^ # 设置 django 启动时加载的配置文件 DJANGO_SETTINGS_MODULE=blogproject.settings.production ``` 4. 修改 Nginx 配置:复制 compose/nginx/hellodjango-blog-tutorial.conf-tmpl 到同一目录,并重命名为 hellodjango-blog-tutorial.conf,修改第 6 行的 server_name 为自己的域名(如果没有域名就改为服务器的公网 ip 地址) 5. 启动容器 ```bash $ docker-compose -f production.yml up --build -d ``` 6. 执行 docker ps 检查容器启动状况,看到如下的 3 个容器说明启动成功: - hellodjango_blog_tutorial_nginx - hellodjango_blog_tutorial_elasticsearch - hellodjango_blog_tutorial 7. 配置 HTTPS 证书(没有配置域名无法配置,只能通过服务器 ip 以 HTTP 协议访问) ```bash $ docker exec -it hellodjango_blog_tutorial_nginx certbot --nginx -n --agree-tos --redirect --email email@hellodjango.com -d hellodjango-blog-tutorial-demo.zmrenwu.com ``` 解释一下各参数的含义: - --nginx,使用 Nginx 插件 - -n 非交互式,否则会弹出询问框 - --redirect,自动配置 Nginx,将所有 http 请求都重定向到 https - --email xxx@xxx.com,替换为自己的 email,用于接收通知 - -d 域名列表,开启 https 的域名,替换为自己的域名,多个域名用逗号分隔 8. 浏览器访问域名或者服务器 ip 即可进入博客首页 ## 教程目录索引 **基础篇** 1. [开始进入 django 开发之旅](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/59/) 2. ["空空如也"的博客应用](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/60/) 3. [创建 Django 博客的数据库模型](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/61/) 4. [Django 迁移、操作数据库](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/62/) 5. [Django 的接客之道](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/63/) 6. [博客从“裸奔”到“有皮肤”](https://www.zmrenwu.com/courseqs/hellodjango-blog-tutorial/materials/64/) 7. [创作后台开启,请开始你的表演](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/65/) 8. [开发博客文章详情页](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/66/) 9. [让博客支持 Markdown 语法和代码高亮](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/67/) 10. [Markdown 文章自动生成目录,提升阅读体验](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/68/) 11. [自动生成文章摘要](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/69/) 12. [页面侧边栏:使用自定义模板标签](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/70/) 13. [分类、归档和标签页](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/71/) 14. [交流的桥梁:评论功能](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/72/) 15. [优化博客功能细节,提升使用体验](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/73/) **部署篇** 16. [Nginx+Gunicorn+Supervisor 部署 Django 博客应用](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/74/) 17. [使用 Fabric 自动化部署](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/75/) 18. [使用 Certbot 向 Let's Encrypt 免费申请 HTTPS 证书](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/76/) 19. [使用 Docker 让部署 Django 项目更加轻松](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/77/) **进阶篇** 20. [开发博客文章阅读量统计功能](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/78/) 21. [Django 官方推荐的姿势:类视图](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/79/) 22. [在脚本中使用 ORM:Faker 批量生成测试数据](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/80/) 23. [通过 Django Pagination 实现简单分页](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/81/) 24. [稳定易用的 Django 分页库,完善分页功能](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/82/) 25. [统计各个分类和标签下的文章数](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/83/) 26. [开启 Django 博客的 RSS 功能](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/84/) 27. [Django 博客实现简单的全文搜索](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/85/) 28. [Django Haystack 全文检索与关键词高亮](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/86/) **测试篇** 29. [单元测试:测试 blog 应用](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/87/) 30. [单元测试:测试评论应用](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/88/) 31. [Coverage.py 统计测试覆盖率](https://www.zmrenwu.com/courses/hellodjango-blog-tutorial/materials/89/) ## 继续学习 有了以上的 django 基础,让我继续学习 [django REST framework 教程](https://www.zmrenwu.com/courses/django-rest-framework-tutorial/) ## 公众号


欢迎关注 HelloGitHub 公众号,获取更多开源项目的资料和内容。

## QQ 群 加入 QQ 群和更多的 django 开发者进行交流: Django学习小组主群:696899473 ## 版权声明 知识共享许可协议
本作品采用署名-非商业性使用-禁止演绎 4.0 国际 进行许可。