web技術棧中不可或缺的Linux技術
隨著第三次信息浪潮的沖擊,web技術在近年來可謂發(fā)生了天翻地覆的變革。從單向信息的web1.0時代,逐步過渡到信息和人交互的web2.0再到數據主動與人發(fā)生關系的web3.0時代,這些成就無疑歸功于Web技術的迅速發(fā)展。
本文引用地址:http://2s4d.com/article/201808/385052.htmWeb技術最重要的載體便是服務器,服務器運行在公共的網絡環(huán)境下,為廣大的用戶提供網頁瀏覽、信息通訊、消息推送等服務,從最開始的硬件服務器到虛擬主機技術,再到虛擬化技術的出現(xiàn)和云概念的興起,絕大部分都是基于Linux操作系統(tǒng)的,因此web工程中,Linux也是一枚舉足輕重的角色,不過掌握一門Linux技術也是重中之重,個人認為《Linux就該這么學》這本書拿來入門還是挺不錯的,下面將開始介紹Linux作為web技術的重要角色的幾個要點。
1、應用部署
絕大多數Web應用都承載在各大Linux發(fā)行版(如ubuntu 、redhat、centos)上,因此掌握Linux環(huán)境下的應用部署和日常維護尤為重要。下面列舉一些典型的應用部署解決方案:
PHP:Nginx/LAMP(Linux+Apache+Mysql+PHP),提供HTTP(S)服務并提供PHP解析的Fastcgi;
JAVA WEB:Tomcat/Jboss,提供HTTP(S)服務、Servlet和JSP容器;
Node.js:pm2/nodemon:提供守護進程和集群管理服務,Node.js應用本身即可開啟Server;
那么我們需要如何進行應用部署的技能補充呢?事實上,學習WEB應用部署并不難,首先我們需要扎實Linux的基本功:了解Linux操作系統(tǒng)概念和發(fā)行版、掌握基本的命令和程序安裝的方法(通常我們會通過包管理器或者源碼安裝的方式進行)。接下來的步驟簡化來說就是安裝應用部署所需的環(huán)境、進行環(huán)境的配置、拉取項目代碼、啟動應用。
或許我們可以再前衛(wèi)一些,通過虛擬化或者容器等技術去進行web應用的部署,都是依賴于上述這些最基本的套路。至于一些技術上細節(jié)和進階的內容,可以通過相關的專業(yè)網站或書籍參考。
2、日常維護
往往我們的Web應用在運行狀態(tài)下,偶有意外發(fā)生,如服務不可用、性能瓶頸等,這時候我們便需要對應用的生產環(huán)境進行現(xiàn)場勘查。
通常情況下,我們首先會進行系統(tǒng)運行狀態(tài)的檢查,通過工具或命令采集和查看機器運行狀態(tài)指數(CPU利用率、物理內存占用率、網絡、IOPS等)、服務運行狀態(tài)(服務可用性、響應速度、最大并發(fā)數等),基于以上的參數,我們可以建立監(jiān)控系統(tǒng)和可視化平臺,通過腳本收集參數信息,再通過WEB前端進行可視化的展示(nagios、zabbix等)。
接下來的重頭戲則是日志系統(tǒng),web應用中日志里保存了用戶的操作和結果反饋,可以快速進行場景和行為的還原。一般我們會將日志分為兩類:結構化日志和非結構化日志。非結構化日志(如log4j)主要是提供給開發(fā)者和維護者人工審閱和快速查詢的,往往當用戶量和數據量達到一定數量級時,會變得不利于閱讀和分析,因此并不適合大規(guī)模的web應用場景。結構化日志(如bunyan)通過代碼生成和序列化之后進行持久化存儲,我們可以通過相應的工具進行海量日志的分析和挖掘,甚至可以直接和業(yè)務耦合,進行集中化的日志分析(如ELK的日志實時分析),缺點是需要通過工具轉換成人工可閱讀的文檔。
基于日志分析和實時監(jiān)控,我們可以從而建立警報系統(tǒng),(當然監(jiān)控以上提及的監(jiān)控平臺均提供了警報功能)通過郵件等方式將服務器運行狀態(tài)、故障、意外事件等進行推送。
3、性能優(yōu)化和架構
一款好的產品總不會一成不變,web產品在發(fā)展過程中通常會遇到性能瓶頸,這時候我們便需要對應用進行優(yōu)化,甚至對整體架構進行升級。
撇開Web應用本身的業(yè)務代碼和邏輯上的優(yōu)化點不說,且講一下在Linux環(huán)境下的優(yōu)化策略,而其最重要的便是參數調優(yōu),主要解決Linux默認配置帶來的性能問題,其中主要的一些調優(yōu)點為:打開文件樹(limits)、內核參數調優(yōu)(協(xié)議棧中的各參數、網絡接口隊列等),通常情況下,我們需要對實際的服務環(huán)境進行參數的調整。
當我們的web應用在不斷的遇到性能瓶頸和升級優(yōu)化之后,整體架構也會隨之演化,從最開始的單機的架構到橫向擴展(升級硬件配置、增加機器數量)架構,再到縱向擴展(數據庫讀寫分離、業(yè)務切分等)架構,然后成為面向服務的分布式集群,甚至結合新興的大數據等技術建立高可用的集群。
對于web開發(fā)者而言,Linux的知識和技能掌握是非常重要的,我們尤其需要一套漸進式的學習路徑去熟悉和鞏固,其中為代表的書籍《Linux就該這么學》提供了大部分的Linux基礎學習和實戰(zhàn)教程,非常值得閱讀幾番。當遇到一些難以處理的場景,需提高自身解決問題的能力,合理利用Linux開源社區(qū)的資源快速找到解決方案。
評論