Fork me on GitHub

在OpenShift上托管web.py应用

一、背景

最近在学习web.py,跟随官网的cookbookcode examples一路敲敲打打,在本地访问了无数遍http://0.0.0.0:8080/,也算是对web.py有了基本的认识。为了加强动手实践,我决定自己写一个简单的web.py应用;为了让这个web.py应用能够真正运行在互联网上,我决定将其托管到一个AppEngine(应用引擎)中去。

目前可供选择的AppEngine有很多,国内的有:百度的BAE、新浪的SAE、阿里的ACE,国外的有:Google的GAE、Redhat的OpenShift,等等。这些AppEngine我都没有用过,自然无权评价它们孰优孰劣,网上关于这些AppEngine的比较有不少。目前为止,这些AppEngine都要收费,虽然SAE申请开发者认证后可以勉强使用,但是申请步骤个人觉得很繁琐。

我选择OpenShift的理由很直接:它在提供收费业务的同时,也支持免费使用(尽管免费服务有一些限制:只能创建三个 app,提供 1.5G 内存和 3G 存储空间,但完全满足我当前的需求),并且操作简单

二、注册帐号

进入OpenShift注册页面,填写邮箱和密码完成注册,收到邮件后点击链接激活帐号即可。

三、创建应用

OpenShift提供了“Web控制台”和“命令行”两种方式来创建应用。

1、Web控制台(web console)

进入管理后台,按照界面提示操作即可,主要有以下几步:

  • 点击“创建应用(Create Application)”属性页
  • 选择应用的Web编程语言(Choose a type of application)
  • 填写“Public URL”中的应用名(Application name)和域名(Domain name)
  • 使用附加功能(数据库、持续构建等)

具体操作在Redhat OpenShift 云计算平台试用小记中有很好的讲解,推荐参考。

2、命令行(command line)

1)安装RHC工具

$ sudo apt-get install ruby rubygems
$ sudo gem install rhc

注意:如果“sudo gem install rhc”命令长时间无响应(可能是自动下载gem包有问题),可以到gems包中心搜索并下载rhc包后,采取本地安装

$ sudo gem install rhc-1.10.7.gem -l

如果安装过程中有依赖,可以根据错误提示到gems包中心逐一搜索并下载,本地安装依赖包(安装命令同rhc,如果又有依赖,递归处理)完毕后,再安装rhc。

2)初始配置

$ rhc setup

3)创建web.py应用

Python Application Hosting中给出了OpenShift支持的Python应用。如果想创建web.py应用,选择Web2Py,其中的openshiftwebpy应用很好地展示了“OpenShift中web.py应用的基本框架”。这里以openshiftwebpy应用为例给出创建web.py应用的命令:

$ rhc app create -a openshiftwebpy -t python-2.6

四、提交应用

在OpenShift中提交应用的一般方法可以参考Deploying and Building Applications,具体到openshiftwebpy应用可以参考README.md

1、安装Git

$ sudo apt-get install git

2、提交代码

1)git下载

git下载,也就是将git仓库中的应用下载到本地,具体到openshiftwebpy应用,命令如下:

$ git clone ssh://51e76ffce0b8cd263d000024@openshiftwebpy-russellluo.rhcloud.com/~/git/openshiftwebpy.git/ openshiftwebppy

其中,形如“ssh://.../~git/openshiftwebpy.git/”的字符串为“Git URL”,可以通过“rhc app show openshiftwebpy”命令获得。

如果使用“命令行”创建应用,则会自动进行git下载;只有使用“Web控制台”创建应用时,才需要执行上述命令手动进行git下载

注意:如果“git clone”命令失败,通常跟SSH有关,解决方法如下:

$ rhc app delete openshiftwebppy    # 慎用此命令:它会删除与应用相关的所有内容,注意备份
$ rhc app create openshiftwebppy python-2.6
$ ssh-keygen -f ~/.ssh/id_rsa -t rsa    # 重新创建ssh key
$ ssh-add ~/.ssh/id_rsa    # 更新本地的ssh私钥
$ rhc sshkey remove -i default    # 删除OpenShift上名为"default"的key(如果有)
$ rhc sshkey add -i default -k ~/.ssh/id_rsa.pub    # 添加ssh公钥(名为"default")到OpenShift

2)修改代码

$ cd openshiftwebpy
$ git remote add upstream -m master git://github.com/openshift/openshiftwebpy.git
$ git pull -s recursive -X theirs upstream master

3)git提交

$ git push

五、访问应用

访问应用主页http://openshiftwebpy-russellluo.rhcloud.com/(如果被GFW了,可以尝试https://openshiftwebpy-russellluo.rhcloud.com/)

 

关于在OpenShift上托管web.py应用,本文只介绍了最基本的操作,诸如数据库、调试、构建等高级主题可以进一步参考Python Application Hosting或者Developer Center

posted on 2013-07-18 13:45  RussellLuo  阅读(1730)  评论(0编辑  收藏  举报

导航