<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                [官方文檔](https://nodejs.org/zh-cn/docs/) JS是腳本語言,腳本語言都需要一個解析器才能運行。對于寫在HTML頁面里的JS,瀏覽器充當了解析器的角色。而對于需要獨立運行的JS,**NodeJS就是一個解析器**。 它只是基于Google v8引擎的JavaScript運行時環境 使之支持io,fs等只有語言才有的特性,使得JavaScript能夠同時具有DOM操作(瀏覽器)和I/O、文件讀寫 操作數據庫(服務器端等能力,是目前最簡單的全棧式語言。這里我們可以簡單理解Node.js是一個內置有chrome v8引擎的JavaScript運行環境,他可以使原本在瀏覽器中運行的JavaScript有能力跑后端,從而操作我們數據庫,進行文件讀寫等。目前市面上高密集的/O模型,比如Web開發,微服務,前端構建等都有做Node.js的身影。不少大型網站都是使用Node.js作為后臺開發語言的,比如淘寶雙十一、去哪兒網的PC端核心業務等。另外我們一些前端工具營如VSCode,webpack等也是有Node.js開發。Node.js的包管理工具, npm已經成為世界開源包管理中最大的生態,功能強大,目前單月使用者接近1000萬。 ## **特點:** 單線程 非阻塞I/O模型(異步) 事件驅動 輕量和高效 ## **例子:** [HK-WOW插件管理器](https://bbs.nga.cn/read.php?tid=14564190&rand=678)軟件環境為[electron](http://electronjs.org/docs/tutorial/first-app),是基于nodejs的桌面客戶端,javascript/CSS/HTML,vue/iview,歡迎技術交流。 ### 安裝web框架express: ~~~ npm install express ~~~ ## **單線程** 在Java, PHP或者net等服務器端語言中,會為每一個客戶端連接創建一個新的線程。而每個線程需要耗費大約2MB內存。也就是說,理論上,一個8GB內存的服務器可以同時連接的最大用戶數為4000個左右。要讓 Web應用程序支持更多的用戶,就需要增加服務器的數量,而Web應用程序的硬件成本當然就上升了。Node.js不為每個客戶連接創建一個新的線程,而僅僅使用一個線程。當有用戶連接了,就觸發一個內部事件,通過非阻塞1/0、事件驅動機制,讓Nodejs程序宏觀上也是并行的。使用Nodejs,一個8GB內存的服務器,可以同時處理超過4萬用戶的連接。.另外,帶線程的帶來的好處,還有操作系統完全不再有線程創建、銷毀的時間開銷。. ##### [既然nodejs是單線程的,那么它怎么處理并發,難道要排隊么](https://segmentfault.com/q/1010000000190024) ## **非阻塞IO.** 例如,當在訪問數據庫取得數據的時候,需要一段時間。在傳統的單線程處理機制中,在執行了訪問數據庫代碼之后,整個線程都將暫停下來,等待數據庫返回結果,才能執行后面的代碼。也就是說, IO阻塞了代碼的執行,極大地降低了程序的執行效率。 由于Nodejs中采用了非阻塞型I/O機制,因此在執行了訪問數據庫的代碼之后,將立即轉而執行其后面的代碼,把數據庫返回結果的處理代碼放在回調函數中,從而提高了程序的執行效率。當某個10執行完畢時,將以事件的形式通知執行I/O操作的線程,線程執行這個事件的回調函數。為了處理異步I/O,線程必須有事件循環,不斷的檢查有沒有未處理的事件,依次予以處理。 阻塞模式下,一個線程只能處理一項任務,要想提高吞吐量必須通過多線程。而非阻塞模式下,一個線程永遠在執行計算操作,這個線程的CPU核心利用率永遠是100%。所以,這是一種特別有哲理的解決方案:與其人多,但是好多人閑著;還不如一個人玩命,往死里干活兒。 # **事件驅動** 在Node中,客戶端請求建立連接,提交數據等行為,會觸發相應的事件。在Node中,在一個時刻,只能執行一個事件回調函數,但是在執行一個事件回調函數的中途,可以轉而處理其他事件(比如,又有新用戶連接了),然后返回繼續執行原事件的回調函數,這種處理機制,稱為“事件環”機制。..Nodejs底層是C++ (V8也是C++寫的),底層代碼中,近半數都用于事件隊列、回調函數隊列的構建。用事件驅動來完成服務器的任務調度,這是鬼才才能想到的。. 單線程, 單線程的好處,減少了內存開銷,操作系繞的內存換頁。如果某一個事情,進入了,但是被1O阻塞了,所以這個線程就阻塞了。. 非阻塞I/O, 不會傻等I/O語句結束,而會執行后面的語句。..非阻塞就能解決問題了么?比如執行著小紅的業務,執行過程中,小剛的I/O回調完成了,此時怎么辦?? 事件機制,事件環, 不管是新用戶的請求,還是老用戶的I/O完成,都將以事件方式加入事件環,等待調度 說是三個特點,實際上是一個特點,離開誰都不行,都玩兒不轉了。Nodejs很像摳門的餐廳老板,只聘請1個服務員,服務很多人。結果,比很多服務員效率還高。Nodejs中所有的I/O都是異步的,回調函數,套回調函數。. 適合開發什么? Nodejs適合用來開發什么樣的應用程序呢? 善于I/O,不善于計算。因為Nodejs最擅長的就是任務調度,如果你的業務有很多的CPU計算,實際上也相當于這個計算阻塞了這個單線程,就不適合Node開發。當應用程序需要處理大量并發的I/O,而在向客戶端發出響應之前,應用程序內部并不需要進行非常復雜的處理的時候, Node.js非常適合。Nodejs也非常適合與web socket配合,開發長連接的實時交互應用程序。比如: 用戶表單收集. 考試系統 聊天室 圖文直播. 提供JSON的API (為前臺Angular使用)..
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看