1. LVS-NAT負載均衡,訪問虛擬ip顯示第一個真實伺服器的web頁面,刷新WEB頁面不會切換到第二個真實伺服器WEB頁
因為同一個IE短時間TCP連接沒有拆除,再刷新還是使用同一個TCP連接,LVS同樣也沒有拆除,而新打開一個窗口則是新建立一個TCP連接。
2. LVS+DR模式web伺服器負載平衡,內網中總共三台測試伺服器,兩台物理機做RS,一台虛擬機做DS。
你可以在DR上將 RS的ip改成本地回環的ip
3. LVS+Nginx+DNS+web伺服器組成的反向代理解析流程是什麼
這個架構我完全無法理解,為毛要2台lvs,一般2台lvs是為了分流或高可用,好吧我暫時這么理解他的意圖,1台nginx是作為反向代理,簡單理解就是在客戶端看來伺服器端就是一台機器,防止其他人員了解你的後端架構和處理流程,nginx也可以減輕web的資源消耗主要是內存和io,也可以配置當成日誌伺服器,減輕web的壓力,但是他後端就一台web啊,用這個架構為毛啊,好吧我暫時理解為他是為了以後方便拓展架構;1台dns伺服器,為毛啊,無法理解,如果只是為了網站本身需要完全可以自解析,直接寫hosts不是更方便,好吧,其實架設dns伺服器是個好習慣,但是在資源有限的前提下,我認為不如把dns換成web,資源利用率更高;lvs和nginx都有負載均衡的作用,小架構1台nginx完全可以搞定,2台lvs純屬浪費;至於123456的問題,nginx配置,推薦《決戰nginx》高性能web伺服器詳解與運維;至於架構原理,推薦《構建高可用linux伺服器》余洪春
簡單說下流程:正常應該是,客戶端包先到lvs,lvs做了高可用,lvs分發給nginx,nginx查詢dns後分發給web
4. 兩台web伺服器做lvs+keepalived,請問有什麼好的解決方案
基於lvs的話,需要兩台伺服器內容一致(發布的虛擬主機),lvs是內核直接轉發,你這樣的話,如果不改動伺服器配置的話,建議用nginx的反向代理。
5. 如何測試lvs對網站性能的改善狀態
lvs和nginx都可以用作多機負載的方案,它們各有優缺,在生產環境中需要好好分析實際情況並加以利用。 首先提醒,做技術切不可人雲亦雲,我雲即你雲;同時也不可太趨向保守,過於相信舊有方式而等別人來幫你做墊被測試。把所有即時聽說到的好東西加以鑽研,從而提高自己對技術的認知和水平,乃是一個好習慣。
下面來分析一下兩者:
一、lvs的優勢:
1、抗負載能力強,因為lvs工作方式的邏輯是非常之簡單,而且工作在網路4層僅做請求分發之用,沒有流量,所以在效率上基本不需要太過考慮。在我手裡的lvs,僅僅出過一次問題:在並發最高的一小段時間內均衡器出現丟包現象,據分析為網路問題,即網卡或linux2.4內核的承載能力已到上限,內存和cpu方面基本無消耗。
2、配置性低,這通常是一大劣勢,但同時也是一大優勢,因為沒有太多可配置的選項,所以除了增減伺服器,並不需要經常去觸碰它,大大減少了人為出錯的幾率。
3、工作穩定,因為其本身抗負載能力很強,所以穩定性高也是順理成章,另外各種lvs都有完整的雙機熱備方案,所以一點不用擔心均衡器本身會出什麼問題,節點出現故障的話,lvs會自動判別,所以系統整體是非常穩定的。
4、無流量,上面已經有所提及了。lvs僅僅分發請求,而流量並不從它本身出去,所以可以利用它這點來做一些線路分流之用。沒有流量同時也保住了均衡器的IO性能不會受到大流量的影響。
5、基本上能支持所有應用,因為lvs工作在4層,所以它可以對幾乎所有應用做負載均衡,包括http、資料庫、聊天室等等。
另:lvs也不是完全能判別節點故障的,譬如在wlc分配方式下,集群里有一個節點沒有配置VIP,會使整個集群不能使用,這時使用wrr分配方式則會丟掉一台機。目前這個問題還在進一步測試中。所以,用lvs也得多多當心為妙。
二、nginx和lvs作對比的結果
1、nginx工作在網路的7層,所以它可以針對http應用本身來做分流策略,比如針對域名、目錄結構等,相比之下lvs並不具備這樣的功能,所以nginx單憑這點可利用的場合就遠多於lvs了;但nginx有用的這些功能使其可調整度要高於lvs,所以經常要去觸碰觸碰,由lvs的第2條優點看,觸碰多了,人為出問題的幾率也就會大。
2、nginx對網路的依賴較小,理論上只要ping得通,網頁訪問正常,nginx就能連得通,nginx同時還能區分內外網,如果是同時擁有內外網的節點,就相當於單機擁有了備份線路;lvs就比較依賴於網路環境,目前來看伺服器在同一網段內並且lvs使用direct方式分流,效果較能得到保證。另外注意,lvs需要向託管商至少申請多一個ip來做Visual IP,貌似是不能用本身的IP來做VIP的。要做好LVS管理員,確實得跟進學習很多有關網路通信方面的知識,就不再是一個HTTP那麼簡單了。
3、nginx安裝和配置比較簡單,測試起來也很方便,因為它基本能把錯誤用日誌列印出來。lvs的安裝和配置、測試就要花比較長的時間了,因為同上所述,lvs對網路依賴比較大,很多時候不能配置成功都是因為網路問題而不是配置問題,出了問題要解決也相應的會麻煩得多。
4、nginx也同樣能承受很高負載且穩定,但負載度和穩定度差lvs還有幾個等級:nginx處理所有流量所以受限於機器IO和配置;本身的bug也還是難以避免的;nginx沒有現成的雙機熱備方案,所以跑在單機上還是風險較大,單機上的事情全都很難說。
5、nginx可以檢測到伺服器內部的故障,比如根據伺服器處理網頁返回的狀態碼、超時等等,並且會把返回錯誤的請求重新提交到另一個節點。目前lvs中ldirectd也能支持針對伺服器內部的情況來監控,但lvs的原理使其不能重發請求。重發請求這點,譬如用戶正在上傳一個文件,而處理該上傳的節點剛好在上傳過程中出現故障,nginx會把上傳切到另一台伺服器重新處理,而lvs就直接斷掉了,如果是上傳一個很大的文件或者很重要的文件的話,用戶可能會因此而惱火。
6、nginx對請求的非同步處理可以幫助節點伺服器減輕負載,假如使用apache直接對外服務,那麼出現很多的窄帶鏈接時apache伺服器將會佔用大量內存而不能釋放,使用多一個nginx做apache代理的話,這些窄帶鏈接會被nginx擋住,apache上就不會堆積過多的請求,這樣就減少了相當多的內存佔用。這點使用squid也有相同的作用,即使squid本身配置為不緩存,對apache還是有很大幫助的。lvs沒有這些功能,也就無法能比較。
7、nginx能支持http和email(email的功能估計比較少人用),lvs所支持的應用在這點上會比nginx更多。
在使用上,一般最前端所採取的策略應是lvs,也就是DNS的指向應為lvs均衡器,lvs的優點令它非常適合做這個任務。
重要的ip地址,最好交由lvs託管,比如資料庫的ip、webservice伺服器的ip等等,這些ip地址隨著時間推移,使用面會越來越大,如果更換ip則故障會接踵而至。所以將這些重要ip交給lvs託管是最為穩妥的,這樣做的唯一缺點是需要的VIP數量會比較多。
nginx可作為lvs節點機器使用,一是可以利用nginx的功能,二是可以利用nginx的性能。當然這一層面也可以直接使用squid,squid的功能方面就比nginx弱不少了,性能上也有所遜色於nginx。
nginx也可作為中層代理使用,這一層面nginx基本上無對手,唯一可以撼動nginx的就只有lighttpd了,不過lighttpd目前還沒有能做到nginx完全的功能,配置也不那麼清晰易讀。另外,中層代理的IP也是重要的,所以中層代理也擁有一個VIP和lvs是最完美的方案了。
nginx也可作為網頁靜態伺服器,不過超出了本文討論的范疇,簡單提一下。
具體的應用還得具體分析,如果是比較小的網站(日PV<1000萬),用nginx就完全可以了,如果機器也不少,可以用DNS輪詢,lvs所耗費的機器還是比較多的;大型網站或者重要的服務,機器不發愁的時候,要多多考慮利用lvs。
6. 分布式Web伺服器架構
最開始,由於某些想法,於是在互聯網上搭建了一個網站,這個時候甚至有可能主機都是租借的,但由於這篇文章我們只關注架構的演變歷程,因此就假設這個時候已經是託管了一台主機,並且有一定的帶寬了,這個時候由於網站具備了一定的特色,吸引了部分人訪問,逐漸你發現系統的壓力越來越高,響應速度越來越慢,而這個時候比較明顯的是資料庫和應用互相影響,應用出問題了,資料庫也很容易出現問題,而資料庫出問題的時候,應用也容易出問題,於是進入了第一步演變階段:將應用和資料庫從物理上分離,變成了兩台機器,這個時候技術上沒有什麼新的要求,但你發現確實起到效果了,系統又恢復到以前的響應速度了,並且支撐住了更高的流量,並且不會因為資料庫和應用形成互相的影響。
這一步架構演變對技術上的知識體系基本沒有要求。
架構演變第二步:增加頁面緩存
好景不長,隨著訪問的人越來越多,你發現響應速度又開始變慢了,查找原因,發現是訪問資料庫的操作太多,導致數據連接競爭激烈,所以響應變慢,但資料庫連接又不能開太多,否則資料庫機器壓力會很高,因此考慮採用緩存機制來減少資料庫連接資源的競爭和對資料庫讀的壓力,這個時候首先也許會選擇採用squid 等類似的機制來將系統中相對靜態的頁面(例如一兩天才會有更新的頁面)進行緩存(當然,也可以採用將頁面靜態化的方案),這樣程序上可以不做修改,就能夠很好的減少對webserver的壓力以及減少資料庫連接資源的競爭,OK,於是開始採用squid來做相對靜態的頁面的緩存。
前端頁面緩存技術,例如squid,如想用好的話還得深入掌握下squid的實現方式以及緩存的失效演算法等。
架構演變第三步:增加頁面片段緩存
增加了squid做緩存後,整體系統的速度確實是提升了,webserver的壓力也開始下降了,但隨著訪問量的增加,發現系統又開始變的有些慢了,在嘗到了squid之類的動態緩存帶來的好處後,開始想能不能讓現在那些動態頁面里相對靜態的部分也緩存起來呢,因此考慮採用類似ESI之類的頁面片段緩存策略,OK,於是開始採用ESI來做動態頁面中相對靜態的片段部分的緩存。
這一步涉及到了這些知識體系:
頁面片段緩存技術,例如ESI等,想用好的話同樣需要掌握ESI的實現方式等;
架構演變第四步:數據緩存
在採用ESI之類的技術再次提高了系統的緩存效果後,系統的壓力確實進一步降低了,但同樣,隨著訪問量的增加,系統還是開始變慢,經過查找,可能會發現系統中存在一些重復獲取數據信息的地方,像獲取用戶信息等,這個時候開始考慮是不是可以將這些數據信息也緩存起來呢,於是將這些數據緩存到本地內存,改變完畢後,完全符合預期,系統的響應速度又恢復了,資料庫的壓力也再度降低了不少。
這一步涉及到了這些知識體系:
緩存技術,包括像Map數據結構、緩存演算法、所選用的框架本身的實現機制等。
架構演變第五步: 增加webserver
好景不長,發現隨著系統訪問量的再度增加,webserver機器的壓力在高峰期會上升到比較高,這個時候開始考慮增加一台webserver,這也是為了同時解決可用性的問題,避免單台的webserver down機的話就沒法使用了,在做了這些考慮後,決定增加一台webserver,增加一台webserver時,會碰到一些問題,典型的有:
1、如何讓訪問分配到這兩台機器上,這個時候通常會考慮的方案是Apache自帶的負載均衡方案,或LVS這類的軟體負載均衡方案;
2、如何保持狀態信息的同步,例如用戶session等,這個時候會考慮的方案有寫入資料庫、寫入存儲、cookie或同步session信息等機制等;
3、如何保持數據緩存信息的同步,例如之前緩存的用戶數據等,這個時候通常會考慮的機制有緩存同步或分布式緩存;
4、如何讓上傳文件這些類似的功能繼續正常,這個時候通常會考慮的機制是使用共享文件系統或存儲等;
在解決了這些問題後,終於是把webserver增加為了兩台,系統終於是又恢復到了以往的速度。
這一步涉及到了這些知識體系:
負載均衡技術(包括但不限於硬體負載均衡、軟體負載均衡、負載演算法、linux轉發協議、所選用的技術的實現細節等)、主備技術(包括但不限於 ARP欺騙、linux heart-beat等)、狀態信息或緩存同步技術(包括但不限於Cookie技術、UDP協議、狀態信息廣播、所選用的緩存同步技術的實現細節等)、共享文件技術(包括但不限於NFS等)、存儲技術(包括但不限於存儲設備等)。
架構演變第六步:分庫
享受了一段時間的系統訪問量高速增長的幸福後,發現系統又開始變慢了,這次又是什麼狀況呢,經過查找,發現資料庫寫入、更新的這些操作的部分資料庫連接的資源競爭非常激烈,導致了系統變慢,這下怎麼辦呢,此時可選的方案有資料庫集群和分庫策略,集群方面像有些資料庫支持的並不是很好,因此分庫會成為比較普遍的策略,分庫也就意味著要對原有程序進行修改,一通修改實現分庫後,不錯,目標達到了,系統恢復甚至速度比以前還快了。
這一步涉及到了這些知識體系:
這一步更多的是需要從業務上做合理的劃分,以實現分庫,具體技術細節上沒有其他的要求;
但同時隨著數據量的增大和分庫的進行,在資料庫的設計、調優以及維護上需要做的更好,因此對這些方面的技術還是提出了很高的要求的。
架構演變第七步:分表、DAL和分布式緩存
隨著系統的不斷運行,數據量開始大幅度增長,這個時候發現分庫後查詢仍然會有些慢,於是按照分庫的思想開始做分表的工作,當然,這不可避免的會需要對程序進行一些修改,也許在這個時候就會發現應用自己要關心分庫分表的規則等,還是有些復雜的,於是萌生能否增加一個通用的框架來實現分庫分表的數據訪問,這個在ebay的架構中對應的就是DAL,這個演變的過程相對而言需要花費較長的時間,當然,也有可能這個通用的框架會等到分表做完後才開始做,同時,在這個階段可能會發現之前的緩存同步方案出現問題,因為數據量太大,導致現在不太可能將緩存存在本地,然後同步的方式,需要採用分布式緩存方案了,於是,又是一通考察和折磨,終於是將大量的數據緩存轉移到分布式緩存上了。
這一步涉及到了這些知識體系:
分表更多的同樣是業務上的劃分,技術上涉及到的會有動態hash演算法、consistent hash演算法等;
DAL涉及到比較多的復雜技術,例如資料庫連接的管理(超時、異常)、資料庫操作的控制(超時、異常)、分庫分表規則的封裝等;
架構演變第八步:增加更多的webserver
在做完分庫分表這些工作後,資料庫上的壓力已經降到比較低了,又開始過著每天看著訪問量暴增的幸福生活了,突然有一天,發現系統的訪問又開始有變慢的趨勢了,這個時候首先查看資料庫,壓力一切正常,之後查看webserver,發現apache阻塞了很多的請求,而應用伺服器對每個請求也是比較快的,看來是請求數太高導致需要排隊等待,響應速度變慢,這還好辦,一般來說,這個時候也會有些錢了,於是添加一些webserver伺服器,在這個添加 webserver伺服器的過程,有可能會出現幾種挑戰:
1、Apache的軟負載或LVS軟負載等無法承擔巨大的web訪問量(請求連接數、網路流量等)的調度了,這個時候如果經費允許的話,會採取的方案是購買硬體負載,例如F5、Netsclar、Athelon之類的,如經費不允許的話,會採取的方案是將應用從邏輯上做一定的分類,然後分散到不同的軟負載集群中;
2、原有的一些狀態信息同步、文件共享等方案可能會出現瓶頸,需要進行改進,也許這個時候會根據情況編寫符合網站業務需求的分布式文件系統等;
在做完這些工作後,開始進入一個看似完美的無限伸縮的時代,當網站流量增加時,應對的解決方案就是不斷的添加webserver。
這一步涉及到了這些知識體系:
到了這一步,隨著機器數的不斷增長、數據量的不斷增長和對系統可用性的要求越來越高,這個時候要求對所採用的技術都要有更為深入的理解,並需要根據網站的需求來做更加定製性質的產品。
架構演變第九步:數據讀寫分離和廉價存儲方案
突然有一天,發現這個完美的時代也要結束了,資料庫的噩夢又一次出現在眼前了,由於添加的webserver太多了,導致資料庫連接的資源還是不夠用,而這個時候又已經分庫分表了,開始分析資料庫的壓力狀況,可能會發現資料庫的讀寫比很高,這個時候通常會想到數據讀寫分離的方案,當然,這個方案要實現並不容易,另外,可能會發現一些數據存儲在資料庫上有些浪費,或者說過於佔用資料庫資源,因此在這個階段可能會形成的架構演變是實現數據讀寫分離,同時編寫一些更為廉價的存儲方案,例如BigTable這種。
這一步涉及到了這些知識體系:
數據讀寫分離要求對資料庫的復制、standby等策略有深入的掌握和理解,同時會要求具備自行實現的技術;
廉價存儲方案要求對OS的文件存儲有深入的掌握和理解,同時要求對採用的語言在文件這塊的實現有深入的掌握。
架構演變第十步:進入大型分布式應用時代和廉價伺服器群夢想時代
經過上面這個漫長而痛苦的過程,終於是再度迎來了完美的時代,不斷的增加webserver就可以支撐越來越高的訪問量了,對於大型網站而言,人氣的重要毋庸置疑,隨著人氣的越來越高,各種各樣的功能需求也開始爆發性的增長,這個時候突然發現,原來部署在webserver上的那個web應用已經非常龐大了,當多個團隊都開始對其進行改動時,可真是相當的不方便,復用性也相當糟糕,基本是每個團隊都做了或多或少重復的事情,而且部署和維護也是相當的麻煩,因為龐大的應用包在N台機器上復制、啟動都需要耗費不少的時間,出問題的時候也不是很好查,另外一個更糟糕的狀況是很有可能會出現某個應用上的bug就導致了全站都不可用,還有其他的像調優不好操作(因為機器上部署的應用什麼都要做,根本就無法進行針對性的調優)等因素,根據這樣的分析,開始痛下決心,將系統根據職責進行拆分,於是一個大型的分布式應用就誕生了,通常,這個步驟需要耗費相當長的時間,因為會碰到很多的挑戰:
1、拆成分布式後需要提供一個高性能、穩定的通信框架,並且需要支持多種不同的通信和遠程調用方式;
2、將一個龐大的應用拆分需要耗費很長的時間,需要進行業務的整理和系統依賴關系的控制等;
3、如何運維(依賴管理、運行狀況管理、錯誤追蹤、調優、監控和報警等)好這個龐大的分布式應用。
經過這一步,差不多系統的架構進入相對穩定的階段,同時也能開始採用大量的廉價機器來支撐著巨大的訪問量和數據量,結合這套架構以及這么多次演變過程吸取的經驗來採用其他各種各樣的方法來支撐著越來越高的訪問量。
這一步涉及到了這些知識體系:
這一步涉及的知識體系非常的多,要求對通信、遠程調用、消息機制等有深入的理解和掌握,要求的都是從理論、硬體級、操作系統級以及所採用的語言的實現都有清楚的理解。
運維這塊涉及的知識體系也非常的多,多數情況下需要掌握分布式並行計算、報表、監控技術以及規則策略等等。
說起來確實不怎麼費力,整個網站架構的經典演變過程都和上面比較的類似,當然,每步採取的方案,演變的步驟有可能有不同,另外,由於網站的業務不同,會有不同的專業技術的需求,這篇blog更多的是從架構的角度來講解演變的過程,當然,其中還有很多的技術也未在此提及,像資料庫集群、數據挖掘、搜索等,但在真實的演變過程中還會藉助像提升硬體配置、網路環境、改造操作系統、CDN鏡像等來支撐更大的流量,因此在真實的發展過程中還會有很多的不同,另外一個大型網站要做到的遠遠不僅僅上面這些,還有像安全、運維、運營、服務、存儲等,要做好一個大型的網站真的很不容易
7. LVS+DR模式下,Web伺服器網關指向哪裡
為了更高的吞吐量。在LVS裡面,添加後端伺服器的成本是線性的,但是如果採用替換替換為更高端單一的伺服器達到相同的效果,成本會高很多,前者是橫向擴展(scale out),後者是縱向擴展(scale up)
為了冗餘。後端伺服器可以從LVS上被管理員提出,然後做其他相關的伺服器操作。
為了適應性。如果吞吐量被評為逐步增加的,或者事件性陡增,後端伺服器的增加可以對用戶透明。
8. web開發都要具備哪些必備能力
一,html,css能力
1,了解階段,知道html標簽是干什麼用的,通過網路和手冊能自主的寫一些html,知道css是怎麼回事,能在html中寫一些簡單的style等
2,熟悉階段,能利用css來能設計一些簡單的布局,可以將css單獨的寫成文件,熟悉css的語法規則,以及繼承性等
3,很熟悉階段,能夠設計出很好的CSS,並且管理好這些CSS文件,盡量減少冗餘代碼。知道如何寫出有利於搜索引擎搜索的代碼,例如:title,h1,h2權重比較高的。等
二,js能力
如果提高用戶體驗,是一個網站能留住人的重要標志。這個就要用到JS了
1,了解階段,了解JS的基本語法,知道如何去調試這些程序,能寫一些簡單function等
2,熟悉階段,對JS的語法,函數,正則等已經熟悉了,能利用js來寫一些特效,並且發 現用JS寫特效,是比較累人的一件事,開始嘗試jquery,prototype,並對jquery,prototype基本語法有所解,個人反對不學 JS,直接入手jquery,prototype這樣的JS框架。
3,很熟悉階段,在框架的幫助下,能熟練的用OOP的思想的來寫代碼,而不是一個個 function累加,熟練運用jquery,prototype的ajax,或者是網上一些ajax框架,如(ajaxrequest),不在直接寫 active控制項了。能夠利用網路資源,來完成各種特效。
三,最關鍵的php能力
1,了解階段,您能寫一些代碼,因為那是在手冊和google的幫助下,您才完成的。變數亂定義,N多函數不知道,做起事來很慢,想到什麼寫什麼,代碼寫的比較亂,後期維護很麻煩。
2,熟悉階段,經常查函數,手冊估計也看過一,二遍了,常用的函數基本上您都了解了。後 期維護給您帶來了不少痛苦,您開始發現自己的代碼有很多不足,開始思考如果改進自己的代碼,如何站在項目的角度來規劃自己的代碼,而不是想到什麼寫什麼, 知道如何來減少冗餘代碼,使您的代碼清晰,知道什麼樣的代碼寫出來讓人看著舒服,基本的代碼規范,已經形成。為了提高自己,會特意的去一些技術性的論壇, 學習研究。
3,很熟悉階段,這個階段,我想您已經從面向過程進入了面向對象。個人覺得面向對象的最大好處就是,能使整個項目功能化,模塊化, 後期維護,改版,升級就很方便了。沒有面向對象的時候,不也一樣開發嗎.這個時期,您已經研究過了一種或者幾種框架,結合自己的實際項目經驗,在腦子里已 經能形成自己的一個框架,這個框架是最適合你的。並且能夠將這個框架運用到實際的開發中去,以提高自己的開發效率,並且能夠優化性能!
四,資料庫能力
用php來做項目的話,用mysql是最多的了,其次是pgsql。因為他們二個是免費的。哈哈,以mysql為例
1,了解階段,知道mysql是什麼,能寫一些簡單的sql語句,能設計簡單的表,知道如何使用資料庫管理工具(如:phpmyadmin)
2,熟悉階段,知道如何才能寫出高效率的sql語句,了解索引原理,知道如何創建索引, 會寫一些儲存過程,觸發器等,能通過各種手段來分析,測試資料庫,例如:利用mysqlslap來進行壓力測試,通來explain來分析sql語句,通 過開啟慢查詢來分析哪些sql語句真正影響mysql的運行,能利用dbdesigner4,mysql workbench為設計資料庫,能在命令狀態下,查詢,分析mysql環境變數,來分析mysql的運行狀態等等
3,很熟悉階段,對於各有種存儲引擎的原理非常熟悉,知道通過修改配置文件來,使存儲引 擎達到最優化,知道如何來優化資料庫的最大連接數,知道怎麼樣來優化mysql的I/o瓶頸,為了項目的需要,向mysql資料庫增加存儲引擎或者插件, 知道如何搭建資料庫集群,並監控資料庫的運行狀態等等
五,apache等能力
個人覺得,到目錄為止,跑php的話用apache的人還是最多,前段時間好多網站在吵NGINX有多麼多麼的好,能比apache好10倍,我覺得還是親自嘗試一下比較好。以apache為例
1,了解階段,不管是linux下,還是windows下,能夠安裝配置apache,知道如何添加php添模,如果面試官問你,apache為什麼能解釋php代碼,你怎麼回答呢。對apache的基本配置有所了解,對於啟動中遇到的問題能夠解決等
2,熟悉階段,知道如何向apache中添加新的模塊,如果如何進行url重寫,防盜鏈,進行IP限制等
3,很熟悉階段,知道如何利用apache來緩存圖片,能利用apache來做負載均衡,並且知道利用ab命令來進行壓力,通過工具對日誌分析,經過分析來對apache進行優化,知道如何搭建多個虛擬主機;對apahce的常用模塊都有實際操作經驗等
對apache進行監控和維護,一般是運維人員或者是項目經理來做的,個人覺得最好還是了解一點,因為這樣您才不會那麼容易被忽悠,對於自己將來的轉型也是非常有必要的。
六,linux系統
為什麼要掌握linux系統呢?用php寫的網站大多數運行在linux或者 freebsd下的,掌握linux系統對自己將來的發展還是比較有好處的。,在linux下,不用擔心中毒的問題,linux下的病毒很少,也不用擔 心,XX和XXX掃描你的硬碟了。哈哈
1,熟悉階段,會裝linux系統,對系統的常用命令能夠熟練運用等
2,運用階段,在linux系統下,能夠安裝配置apache,php,mysql,svn,memcache,squid,lvs等一些web項目必要的工具,能夠通過日誌分析其狀態等。對shell要有所了解,並能夠寫一些簡單的shell腳本等
七,溝通能力
這一點非常重要,並且被越來越多的人所忽視,其實做程序員挺杯具的,根電腦打交道的時間 是最多,也許是因為這樣吧,溝通的時候,是比較費勁的,也有可能是被程序的嚴謹性束縛了大腦,說出來的話,太專業,可能其他人聽不懂得。所以平時多和他人 交流,特別是根非技術人員多溝通,多站在對方的角度來思想問題,這樣的話,我想溝通起來會容易很多。
9. linux web負載均衡
概念我簡單講下:
兩台機器IP A,IP B通過虛擬IP C向外發布web服務,用戶通過C,會被LVS隨機分配至A,B中一台,用戶量大,會通過LVS進行自動調整達到負載均衡,而不會導致單台宕機。節點可以設置多個。
這種問題最好去論壇找答案,網路哪能找到。
我自己寫的,將就看看。
http://hi..com/isvaftouwvbaprd/item/d8587cdb7b2f671e20e25034
10. lvs 一台轉發 兩台web 最近發現兩台很慢 於是把其中一台給撤了 跑的比兩台都快!!這是啥情況
檢查一下lvs上面的轉發速度和資源使用量