(以前寫的一篇文章)
最近一直在關(guān)注ICE(
http://www.zeroc.com/),不得不說其功能的強大,我主要看重幾個點:
1.多語言支持,C++,Java,C#,Objective-C,Python,Ruby,PHP。
2.高級RPC,同時支持同步調(diào)用和異步調(diào)用,由于RPC是在ICE框架環(huán)境下運行的,所以穩(wěn)定性和可靠性可以保證。在服務(wù)端內(nèi)部使用會非常方便,比如將ICE前置在數(shù)據(jù)庫之上,所有對數(shù)據(jù)庫的訪問方式就成了RPC
3.對分布式系統(tǒng)的支持-ICEGrid,涵蓋了負載均衡,位置服務(wù),計算節(jié)點“需要時啟動”等眾多特性,更多內(nèi)容可以參考幫助文檔(http://www.zeroc.com/doc/index.html)。簡單提一下“需要時啟動”,就是說某個client調(diào)用了節(jié)點Node1,如果Node1此時沒有啟動,則ICE負責(zé)將他啟動,這個過程對client來說是透明的。 假如計算節(jié)點的邏輯上存在bug,觸發(fā)bug會引起節(jié)點退出。通常的做法是自己寫一些監(jiān)控程序,如果發(fā)現(xiàn)節(jié)點不在了重啟動,利用ICEGrid后,就避免了這個問題
4.提供了基于發(fā)布-訂閱機制的消息組建ICEStorm
上面只是我關(guān)注的幾點,更多的功能特性,請參考幫助文檔! 下面以python作為web的開發(fā)后端,來調(diào)用python寫的ICE服務(wù),注意ICE服務(wù)可以是其他語言編寫的,這個例子是修改的ICE提供的demo(D:\libs\Ice-3.3.1\demopy\book\printer),主要的功能是
(1)client通過瀏覽器打開某個python頁面
(2) python頁面調(diào)用ICE基礎(chǔ)服務(wù)
(3)python頁面將結(jié)果通過瀏覽器返回給client
一。接口文件Printer.ice內(nèi)容如下:
#ifndef SIMPLE_ICE
#define SIMPLE_ICE
module Demo
{
interface Printer
{
string echo(string s);
};
};
#endif
二。Server.py內(nèi)容如下:
import sys,traceback,Ice
Ice.loadSlice(’Printer.ice’)
import Demo
class PrinterI(Demo.Printer):
def echo(self, s, current=None):
print s
return s
status = 0
ice = None
try:
ic = Ice.initialize(sys.argv)
adapter = ic.createObjectAdapterWithEndpoints(”SimplePrinterAdapter”, “default -p 10000″)
object = PrinterI()
adapter.add(object, ic.stringToIdentity(”SimplePrinter”))
adapter.activate()
ic.waitForShutdown()
except:
traceback.print_exc()
status = 1
if ic:
# Clean up
try:
ic.destroy()
except:
traceback.print_exec()
status = 1
sys.exit(status)
三。echo.psp內(nèi)容如下:
<%
import sys, traceback, Ice
import Demo
status = 0
ice = None
try:
ic = Ice.initialize(sys.argv)
base = ic.stringToProxy(”SimplePrinter:default -p 10000″)
printer = Demo.PrinterPrx.checkedCast(base)
if not printer:
raise RuntimeError(”Invalid proxy”)
sEcho = printer.echo(”Hello ICE!”)
print sEcho
except:
traceback.print_exc()
status = 1
if ic:
# Clean up
try:
ic.destroy()
except:
traceback.print_exc()
status = 1
%>
<%=sEcho%>
四。運行過程:
1.啟動ICE服務(wù):python Server.py
2.啟動Apache
3.瀏覽器中輸入http://localhost:8080/echo.psp
4.此時瀏覽器中顯示:Hello ICE!