
在企業(yè)應用開(kāi)發(fā)中,為了提高開(kāi)發(fā)效率,經(jīng)??赡軙?huì )用到一些開(kāi)源的軟件、項目、組件。在使用這些開(kāi)源項目的時(shí)候,必須要先看好其開(kāi)源協(xié)議,免得被Challenge。網(wǎng)上有很多文章介紹各種開(kāi)源協(xié)議以及其進(jìn)行比較的,我就不在此老生常談了,我只說(shuō)是該怎么用。
這里指的企業(yè)應用開(kāi)發(fā),主要是希望實(shí)現盡量閉源以保護自己的知識成果,盡量免費以降低成本。
對于A(yíng)pache Licence、BSD、MIT這幾種協(xié)議的開(kāi)源項目,可以直接基于項目的源代碼進(jìn)行二次開(kāi)發(fā),也可以引用項目編譯出來(lái)的Dll或其他,這些協(xié)議都是對企業(yè)友好的,我們的項目不需要開(kāi)源,不需要付錢(qián)購買(mǎi)許可。只需要在版權聲明文檔中注明原項目的License信息。
對于LGPL,其要求是對源代碼的修改需要開(kāi)源,但是只是引用的話(huà)就可以不用開(kāi)源。所以一般我們直接使用LGPL協(xié)議的程序集,而不使用其源代碼進(jìn)行二次開(kāi)發(fā),比如我們常用使用的NHibernate就是LGPL協(xié)議的,只需要在開(kāi)發(fā)中引用NHibernate程序集就可以了,我們的代碼仍然是閉源的。但是這里有一個(gè)問(wèn)題是,如果現有的LGPL協(xié)議的開(kāi)源項目能夠滿(mǎn)足我們的大部分需求,但是仍然有一小部分需求必須要修改源代碼,或者原項目中有Bug,我們必須要修改源代碼進(jìn)行修正。對于這種必須修改源代碼的情況,我的做法是基于該源代碼,專(zhuān)門(mén)新建一個(gè)項目,在這個(gè)項目中補充我們需要的功能和修復發(fā)現的Bug,然后將這個(gè)項目以L(fǎng)GPL協(xié)議開(kāi)源并將項目編譯好的Dll用于我們的企業(yè)應用開(kāi)發(fā)中。這樣既滿(mǎn)足了我們必須修改源代碼的需求,也保護了我們自己的項目,同時(shí)仍然滿(mǎn)足其協(xié)議的要求。
總之,LGPL協(xié)議主要還是以類(lèi)庫的方式使用,不建議在LGPL協(xié)議的項目上直接進(jìn)行二次開(kāi)發(fā)。在不得已必須修改開(kāi)源項目源代碼時(shí)新建一個(gè)開(kāi)源項目,在該項目上進(jìn)行修改。
MPL也是和LGPL差不多,對于類(lèi)庫的引用是比較友好的,但是要是對源代碼進(jìn)行了二次開(kāi)發(fā),那么修改后的版權就歸原MPL項目的作者了,所以處理方法也是在必須修改源代碼的情況下,新建一個(gè)開(kāi)源項目來(lái)修改,修改好后以類(lèi)庫的形式引用。另外MPL需要對修改之處提供說(shuō)明文檔。
接下來(lái)說(shuō)說(shuō)GPL協(xié)議,這是個(gè)對企業(yè)不友好的協(xié)議,其變態(tài)之處在于,你哪怕是引用了GPL協(xié)議的類(lèi)庫,那么你的項目也必須開(kāi)源。所以在企業(yè)應用中,能不用GPL的就盡量不用GPL的,大家說(shuō)GPL協(xié)議像是病毒,所有使用了GPL項目的新項目都被傳染成了開(kāi)源的GPL項目。所以對于病毒,我們想不被傳染,變成開(kāi)源的GPL項目,處理方法除了盡量避免使用GPL外,如果必須使用,找不到合適的替代產(chǎn)品,那么我們就應該盡量隔離使用GPL項目的那個(gè)模塊。比如我們的項目有10個(gè)模塊,而其中有1個(gè)模塊要使用GPL項目,那么可以盡量把我們的項目拆分成2個(gè)項目,一個(gè)項目是完全閉源的包含9個(gè)模塊的項目,另一個(gè)項目是開(kāi)源的GPL項目。這樣至少可以隔離開(kāi)GPL與我們其他不相關(guān)模塊的代碼,免得被傳染。
另外還有一個(gè)隔離辦法是將GPL項目與閉源項目并列,不存在引用關(guān)系。比如A項目中需要使用到GPL項目B,那么我們可以先建立項目A1,在其中完成我們的核心邏輯處理,然后以閉源的形式發(fā)布A1,接下來(lái)再建立開(kāi)源項目A,A引用了項目A1和B,將這兩個(gè)項目結合起來(lái)完成相應的功能??傊M量減少對GPL項目的使用范圍,做到最低限度的開(kāi)源,滿(mǎn)足企業(yè)應用開(kāi)發(fā)的需要。
PS:所有的開(kāi)源協(xié)議列表:http://www.opensource.org/licenses/alphabetical
聯(lián)系客服