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

[经验分享] Windows7(32bit)用Firefly创建第一个示例

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-12-18 08:37:20 | 显示全部楼层 |阅读模式
安装完成Firefly之后,在python script包(即Scripts文件夹)中就存在 firefly-admin的工具。

创建第一个工程

打开命令行窗口,运行如下命令:

firefly-admin.py createproject chat_rooms

这样就创建好了chat_rooms的工程,工程目录结构如下:(后补充,今天晚上无法上传图片!)

注意到chat_rooms文件夹下存在一个文件startmaster.py,它正是工程的启动模块,建立工程后可以直接启动startmaster.py进行测试。

方法是以管理员方式启动并进行CMD窗口,然后运行如下命令:

python startmaster.py

第一次运行时,出现类似于下面的运行错误:
import os,sys,affinity
  File "build\bdist.win32\egg\affinity\__init__.py", line 15, in <module>
  File "build\bdist.win32\egg\affinity\__init__.py", line 15, in <module>
ImportError: No module named win32api
ImportError: No module named win32api
估计是没有安装pywin32所致。于是,下载并运行pywin32-218.win32-py2.7.exe。再运行上面的程序即OK。出现类似如下的等待状态。

C:\Python27\Scripts\chat_rooms>python startmaster.py
2014-12-17 22:03:15+0800 [-] Log opened.
2014-12-17 22:03:15+0800 [-] DelaySite starting on 9998
2014-12-17 22:03:15+0800 [-] Starting factory <firefly.web.delayrequest.DelaySite instance at 0x02953AF8>
2014-12-17 22:03:15+0800 [-] BilateralFactory starting on 9999
2014-12-17 22:03:15+0800 [-] Starting factory <firefly.distributed.root.BilateralFactory instance at 0x0295
2014-12-17 22:03:16+0800 [-] Log opened.
2014-12-17 22:03:16+0800 [-] Starting factory <twisted.spread.pb.PBClientFactory instance at 0x02A79468>
2014-12-17 22:03:16+0800 [-] Log opened.
2014-12-17 22:03:16+0800 [-] gate start...
2014-12-17 22:03:16+0800 [-] gate pid: 2712
2014-12-17 22:03:16+0800 [-] Starting factory <twisted.spread.pb.PBClientFactory instance at 0x02A09378>
2014-12-17 22:03:16+0800 [-] net start...
2014-12-17 22:03:16+0800 [-] net pid: 10700
2014-12-17 22:03:16+0800 [BilateralBroker,0,127.0.0.1] node [gate] takeProxy ready
2014-12-17 22:03:16+0800 [BilateralBroker,1,127.0.0.1] node [net] takeProxy ready

再以管理员方式启动并进行CMD窗口,然后运行如下命令:
python clienttest.py

此时,当前窗口(上面这个CMD)处于等待状态。上面第一个CMD窗口(SERVER)出现类似如下提示信息:
2014-12-17 22:31:31+0800 [firefly.netconnect.protoc.LiberateFactory] Client 1 login in.[127.0.0.1,42321]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
2014-12-17 22:31:31+0800 [LiberateProtocol,1,127.0.0.1] call method echo_1 on service[single]
......

这说明客户端与服务器端通信正常。

注意:clienttest.py文件位于tool目录下。

另外,config.json是用来描述服务端整体架构的配置文件(目前我没有作任何修改),可以在文件中配置添加新的服务进程,描述各个服务进程的连接结构。以及数据库配置和memcached缓存服务配置。


根据Firefly官方文档,app包中就是用来服务器逻辑的地方,app包中的apptest.py提供了测试服务器的处理方式。
于是,再启动一个CMD窗口,运行如下命令:
python apptest.py

可是出现如下错误提示:
Traceback (most recent call last):
  File "apptest.py", line 5, in <module>
    @netserviceHandle
  File "C:\Python27\lib\site-packages\firefly-1.3.3dev_r0-py2.7.egg\firefly\server\globalobject.py", line 40, in netserviceHandle
    GlobalObject().netfactory.service.mapTarget(target)
AttributeError: 'NoneType' object has no attribute 'service'
网络搜索一下,没有发现恰当答案,先等等再说吧。反正这个拦路虎是迟早要解决掉的.....

运维网声明 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-38215-1-1.html 上篇帖子: Thinkpad X230 32位window7 换 64位windows7 下篇帖子: win8系统玩一会就变的很卡啊?很卡很卡!过一会就好了,这是怎么回事?
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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