http://karrigell.sourceforge.net/images/karrigell_text.png

::-- ZoomQuiet [2005-06-21 12:22:39]

1. instant_site

最新版本的 Karrigell 提供整站创立支持! 感谢 broader <broader.zhong@gmail.com> 的列表分享!

1 启动karrigell,即直接运行karrigell.py程序
2 在浏览器地址栏输入-》
http://localhost/instant_site/index.ks/index
3 选择app_buzhug,点击ok按钮即可
4 出现以下页面信息
Script app_buzhug.ks generated
Test it
Back to configuration
可以选择Testit,进入下一页面,
login时,用户名:admin,口令:admin

其它若有问题,可看一下程序代码,不是很复杂。

2. 惊奇的调试

:snap-Karrigell-debug.png

3. Livin Leo

:snap-Karrigell-Leo.png

生活在 Leo 中!

哈哈哈!凡是 Pure Python 的站点应用开发,配合Leo 简直太舒服了!

  1. 按照目录分类分层指引文件,自然,习惯;
    • 进一步的,你可以随时按照你自个儿的理解进行进一步的逻辑分类,折叠入中文说明的 headline 中
  2. 随手可以将技术笔记也收集在工程中,方便!
    • 配合 txt2tags 你可以随时获取不同格式的标准输出文档来分享

  3. 使用 @nosent 标记符来声明文档类的树,不用象 @root组织时每页都要加 @c, 省心!

    • 只是小心,这样一来你代码的 Leo 对象树化的信息只存在于 .leo 文档中,一但有任何意外,你将无法对应的从生成的文件中恢复回来
  4. 使用 @thin 标记符来声明脚本的树,不在 .leo 文档中记录代码,以便团队协作时的分享传送

  5. 使用节点的clone 操作,组织各种经常性修改的代码部分在手边,而同时不破坏实际的对象继承设计!

    • 可以看到我将 DB 支持部分的SQL操作字典,统一调用的JS,站点的总帧设计等等部分代码汇集在常用代码 中,随着我编辑的关注中心随时随地的移动,修改,而又没有变动实际的运行脚本——因为它们根本没有从常用代码树的位置输出为真正的文件!

4. 我们的体验

4.1. lv yi ~装在推车里的暴风雪

lv yi <lvscar@gmail.com>

4.2. Moyan的MVC设计

4.3. limodou's Blog文章

收集有关 KarriGell 的资料

::-- limodou [2005-06-22 10:39:55]

有关KarriGell的Blog文章的收集

4.4. Rockety的开发体验

4.5. Zoomq的快乐体验

4.6. 作为服务守护

思路
  • Windows 下面——不用想了,M$不会让你这么玩的…………
  • Uunix 下面——太太自然了,和一切服务一样!伪造成服务类的脚本来启动就好!
  • FreeBSD 环境中
  • # running Karrigell as srv
    echo
    echo "running K!"
    cd /path/to/u/Karrigell
    /usr/local/bin/python Karrigell.py 2>/var/log/K.log &
    echo
    exit  0
    • 标准的输出导向,就可以将Karrigell 丢到后台运行了

    4.6.1. rcNG

    利用FreeBSD 的优秀工具,可以更加标准的管理Karrigell 服务!

    • FreeBSD 扩展应用程序配置 有脚本模板

    • 改进现有启动脚本:runK.sh

      # running Karrigell as srv
      echo
      echo "running K!"
      cd /path/to/Karrigell
      # 使用 daemon 命令来记录运行 pid
      /usr/sbin/daemon -p /var/run/karrigell.pid /usr/local/bin/python Karrigell.py 2>/var/log/K.log &
      echo
      exit  0
    • 创建 rcNG 脚本在 /usr/local/etc/rc.d 中,比如说叫:karrigell.sh

      #
      # PROVIDE: karrigell
      # REQUIRE: DAEMON
      # KEYWORD: shutdown
      
      #
      # DO NOT CHANGE THESE DEFAULT VALUES HERE
      # SET THEM IN THE /etc/rc.conf FILE
      #
      karrigell_enable=${karrigell_enable-"YES"}
      karrigell_flags=${karrigell_flags-""}
      #karrigell_pidfile=${karrigell_pidfile-"/var/run/karrigell.pid"}
      # 奇怪的模板指示,两种声明方式都可以
      karrigell_pidfile="/var/run/karrigell.pid"
      
      . /etc/rc.subr
      
      name="karrigell"
      rcvar=`set_rcvar`
      command="/path/to/u/runK.sh"
      # 因为不是直接运行的进程,所以要给 rc.subr 一点提示,声明真实运行的进程特征
      procname="/usr/local/bin/python"
      
      load_rc_config $name
      
      pidfile="${karrigell_pidfile}"
      
      start_cmd="echo \"Starting ${name}.\"; /usr/bin/nice -5 ${command} ${karrigell_flags} ${command_args}"
      
      run_rc_command "$1"

    最后在  /etc/rc.conf 中追加

    #rc_debug="YES"
    #060421 rcNG Karrigell
    karrigell_enable="YES"
    ## 特别注意BSD 中的语法约定,不能有空格,这里!
    • 唉呀呀!好也!就可以通过

      #/usr/local/etc/rc.d/karrigell start
      #/usr/local/etc/rc.d/karrigell stop
      的标准方式来进行服务管理了

    4.7. ccnusjy的多线程Karrigell 增强

    KarrigellQuickIn (last edited 2009-12-25 07:09:49 by localhost)