Node.js中環境變數process.env的一些事詳解,node.jsprocess.env

來源:互聯網
上載者:User

Node.js中環境變數process.env的一些事詳解,node.jsprocess.env

前言

最近這兩天在和營運GG搞部署項目的事兒。碰到一個問題就是,咱們的dev,uat,product環境的問題。

因為是前後端分離,所以在開發和部署的過程中會有對後端介面的網域名稱的切換問題。折騰了一下午,查詢了各種資料這才把這Node環境變數process.env給弄明白。

下面這就做個問題解決的記錄。希望能對這個不明白的人有所協助。話不多說了,來一起看看詳細的介紹吧。

Node環境變數

首先,咱們在做react、vue的單頁應用開發的時候,相信大家對設定檔裡的process.env並不眼生。

想不起來? 黑人問號.jpg。

就是下面這些玩意兒。

從字面上看,就是這個 env屬性,在 development和production不同環境上,配置會有些不同。

行,那下面我們開始看看這個所謂的 process到底是個什麼東西。

文檔:http://nodejs.cn/api/process.html

官方解釋:process 對象是一個 global (全域變數),提供有關資訊,控制當前 Node.js 進程。作為一個對象,它對於 Node.js 應用程式始終是可用的,故無需使用 require()。

process(進程)其實就是存在nodejs中的一個全域變數。

然後呢,咱們可以通過這個所謂的進程能拿到一些有意思的東西。

不過我們今天主要是講講 process.env。

process.env

這是啥?

官方: process.env屬性返回一個包含使用者環境資訊的對象。

文檔:http://nodejs.cn/api/process.html#process_process_env

噢噢噢,原來著個屬效能返回項目運行所在環境的一些資訊。

有啥用呢?

很明顯的一個使用情境,依靠這個我們就可以給伺服器上打上一個標籤。這樣的話,我們就能根據不同的環境,做一些配置上的處理。比如開啟 sourceMap,後端介面的網域名稱切換等等。

你是 dev 環境他是 uat 環境她是 product 環境。

如何配置環境變數

下面講講如何配置各個環境的環境變數。

Windows配置

臨時配置

直接在cmd環境配置即可,查看環境變數,添加環境變數,刪除環境變數。

#node中常用的到的環境變數是NODE_ENV,首先查看是否存在 set NODE_ENV #如果不存在則添加環境變數 set NODE_ENV=production #環境變數追加值 set 變數名=%變數名%;變數內容 set path=%path%;C:\web;C:\Tools #某些時候需要刪除環境變數 set NODE_ENV=

永久配置

右鍵(此電腦) -> 屬性(R) -> 進階系統設定 -> 環境變數(N)...

Linux配置

臨時

查看環境變數,添加環境變數,刪除環境變數

#node中常用的到的環境變數是NODE_ENV,首先查看是否存在echo $NODE_ENV#如果不存在則添加環境變數export NODE_ENV=production#環境變數追加值export path=$path:/home/download:/usr/local/#某些時候需要刪除環境變數unset NODE_ENV#某些時候需要顯示所有的環境變數env

永久

開啟設定檔所在

# 所有使用者都生效vim /etc/profile# 目前使用者生效vim ~/.bash_profile

在檔案末尾添加類似如下語句進行環境變數的設定或修改

# 在檔案末尾添加如下格式的環境變數export path=$path:/home/download:/usr/local/export NODE_ENV = product

最後修改完成後需要運行如下語句令系統重新載入

# 修改/etc/profile檔案後source /etc/profile# 修改~/.bash_profile檔案後source ~/.bash_profile

解決環境導致後端介面變換問題

搞清楚這個問題後,我們就可以在不同環境的機器上設定不同的 NODE_ENV,當然這個欄位也不一定。
你也可以換成其他的NODE_ENV_NIZUISHUAI等等,反正是自訂的。

解決步驟

1.修改代碼裡的後端地址配置

很簡單,就是利用 process.env.NODE_ENV這個欄位來判斷。(process是node全域屬性,直接用就行了)

2.在linux上設定環境變數

export NODE_ENV=dev

然後你就可以去愉快的啟動項目玩了。

說在最後

因為我現在這個項目 React 服務端渲染。所以後端的請求轉寄就沒交給nginx進行處理。
像平常的純單頁應用,一般是用nginx進行請求轉寄的。

本篇成文比較快,哈哈,如果文內有任何的紕漏,還請指點,我也就學習學習啦。

另外,如果這篇小小的文章對你帶來協助,不妨給我點個贊吧,這將是我繼續下的一大動力。

謝謝~~

參考文獻

  • 環境變數-JasperXu的部落格 :http://sorex.cnblogs.com/p/6200940.html
  • 如何查看並設定NODE_ENV的值? : http://cnodejs.org/topic/587dc8a62967eeb01aafe87b
  • Node.js的process模組 : http://www.css88.com/archives/4548

註: 【如何配置環境變數】這一塊的內容,是直接引用的 JasperXu的部落格 的環境變數。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對幫客之家的支援。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.