PythonAnyWhere免费部署python类网站

步骤:

在执行部署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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏LeeCen

React Native 环境搭建

9210
来自专栏杂烩

katalon中REST URL占位参数动态化

REST URL中占位参数很常见,但是在测试中就会带来一些麻烦,比如ab中URL是死的,不能变化的,而在katalon中则可以很轻松的处理这个问题。

9720
来自专栏JavaEdge

ReactJS从零打造企业级电商后台管理系统之通用组件部分的开发

21340
来自专栏张善友的专栏

Node.js入门学习笔记-IDE选择/配置之WebStorm(windows)

Node.js是什么?! http://www.ibm.com/developerworks/cn/opensource/os-nodejs/index.htm...

36970
来自专栏Samego开发资源

Chrome扩展开发入门体验

23140
来自专栏Java技术分享

1.第一个SpringBoot应用和项目属性配置

SpringBoot和SpringMVC的区别 SpringBoot的特点:     1.简化配置     2.微服务的入门级微框架 此文章学习目标如...

35070
来自专栏SAP梦心的SAP分享

对.net 程序进行源码混淆

还是那个一卡通的程序,这几天做了一点更新。 因为里面涉及到对数据库的链接,含IP地址和账户密码,一旦被反编译窃取,则源码泄露不说,也给服务器带来一定的风险! 下...

25390
来自专栏Youngxj

emlog SVG分类导航插件

14530
来自专栏葡萄城控件技术团队

渐进式Web应用(PWA)入门教程(下)

渐进式Web应用程序需要使用HTTPS连接。虽然使用HTTPS会让您服务器的开销变多,但使用HTTPS可以让您的网站变得更安全,HTTPS网站在Google上的...

11400
来自专栏云计算教程系列

在CentOS上用Caddy安装WordPress

WordPress是一个以PHP和MySQL为平台的自由开源的博客软件和内容管理系统。WordPress具有插件架构和模板系统。Alexa排行前100万的网站中...

1K40

扫码关注云+社区

领取腾讯云代金券