首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >PythonAnyWhere免费部署python类网站

PythonAnyWhere免费部署python类网站

作者头像
晓歌
发布2018-08-15 12:43:42
7.2K0
发布2018-08-15 12:43:42
举报
文章被收录于专栏:破晓之歌破晓之歌

步骤:

在执行部署Django网站之前,应该先处理好前期工作,比如对settings.py文件进行设置以防止私密信息泄露等。本文只是简单的笔记,原文地址为:https://tutorial.djangogirls....

1, 将Django项目发布到GitHub

2, 申请免费的PythonAnyWhere账号

网址:https://www.pythonanywhere.com/ 免费的账号只能建一个站。站名只能为XXX.pythonanywhere.com。其中XXX代表注册账户时所用的用户名。站点只能维持2个月,2个月后就会被删除。

3, 将GitHub上的项目发送至PythonAnyWhere

3.1 在PythonAnyWhere中,点击 “Consoles” –> start a “Bash” console 这个Bash是类似于Linux系统里的“终端”。 3.2 在这个新建的Bash里面输入: 注意:如下代码表示需要在PythonAnyWhere的Bash中执行!!

$ git clone https://github.com/<your-github-username>/my-first-blog.git

这个步骤将GitHub的项目发送到PythonAnyWhere。注意上面的这个链接就是GitHub里项目的仓库地址:

Bash的响应非常慢,需要耐心等候。 发送完成后可以使用下面的代码来看被复制到PythonAnyWhere的文件目录结构,需要强调的是,这个my-first-blog即为GitHub里的仓库的项目名字。 注意:如下代码表示需要在PythonAnyWhere的Bash中执行!!

tree my-first-blog

4, 为PythonAnyWhere里的项目创建virtual environment

继续在PythonAnyWhere的Bash里执行下面的命令,以创建一个名为myvenv的虚拟环境。 注意:如下代码表示需要在PythonAnyWhere的Bash中执行!!

$ cd my-first-blog
$ virtualenv --python=python3.5 myvenv
$ source myvenv/bin/activate
(myvenv) $ pip install django==1.10.0

上面的python和django版本号仅供参考!

5, 为PythonAnyWhere里的项目创建数据库并创建超级账户

注意:如下代码表示需要在PythonAnyWhere的Bash中执行!!

(myvenv) $ python manage.py migrate
(myvenv) $ python manage.py createsuperuser

6, 将Django项目作为Web App发布

到这里,我们的Django项目已经在PythonAnyWhere上了,虚拟环境也准备好了,数据库也创建好了,此时就可以将它作为Web App发布了!在PythonAnyWhere里,点击 “Web”选项卡 -> 点击 “Add a new web app” -> 确认域名 -> 选择manual configuration(注意不是选择“Django”哦) -> 选择Python3.5 -> 点击Next以最终完成向导。

7, 配置Web App的虚拟环境

创建好了Web App之后,PythonAnyWhere就会将你带到该Web App的配置界面,点击Virtualenv下面红色的字体来编辑虚拟环境的位置,如下图所示:

将地址修改为:

/home/<你的PythonAnyWhere的账户名>/my-first-blog/myvenv

注意:上面的my-first-blog为GitHub里的项目的仓库地址。 注意:上面的myvenv是该创建的虚拟环境的名字

8, 配置PythonAnyWhere里的WSGI文件

仍然是在Web选项卡,点击WSGI configuration file后面的蓝色字体连接(如下图所示)。  PythonAnyWhere将带我们到一个新的页面(一个代码编辑器),将编辑器的代码全部用下面的代码替换。

import os
import sys

path = '/home/<你的PythonAnyWhere用户名>/my-first-blog'  # 在这里使用你自己的用户名和GitHub项目的名字。
if path not in sys.path:
    sys.path.append(path)

os.environ['DJANGO_SETTINGS_MODULE'] = 'mysite.settings' # 在这里mysite请用settings所在文件夹名,我用的是和GitHub仓库名一样的名字
from django.core.wsgi import get_wsgi_application
from django.contrib.staticfiles.handlers import StaticFilesHandler
application = StaticFilesHandler(get_wsgi_application())

点击 “Save” -> 返回Web选项卡 -> 点击大大的绿色按钮“Reload”。此时我们就可以通过Web选项卡上提供的地址(也就是XXX.pythonanywhere.com)访问了!这样我们的网站就真正在互联网上存在了,虽然只有两个月的有效期:-(

9, Debug

在配置过程中,难免会出错导致站点无法成功发布。首先应该:

  • 查看出错页面显示的error log
  • 查看Web选项卡页面有无任何错误提示 常见的错误包括:
  • 在PythonAnyWhere的Bash漏了创建virtualenv,激活它,给它安装Django,给它初始化数据库
  • 第7步设置虚拟环境的路径是时有错误
  • 第8步配置WSGI时有错误,是否填入正确的path了呢?
  • 安装虚拟环境时选择的Python版本和创建Web App时选择的Python是否都是同一版本?

10, 如何将GitHub里项目的修改反馈到PythonAnyWhere?

项目又要修改的时候,通常是在本地计算机修改,修改好之后发布到GitHub,之后发布到PythonAnyWhere。当GitHub里项目修改好之后,在PythonAnyWhere的Bash里面输入下面两行代码就可以同步了: 注意:如下代码表示需要在PythonAnyWhere的Bash中执行!!

cd my-first-blog
git pull
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017/12/11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 步骤:
    • 1, 将Django项目发布到GitHub
      • 2, 申请免费的PythonAnyWhere账号
        • 3, 将GitHub上的项目发送至PythonAnyWhere
          • 4, 为PythonAnyWhere里的项目创建virtual environment
            • 5, 为PythonAnyWhere里的项目创建数据库并创建超级账户
              • 6, 将Django项目作为Web App发布
                • 7, 配置Web App的虚拟环境
                  • 8, 配置PythonAnyWhere里的WSGI文件
                    • 9, Debug
                      • 10, 如何将GitHub里项目的修改反馈到PythonAnyWhere?
                      领券
                      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档