设为首页 收藏本站
查看: 979|回复: 0

[经验分享] 使用Pyramid框架构建Python Web应用

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-4-19 21:24:17 | 显示全部楼层 |阅读模式
本帖最后由 e23ewe 于 2014-4-19 21:25 编辑

关于Pyramid框架
在本博另一篇文章“使用Buildout进行开发”中,有讲到使用Buildout来将Pyramid框架集成到Python环境中,并构建一个“helloworld”级别的Python Web应用。
Web框架旨在提供一个快速、简单的方式来跳跃式的开始一个Web应用。几乎每一个框架都遵从MVC软件模式,MVC代表模型(model)、视图(view)和控制器(controller)。这是一种以分辨和分隔应用中的不同功能来简化应用的设计和允许每一个部件的修改完全独立于其他的模式。
Pyramid是一个轻量级的Python应用的web框架,它允许非常快速的拥有你的基本的web应用并运行之。事实上,它能够将所有的框架都放置在单一文件中,只要你喜欢。

使用Pyramid构建web应用
1. 依照本博的另外一篇文章,http://www.yunvn.com/thread-17833-1-1.html,可以创建一个Python的虚拟环境:
#virtualenv --no-site-packages env
#source env/bin/activate

2. 创建项目主目录,并在虚拟环境中安装Pyramid:
#mkdir pyramid_sites
#cd pyramid_sites
#easy_install pyramid
上述命令会将框架需要的所有文件都安装到虚拟环境中。

3. 创建一个helloworld示例项目:
#mkidr hello_world
#cd hello_world
创建应用脚本文件,并添加以下内容:
#vim application.py
from wsgiref.simple_server import make_server
from pyramid.config import Configurator
from pyramid.response import Response
def hello_world(request):   
   return Response('<h1>Hello world!</h1>')
if __name__ == '__main__':   
   config = Configurator()   
   config.add_view(hello_world)   
   app = config.make_wsgi_app()   
   server = make_server('0.0.0.0', 8080, app)   
   server.serve_forever()
注解:
1. import语句部分:make_server函数能够创建一个web服务器,当它运行了一个应用时;Configurator和Response是Pyramid中的函数,这些函数分别被使用来为应用配置细节和设置参数以及对请求作出反应。
2. hello_world函数部分代表了我们应用的一个视图,通过Response函数将请求反应值传送到客户端。
3. 主函数是程序真正执行的地方,通过运行主函数的实例来配置和构建服务器。

保存上述文件,并执行:
#python application.py
通过Web访问helloworld应用:
http://ip:8080
wKioL1NQ3IagJPY9AAApFLI637Q598.jpg

使用Scaffolding构建一个Pyramid应用
在上述示例中,所有的工作都是在一个文件中(application.py)完成,虽然这是一种非常好的方式来展示如何使用Pyramid来压缩和简化构建MVC应用的过程,但这不总是最简单的方法。
与大多数流行框架类似,Pyramid能够使用scaffolding来快速创建一个复杂的项目目录结构。通过pcreate这个工具来使用scaffolding。Wikipedia上关于scaffolding的介绍为:
Scaffolding is a technique supported by some model-view-controller frameworks, in which the programmer may write a specification that describes how the application database may be used. The compiler uses this specification to generate code that the application can use to create, read, update and delete database entries, effectively treating the template as a "scaffold" on which to build a more powerful application.

进入Pyramid主目录下,查看可用的scaffolding:
#cd pyramid_sites
#pcreate -l
Available scaffolds:
alchemy:  Pyramid SQLAlchemy project using url dispatch
starter:  Pyramid starter project
zodb:     Pyramid ZODB project using traversal
注解:
1. alchemy能够使用SQL融合来创建一个项目
2. starter能够创建一个在应用实体之间非持续性的基本项目
3. zodb能够创建一个依靠ZODB来运行的项目

使用starter模板来创建第一个项目:
#pcreate -s starter first_project
#cd first_project
#ls
CHANGES.txt      first_project           MANIFEST.in     README.txt
development.ini  first_project.egg-info  production.ini  setup.py
在该目录下的文件大多是用于配置的,程序本身主要包含在以项目名字命名的一个子目录中

运行setup脚本来配置应用的开发环境:
#python setup.py develop
running develop
running egg_info
writing requirements to first_project.egg-info/requires.txt
writing first_project.egg-info/PKG-INFO
writing top-level names to first_project.egg-info/top_level.txt
writing dependency_links to first_project.egg-info/dependency_links.txt
writing entry points to first_project.egg-info/entry_points.txt
writing requirements to first_project.egg-info/requires.txt
writing first_project.egg-info/PKG-INFO
writing top-level names to first_project.egg-info/top_level.txt
writing dependency_links to first_project.egg-info/dependency_links.txt
writing entry points to first_project.egg-info/entry_points.txt
reading manifest file 'first_project.egg-info/SOURCES.txt'
reading manifest template 'MANIFEST.in'
warning: no files found matching '*.cfg'
......
该命令将使用定义在development.ini中的可用参数来配置你的应用

最后运行你的项目:
#pserve development.ini
Starting server in PID 21251.
serving on http://0.0.0.0:6543
登录http://ip:6543 ,可查看到默认的应用界面

增加调试面板:Pyramid Debug Toolbar,
#vim development.ini
#在[app:main]选项中增加以下语句来使得所有连接到的主机都能够看到调试面板
debugtoolbar.hosts = 0.0.0.0/0
保存并退出,重启服务器可以看到调试面板在右手边
#pserve development.ini



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-17832-1-1.html 上篇帖子: python爬虫学习小程序 下篇帖子: virtualenv创建独立的Python环境
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表