




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、Erlang開發(fā)電信網(wǎng)管項目實踐,Author: Ery Lee Date: December 2008 Email: ,Agenda,About Opengoss Project Road to Erlang The Architecture Erlang Highlights What We Got What We Lost About Erlang Syntax Thinking in Software,About Opengoss Project,Whats Opengoss?,Next Generation Network and Business Management System
2、 One uniform platform based on Linux,Erlang/OTP and ROR Different applications for WIFI, EPON and Enterpise networks,Opengoss Product Family,DMIT, Monet, Evabus, Report, RRDB, WebTopo,Platform,Linux/Unix, MySQL, Oracle, LDAP, Erlang/OTP, Ruby and Rails,Base,N/A,Opengoss Enterprise,Opengoss EPON,Open
3、goss WLAN,NMS,N/A,N/A,N/A,WIMSS,OSS,Internet,Enterprise,EPON-OSS,WIFI-OSS,Future of Opengoss,The Network Management Cloud,Road to Erlang,Pure Java Originally,First Version: Java and JEE Second Version: Java, OSGi, Eclipse, Model-Driven,Java could do everything, but,Java , JSP , JSF, Struts, Webwork,
4、 Velocity , Spring, Hibernate, iBatis, EJB, JDO, JMS, JNDI, JDBC, JAAS, JTA, RMI, IIOP, Web Services, SOAP, SOA, SDO. But, could Java do anything best?,We Had a Big Idea Once,Planned Third Version: OSGI, Component, Plugin, SOA, SDO, SCA,But we have no money and big team.,We are tired of NEW concepts
5、 and frameworks.,SDO, SCA, SOA, ESB, BPML,SOBA. Endless WS-* Documents,Into the Wild,We want to be far away.,“Hello Stranger”,Fall in love with REST, Rails and Erlang ,Why Erlang?,Simplicity Performance Concurrency Distribution Fault Tolerance,The Architecture,Architecture,Trouble Ticket 3rd party,A
6、utomations,SNMP Probe,P,Syslog Probe,P,API,P,Generic,P,Evabus,SNMPMonitor,M,Ping Monitor,M,TCPMonitor,M,OtherMonitor,M,WebPortal (WebTop),DMIT,RRDB,LDAP/MIT,RDMS,Monet,UI,Data,Biz,Collect,Design,Layers,Present Layer: AJAX, Rails Data Center Layer: MySQL, Oracle, RRDB, LDAP Business Layer: DMIT(Distr
7、ibuted MIT), Evabus(Event and Alarm Bus), Monet(Distributed network monitor) Data Collection Layer: Probe, Monitor, Mediator,DMIT,LDAP and Syncrepl,Evabus,Concurrent Event and Alarm Process Line,Monet,Massively distributed network monitor and data collection,Errd,RRDTool Erlang port,Erlang Highlight
8、s,Master/Slave and Pool,Distribution and load balance.,Master Applications,Slave Applications,Sample code: pool,handle_cast(add, Dn, Attrs, State) - Node = pool:get_node(), rpc:call(Node, monet_agent, monitor, Dn, Attrs), ets:insert(mon_entry_table, Dn, Node), noreply, State;,OTP Behaviors,applicati
9、on supervisor gen_server gen_event gen_fsm gen_monitor,Supervisor tree,gen_server: opengoss_mysql,-module(opengoss_mysql). -behaviour(gen_server). -export(insert/2, select/1, select/2, select/3, update/2, update/3, delete/2). . . .,gen_server: opengoss_mysql(cont),opengoss_mysql:select(wifi_mobile_u
10、nits, id, mac, ap_dn, Dn) opengoss_mysql:update(wifi_mobile_units, last_seen, datetime, Now, and, ap_Dn, Dn, in, id, UpdatedIds) opengoss_mysql:delete(wifi_mobile_units, and, ap_Dn, Dn, in, id, DeletedIds);,gen_event: mit_event_h,handle_event(present, Dn, Entry, State) - handle_add_entry(Dn, Entry),
11、 ok, State; handle_event(add, Dn, Entry, State) - handle_add_entry(Dn, Entry), ok, State; handle_event(modify, Dn, Entry, State) - handle_modify_entry(Dn, Entry), ok, State; handle_event(delete, Dn, _Entry, State) - handle_delete_entry(Dn), ok, State;,gen_fsm: eldap_syncrepl,-module(eldap_syncrepl).
12、 -behaviour(gen_fsm). -include(eldap.hrl). -include(ELDAPv3.hrl). -export(init/1, connecting/2, wait_bind_response/2, wait_syncrepl_response/2, handle_event/3, handle_sync_event/4, handle_info/3, terminate/3, code_change/4, close/0).,Other libraries,SNMP Mochiweb Errd Eldap MySQL driver Cron,What We
13、 Got,Productivity,Small team to develop a NMS product 2 Ajax/Html, 2 Rails/DB, 1 Erlang 2 days to coding syncrepl protocol,Performance,1 HP380, 2 CPUs, 4G mem, 8 Cores 1 Oracle, 1 Mysql, 1 OpenLdap, 4 Mongrel, 1 Master, 4Slaves 5 minutes interval 10+ measure items average Collect 200 Switches, 1200
14、Aps, 8000 Interfaces,Concurrency,8000+ collect processes 80 SNMP client 80 PING 30 RRDTools 4 Erlang SNMP Client,Scalability,Massively Distributed Data Collection Scale from 1000+ to 100,000+ Aps Try to resolve IO bottleneck Try to partition data,Stability,Never stop monitor engine Failure Recover H
15、ot code loading,Distribution,Transparent distribution No effort to get master/slave,Happiness,Less code, Less noises More Happiness,Loneliness,No Girls?,What We Lost,Java,Comprehensive matured libraries and frameworks The Java community,Buzzword,No SOA, SCA, SDO, ESB finally.,About Erlang Syntax,Lov
16、e,Function Programming? Pattern match List comprehension,Hate,Ugly If String Support Records,Thinking in Software,Far away from SOA,SOAP Died. WS-* is dying. And then SOA?,OO is over evaluated,The revolution is RDBMS and C Language ,Its just Data,IT was named as Data Processing in enterprise. The data looks li
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 幕墻工程隱裂質(zhì)量通病及防治措施
- 新材料建筑設(shè)計說明范文
- 混凝土冬季施工裂縫防控措施
- 2025屆高三語文課堂筆記優(yōu)化計劃
- 2025信息技術(shù)運營管理學習心得體會
- 高中數(shù)學跨學科教學研究報告范文
- 2025年中小學校長家校溝通能力提升培訓心得體會
- 以歸因理論為翼助力高中文言文教學新突破
- 以客戶為中心:SL律師事務(wù)所服務(wù)滿意度剖析與進階策略
- 倉儲物流培訓及操作流程
- DB37-T5311-2025建筑工程消防設(shè)計文件編制標準
- 成都市高新區(qū)2023年七年級《歷史》下冊期末試卷與參考答案
- 中國上市銀行2024年回顧及未來展望-安永-202505
- TSG Z7002-2022特種設(shè)備檢測機構(gòu)核準規(guī)則
- 裝修售后維修合同協(xié)議
- 2025年數(shù)字經(jīng)濟下的創(chuàng)業(yè)政策調(diào)整策略試題及答案
- 第30課 在線安全防范-2024-2025學年三年級全一冊《信息技術(shù)》教案
- 政治 (道德與法治)八年級下冊自由平等的追求教案
- 山東省濟南市高新區(qū)學卷B2024-2025學年數(shù)學五下期末教學質(zhì)量檢測試題含答案
- 訂單外發(fā)合同協(xié)議
- 山東省2024年藝術(shù)類本科批音樂類第1次志愿投檔情況表(公布)
評論
0/150
提交評論