從前端的角度來講,性能優化能夠分爲兩個方向。從用戶角度來看,一個是頁面加載的很快,另外一個是頁面使用起來很流暢。所以,對性能優化的探索,咱們能夠分爲頁面加載時間跟頁面運行效率兩個方向來進行研究html
在對這些環節進行優化以前,咱們須要知道如何監控這些環節花費了多少時間。前端
能夠獲取到不少頁面加載相關的數據。比較經常使用的有web
若是不使用該API,能夠以服務器渲染返回的時間,或是SPA路由跳轉離開的時間爲起點,domContentLoaded,load等事件爲結束點進行記錄。或是直接上google analytics。方法不少,就不細說了。面試
後端部分能夠對緩存,dns查詢時間,連接時間,處理請求時間,響應時間等進行優化。後端
dns查詢時間可使用httpdns或是dns預加載,域名收斂等手段優化。瀏覽器
創建鏈接的重點是長鏈接和連接複用,keep-alive,long-polling,http-straming,websocket或是本身寫過別的協議,更好的是直接上http2。爲了優化連接的環節,前端這裏還須要對資源使用cdn,雪碧圖,代碼合併等手段。緩存
服務器處理請求這裏能夠優化的點也很多,值得注意的就是移動端訪問PC端頁面須要跳轉到移動端頁面時,要再服務器端使用302跳轉,不要在前端進行跳轉。還有就是啓用hsts,要求瀏覽器在以後的訪問使用https,減小無謂的http跳轉https,同時還能夠防止ssl剝離攻擊,提高安全性。安全
服務器發送響應環節,可使用Transfer-Encoding=chunked,屢次返回響應,具體操做查詢bigpipe。還有就是減少cookie的體積等等。性能優化
推薦閱讀:服務器