到现在,关于CERL的故事终于看起来慢慢多起来了:
之前我们已经谈到C++做高性能的服务器,然后PHP或Python作为前端,将服务展现给客户。这是一种比较正常的逻辑。今天的内容可能稍微偏门一点,谈谈基于CERL,用PHP或Python来做服务器。这在一定程度上有意义的,如果你原先就已经写了基于PHP或者Python的服务的话(或者服务本身的性能要求不高,而你更喜欢PHP或Python)。
用PHP写的HashServer(这个例子貌似我们举了很多次了)如下:
<?php define('HashSever_put', 1); define('HashSever_get', 2); if (!extension_loaded('php_cerl')) { if (!dl('php_cerl.' . PHP_SHLIB_SUFFIX)) die("ERROR: Cannot load php_cerl library!\n"); } if (!cerl_bind('localhost:8889')) die("ERROR: Bind failed!\n"); cerl_thread_init(); cerl_register('HashServer'); echo "HashServer (port:8889) starting ... ok!\n"; for (;;) { $mail = cerl_receive(); list($fid, $args) = $mail->decode(); echo "\nreceived: $fid - "; foreach ($args as $arg) echo "$arg "; if ($fid == HashSever_put) { list($key, $value) = $args; $dict[$key] = $value; $mail->reply(code_ok); } else if ($fid == HashSever_get) { list($key) = $args; @$value = $dict[$key]; if (isset($value)) $mail->reply(code_ok, $value); else $mail->reply(code_false); } else { $mail->default_handle(); } } cerl_thread_term(); ?>
用Python写的HashServer看起来是这样的:
HashSever_put = 1 HashSever_get = 2 import sys, pycerl if not pycerl.bind("localhost:8889"): print "ERROR: Bind failed!" else: pycerl.thread_init() pycerl.register("HashServer") print "HashServer (port:8889) starting ... ok!" dict = {} while True: mail = pycerl.receive() (fid, args) = mail.decode() print "received:", fid, "-", args if fid == HashSever_put: (key, value) = args dict[key] = value mail.reply(pycerl.code_ok) elif fid == HashSever_get: (key,) = args if key in dict: mail.reply(pycerl.code_ok, dict[key]) else: mail.reply(pycerl.code_false) else: mail.default_handle() pycerl.thread_term()
我们目前已经实现了3个语言的HashServer服务器(C++,PHP,Python),对应地也写了3个语言的HashClient。需要指出的是,这些HashServer和HashClient可以任意搭配使用,你可以想象这里面可以有9种可能。:) 当然多少种可能并不重要,重要的是,语言之间的隔阂消除了。以前你可能想的是,如何让C与Python交互,C与PHP交互,但是却很少会涉及Python与PHP交互。而CERL打破了这个界限。
当然,你可能会说,一些RPC(如DCOM、ICE等等)也致力于消除语言的隔阂。没错。不过关于这方面的对比,我始终要卖一个关子,要等到“CN Erlounge IV”上作详细的阐述。关于本次大会的详细内容,参阅:http://blog.youkuaiyun.com/xushiweizh/archive/2009/08/09/4428977.aspx