你們先了解一下什麼是Go語言?
編程
Go語言是谷歌2009發佈的第二款開源編程語言。Go語言專門針對多處理器系統應用程序的編程進行了優化,使用Go編譯的程序能夠媲美C或C++代碼的速度,並且更加安全、支持並行進程。安全
Go做爲最近幾年最火的服務端開發語言,由於其學習門檻低、開發效率高,迅速佔領各大公司的服務端開發領域!服務器
Go語言的巨大優點有哪些?多線程
Go語言有三大優點:架構
部署簡單:Go 編譯生成的是一個靜態可執行文件,除了 glibc 外沒有其餘外部依賴。這讓部署變得異常方便:目標機器上只須要一個基礎的系統和必要的管理、監控工具,徹底不須要操心應用所需的各類包、庫的依賴關係,大大減輕了維護的負擔。這和 Python 有着巨大的區別。因爲歷史的緣由,Python 的部署工具生態至關混亂【好比 setuptools, distutils, pip, buildout 的不一樣適用場合以及兼容性問題】。官方 PyPI 源又常常出問題,須要搭建私有鏡像,而維護這個鏡像又要花費很多時間和精力。併發
併發性好:編程語言
Goroutine 和 channel 使得編寫高併發的服務端軟件變得至關容易,不少狀況下徹底不須要考慮鎖機制以及由此帶來的各類問題。單個 Go 應用也能有效的利用多個 CPU 核,並行執行的性能好。這和 Python 也是天壤之比。多線程和多進程的服務端程序編寫起來並不簡單,並且因爲全局鎖 GIL 的緣由,多線程的 Python 程序並不能有效利用多核,只能用多進程的方式部署;若是用標準庫裏的 multiprocessing 包又會對監控和管理形成很多的挑戰【咱們用的 supervisor 管理進程,對 fork 支持很差】。部署 Python 應用的時候一般是每一個 CPU 核部署一個應用,這會形成很多資源的浪費,好比假設某個 Python 應用啓動後須要佔用 100MB 內存,而服務器有 32 個 CPU 核,那麼留一個核給系統、運行 31 個應用副本就要浪費 3GB 的內存資源。ide
性能優異:高併發
雖然不如 C 和 Java,但一般比原生 Python 應用仍是高一個數量級的,適合編寫一些瓶頸業務。內存佔用也很是省。工具
能夠說,go語言是服務端開發的將來!
想要學好Go語言,你必須掌握:Go語言理論與應用的最佳實踐、高併發服務端開發經驗、海量日誌系統架構設計與實踐、高併發搶購系統架構設計與實踐。