-
apache
(Apache軟件基金會)
鎖定
Apache軟件基金會(Apache Software Foundation,簡稱 ASF)是專門為運作一個開源軟件項目的 Apache 的團體提供支持的非盈利性組織,這個開源軟件的項目就是 Apache 項目。
- 中文名
- Apache軟件基金會
- 外文名
- Apache Software Foundation
- 簡 稱
- ASF
- 創辦時間
- 1999年
- 創建者
- “Apache 組織”羣體
- 作 用
- 為運作一個開源軟件項目的Apache的團體提供支持的非盈利性組織
apache基金會簡介
Apache軟件基金會(也就是Apache Software Foundation,),是專門為運作一個開源軟件項目的 Apache 的團體提供支持的非盈利性組織,這個開源軟件項目就是 Apache 項目。這個組織把自己作為有着相同目標的開發者與用户的團體,而不是簡單的共享在一個服務器上的一組項目的組織團體。在它所支持的 Apache 項目與子項目中,所發行的軟件產品都遵循 Apache許可證(Apache License)。
Apache軟件基金會(ASF)的前身起源於一個從事服務器開發與維護的“Apache 組織”。這個“Apache 組織”在1999年以前就已經存在很長時間了,這個組織的開發愛好者們聚集在一起,在美國伊利諾斯大學超級計算機應用程序國家中心(National Center for Supercomputing Applications,簡稱為NCSA)開發的 NCSA HTTPd 服務器的基礎上開發與維護了一個叫 Apache 的 HTTP服務器。
最初 NCSA HTTPd 服務器是由 Rob McCool 開發出來的,但是它的最初開發者們逐漸對這個軟件失去了興趣,並轉移到了其他地方,造成了沒有人來對這個服務器軟件提供更多的技術支持。因為這個服務器的功能又如此強大,而代碼可以自由下載修改與發佈,當時這個服務器軟件的一些愛好者與用户開始自發起來,互相交流並分發自己修正後的軟件版本,並不斷改善其功能。為了更好進行溝通,Brian Behlendorf 自己建立了一個郵件列表,把它作為這個羣體(或者社區)交流技術、維護軟件的一個媒介,把代碼重寫與維護的工作有效組織起來。這些開發者們逐漸地把他們這個羣體稱為“Apache 組織”,把這個經過不斷修正並改善的服務器軟件命名為 Apache 服務器(Apache Server)。
這個命名是根據北美當地的一支印第安部落而來,這支部落以高超的軍事素養和超人的忍耐力着稱,19世紀後半期對侵佔他們領土的入侵者進行了反抗。為了對這支印第安部落表示敬仰之意,取該部落名稱(Apache)作為服務器名。但一提到這個命名,這裏還有流傳着一段有意思的故事。因為這個服務器是在 NCSA HTTPd 服務器的基礎之上,通過眾人努力,不斷地修正、打補丁(Patchy)的產物,被戲稱為“A Patchy Server”(一個補丁服務器)。在這裏,因為“Patchy”與“Apache”是諧音,故最後正式命名為“Apache Server”。
後來由於商業需求的不斷擴大,以 Apache HTTP 服務器為中心,啓動了更多的與 Apache 項目並行的項目,比如mod_ perl、PHP、Java Apache等等。隨着時間的推移、形勢的變化,Apache軟件基金會的項目列表也不斷更新變化中--不斷的有新項目啓動,項目的中止以及項目的拆分與合併。比如一開始,Jakarta 就是為了發展 JAVA 容器而啓動的 Java Apache 項目,後來由於太陽公司(SUN)的建議,項目名稱變為 Jakarta 。但當時該項目的管理者也沒有想到 Jakarta 項目因為 JAVA 的火爆而發展到如今一個囊括了眾多基於 JAVA 語言開源軟件子項目的項目。以至後來,不得不把個別項目從 Jakarta 中獨立出來,成為 Apache軟件基金會的頂級項目,Struts 項目就是其中之一。
最近,為了避免 SCO 與 UNIX 開源社區之間的發生糾紛降臨在 Apache 軟件基金會(ASF)身上。Apache軟件基金會(ASF)裏面開始採取一些措施,讓眾多的項目進行更多協調的、結構化管理,並保護自己的合法利益,避免一些潛在的合乎法律的侵犯(potential legal attacks)。
由於Apache軟件基金會在開源服務器技術上的卓越貢獻,榮獲了著名IT雜誌SD Times頒發的2013 SD Times 100獎項,位於“極大影響力”分類第二位,僅次於亞馬遜。也由於hadoop在大數據處理和大數據挖掘上的出色表現,ASF也榮獲了“大數據和商業智能”的第二位。
主要成果:HTTP Server,Ant,DB,iBATIS,Jakarta,Logging,Maven,Struts,Tomcat,Tapestry等等。Apache有名的幾個項目介紹
HTTPServer
這個在前面的段落介紹過了,Apache已經是他的代號了
apache相關產品
Subversion
Subversion已經正式由Apache接管。
另外,它也支持通過除java語言外的語言的使用
Ant
這個太出名了。標準的批處理工具。是一套基於java的程序打造工具
Commons
一些常用的工具類庫,包括common-pool,dbcp,fileupload,Common-beans等。
DolphinScheduler( 原 Easy Scheduler)
[1]
它的主要產品是一個由java寫成的,名字叫做Fortress(要塞) 的輕量級的可嵌入式反向控制容器。
iBATIS
併入的一個項目,是ORM的一個很流行的工具
Geronimo
是Apache軟件基金會為了創造一個兼容j2ee的容器,而整理出來的一個新成果
Jakarta
James
Logging
基於java的可靠,快速,擴展性強的日誌工具
Maven
Portals
門户產品
Struts
Tomcat 用量最大的免費的Java服務器
Hadoop
[2-3]
現今最為著名的大數據神器,包括分佈式存儲和計算框架。
apache虛擬主機
1、核心的增強
Unix線程
新的構架系統
構架系統已經對原來基於autoconf和libtool上的草稿進行了重寫。這使得Apache的配置系統與其他包的配置系統更加相似。
多協議支持
apache 虛擬主機現在已經擁有了能夠支持伺服多協議的底層構造。mod_echo就是作為示例的成果。
對非Unix平台更好的支持
Apache 2.0在諸如BeOS,OS/2和Windows等非Unix平台上有了更好的速度和穩定性。隨着平台特定的multi-processing modules (MPMs)和Apache Portable Runtime (APR)的引入,Apache在這些平台上的指令由它們本地的API指令實現。避免了以往使用POSIX模擬層造成的bug和性能低下。
新的Apache API
2.0中模塊的API進行了重大改變。很多1.3中模塊排序/模塊優先級的問題已經不復存在了。2.0自動處理了很多這樣的問題,模塊排序現在用per-hook的方法進行,從而擁有了更多的靈活性。而且,新的調用被加入以在避免修改Apache服務器核心的前提下提供額外的模塊容量。
IPv6支持
在所有能被Apache Portable Runtime庫提供IPv6支持的系統上,Apache默認獲得IPv6偵聽套接字。另外,Listen, NameVirtualHost和VirtualHost 指令支持了IPv6的數字形地址字串(比如:“Listen [fe80::1]:8080”)。
濾過
apache 虛擬主機的模塊現在可以寫成過濾器的形式。當內容流經過它到服務器或從服務器到達的時候進行操作。舉例來説,這將使使用mod_include中的INCLUDES過濾器將CGI腳本的輸出解析為服務器端包含指令成為可能。mod_ext_filter允許外部程序充當過濾器的角色,就象用CGI程序做處理器一樣。
多語種錯誤回報
簡化了的配置
很多易混淆的配置項已經進行了簡化。經常產生混淆的Port和BindAddress配置項已經取消了;只有Listen選項現在用於IP地址的綁定;ServerName配置項中指定的服務器名和端口僅用於轉向和虛擬機的辨識。
本地Windows NT Unicode支持
Windows NT上的Apache 2.0現在使用utf-8標準來進行文件名的解析。這個操作直接轉換成底層的Unicode文件系統,由此為所有以Windows NT(包括Windows 2000和XP)為基礎的安裝提供了多語言支持。這一支持目前尚未涵蓋Windows 95, 98 or ME系統,因為它們仍使用機器本地的代碼頁進行文件系統的操作。
正則表達式庫更新
2、模塊的增強
mod_ssl
Apache 2.0中的新模塊。此模塊是一個面向OpenSSL提供的SSL/TLS加密協議的一個接口。
mod_dav
mod_deflate
Apache 2.0中的新模塊。此模塊允許支持此功能的瀏覽器請求頁面內容在發送前進行壓縮,以節省網絡資源。
mod_auth_ldap
mod_auth_digest
利用共享內存實現了了額外的跨進程的session緩衝支持。
mod_charset_lite
Apache 2.0中的新模塊。這個試驗模塊允許針對字符集的轉換和記錄。
mod_file_cache
mod_headers
此模塊在Apache 2.0中更具靈活性。它現在可以更改mod_proxy需用的請求headers,而且它能有條件的設置回覆headers。
mod_proxy
代理模塊已經被完全重寫以充分利用新的過濾器結構的優勢,從而實現一個更為可靠的HTTP/1.1兼容的代理模塊。另外,新的<Proxy>配置部分提供了更具可讀性(而且更快)的代理站點控制; 重載<Directory "proxy:...">配置的方法已經不再支持了。這個模塊現在依照協議支持分為proxy_connect, proxy_ftp和proxy_http三個部分。
mod_negotiation
加入一個新的ForceLanguagePriority指令用於保證所有情況下客户端都收到同一個文檔,取代了不可接受的或多選擇的迴應。另外,negotiation和MultiViews算法已經進行了優化以提供更完美的結果,還有,提供了包括文檔內容的新型類型圖。
mod_autoindex
mod_include
新的指令集允許修改默認的SSI元素的開始和結束標籤,而且允許以主配置文件裏的錯誤提示和時間格式的配置取代SSI文檔中的相應部分。正則表達式(現在已基於Perl的正則表達式語法)的解析和分組結果可以用mod_include的變量$0 .. $9取得。
mod_auth_dbm
現在在AuthDBMType的規策下支持多種類似DBM的數據庫。
apache開源技術
Apache HTTP服務器項目
Apache HTTP服務器項目主要致力於為現代操作系統開發和維護開源的HTTP服務器,其中包括Unix和Windows NT。這個項目的主要目標是提供一個可以與當前的HTTP標準同步提供安全、高效和可擴展的服務器的HTTP服務。
自1996年4月以來,Apache就變成了互聯網上最流行的Web服務器。
Apache Tomcat
Apache Tomcat是一個可以執行Java Servlet和JavaServer網頁技術的開源軟件。Apache和Tomcat是相對獨立的,用户可以通過Apache訪問Tomcat資源,反之亦然,二者可以在同一台服務器上。
Apache Tomcat是由全世界各地的最佳開發者合力研發而來的,是一款非常優異的開源軟件。
用户羣:Tomcat推動了很多不同行業的大型的、關鍵的Web應用程序的發展,其中包括ETrade、沃爾瑪、天氣頻道以及EMC等。
Apache Lucene
Apache Lucene是一個高性能、全功能的文字搜索引擎圖書館,是由Java語言編寫的。Apache
Lucene適用於任何需要全文字搜索的應用程序,特別是跨越平台。一開始,Lucene是由Java語言編寫的,目前已經被移植到其他的語言,其中包括
Apache Struts
Apache Struts是一個用於開發Java EE Web應用程序的開源Web應用程序框架。Apache Struts使用和擴展Java Servlet
API去鼓勵開發者採用模型視圖控制器(MVC)構架。
用户羣: IRS、波士頓環球報、大赦國際、Sears、Alamo Car Rental、National Car Rental、Travelocity等等。
Apache Geronimo是Apache
Apache Ant
Apache
Apache Cocoon
Apache Cocoon是一個基於Spring框架的圍繞分離理念建立的構架,在這種框架下的所有處理都被預先定義好的處理組件線性連接起來,能夠將輸入和產生的輸出按照流水線順序處理。
用户羣:Apache Lenya、Daisy CMS、Hippo CMS、Mindquarry等等,Apache
Apache SpamAssassin
SpamAssassin是一個由Apache開發的一個著名的反垃圾引擎,郵件系統完整的集成了SpamAssassin反垃圾引擎。
用户羣:SpamAssassin被數以千計的獨立開發商和用户所採用,並被作為數個商業產品的主要成分.\
Apache Axis
Apache Axis是一個基於SOAP應用的框架,核心是一個SOAP處理器,用於開發包括客户端,服務器端,SOAP Gateway等各種應用。
用户羣:WSO2、MuleSource IBM、Progress Software等。
Apache Logging Services
Apache Logging Services項目主要是為了提供應用程式除錯以及監督的日誌登錄服務。
Apache Logging Services項目的產品包括三個日誌登錄框架,分別為log4j for Java、log4cxx for
C++以及log4net for the Microsoft .NET framework。
Apache Logging Services還被應用於日誌查看器和分析工具Chainsaw中。
用户羣:Apache Logging在Java開發中無處不在。
Apache Commons
Commons是一個主要專注於可再用Java組件所有方面的Apache項目。
Apache Commons項目由3個部分組成:
*The Commons Proper—可再用Java組件的貯存處;
*The Commons Sandbox—Java組件的開發工作區;
*The Commons Dormant—沙盒組件的貯存庫。
用户羣:亞馬遜Web服務、谷歌。
- 參考資料
-
- 1. apache wiki .apache官網[引用日期2020-04-20]
- 2. apache .apache官網[引用日期2012-11-09]
- 3. hadoop .hadoop官方主頁[引用日期2012-11-09]