Node.js中環(huán)境變量process.env的一些事詳解
前言
最近這兩天在和運(yùn)維GG搞部署項(xiàng)目的事兒。碰到一個(gè)問題就是,咱們的dev,uat,product環(huán)境的問題。
因?yàn)槭乔昂蠖朔蛛x,所以在開發(fā)和部署的過程中會有對后端接口的域名的切換問題。折騰了一下午,查詢了各種資料這才把這Node環(huán)境變量process.env給弄明白。
下面這就做個(gè)問題解決的記錄。希望能對這個(gè)不明白的人有所幫助。話不多說了,來一起看看詳細(xì)的介紹吧。
Node環(huán)境變量
首先,咱們在做react、vue的單頁應(yīng)用開發(fā)的時(shí)候,相信大家對配置文件里的process.env并不眼生。
想不起來? 黑人問號.jpg。
就是下面這些玩意兒。

從字面上看,就是這個(gè) env屬性,在 development和production不同環(huán)境上,配置會有些不同。
行,那下面我們開始看看這個(gè)所謂的 process到底是個(gè)什么東西。
文檔:http://nodejs.cn/api/process.html
官方解釋:process 對象是一個(gè) global (全局變量),提供有關(guān)信息,控制當(dāng)前 Node.js 進(jìn)程。作為一個(gè)對象,它對于 Node.js 應(yīng)用程序始終是可用的,故無需使用 require()。
process(進(jìn)程)其實(shí)就是存在nodejs中的一個(gè)全局變量。
然后呢,咱們可以通過這個(gè)所謂的進(jìn)程能拿到一些有意思的東西。
不過我們今天主要是講講 process.env。
process.env
這是啥?
官方: process.env屬性返回一個(gè)包含用戶環(huán)境信息的對象。
文檔:http://nodejs.cn/api/process.html#process_process_env
噢噢噢,原來著個(gè)屬性能返回項(xiàng)目運(yùn)行所在環(huán)境的一些信息。
有啥用呢?
很明顯的一個(gè)使用場景,依靠這個(gè)我們就可以給服務(wù)器上打上一個(gè)標(biāo)簽。這樣的話,我們就能根據(jù)不同的環(huán)境,做一些配置上的處理。比如開啟 sourceMap,后端接口的域名切換等等。
你是 dev 環(huán)境 他是 uat 環(huán)境 她是 product 環(huán)境。
如何配置環(huán)境變量
下面講講如何配置各個(gè)環(huán)境的環(huán)境變量。
Windows配置
臨時(shí)配置
直接在cmd環(huán)境配置即可,查看環(huán)境變量,添加環(huán)境變量,刪除環(huán)境變量。
#node中常用的到的環(huán)境變量是NODE_ENV,首先查看是否存在 set NODE_ENV #如果不存在則添加環(huán)境變量 set NODE_ENV=production #環(huán)境變量追加值 set 變量名=%變量名%;變量內(nèi)容 set path=%path%;C:\web;C:\Tools #某些時(shí)候需要?jiǎng)h除環(huán)境變量 set NODE_ENV=
永久配置
右鍵(此電腦) -> 屬性(R) -> 高級系統(tǒng)設(shè)置 -> 環(huán)境變量(N)...
Linux配置
臨時(shí)
查看環(huán)境變量,添加環(huán)境變量,刪除環(huán)境變量
#node中常用的到的環(huán)境變量是NODE_ENV,首先查看是否存在 echo $NODE_ENV #如果不存在則添加環(huán)境變量 export NODE_ENV=production #環(huán)境變量追加值 export path=$path:/home/download:/usr/local/ #某些時(shí)候需要?jiǎng)h除環(huán)境變量 unset NODE_ENV #某些時(shí)候需要顯示所有的環(huán)境變量 env
永久
打開配置文件所在
# 所有用戶都生效 vim /etc/profile # 當(dāng)前用戶生效 vim ~/.bash_profile
在文件末尾添加類似如下語句進(jìn)行環(huán)境變量的設(shè)置或修改
# 在文件末尾添加如下格式的環(huán)境變量 export path=$path:/home/download:/usr/local/ export NODE_ENV = product
最后修改完成后需要運(yùn)行如下語句令系統(tǒng)重新加載
# 修改/etc/profile文件后 source /etc/profile # 修改~/.bash_profile文件后 source ~/.bash_profile
解決環(huán)境導(dǎo)致后端接口變換問題
搞清楚這個(gè)問題后,我們就可以在不同環(huán)境的機(jī)器上設(shè)置不同的 NODE_ENV,當(dāng)然這個(gè)字段也不一定。
你也可以換成其他的NODE_ENV_NIZUISHUAI等等,反正是自定義的。
解決步驟
1.修改代碼里的后端地址配置
很簡單,就是利用 process.env.NODE_ENV這個(gè)字段來判斷。(process是node全局屬性,直接用就行了)

2.在linux上設(shè)置環(huán)境變量
export NODE_ENV=dev
然后你就可以去愉快的啟動(dòng)項(xiàng)目玩了。
說在最后
因?yàn)槲椰F(xiàn)在這個(gè)項(xiàng)目 React 服務(wù)端渲染。所以后端的請求轉(zhuǎn)發(fā)就沒交給nginx進(jìn)行處理。
像平常的純單頁應(yīng)用,一般是用nginx進(jìn)行請求轉(zhuǎn)發(fā)的。
本篇成文比較快,哈哈,如果文內(nèi)有任何的紕漏,還請指點(diǎn),我也就學(xué)習(xí)學(xué)習(xí)啦。
另外,如果這篇小小的文章對你帶來幫助,不妨給我點(diǎn)個(gè)贊吧,這將是我繼續(xù)下的一大動(dòng)力。
謝謝~~
參考文獻(xiàn)
- 環(huán)境變量-JasperXu的博客 :http://sorex.cnblogs.com/p/6200940.html
- 如何查看并設(shè)置NODE_ENV的值? : http://cnodejs.org/topic/587dc8a62967eeb01aafe87b
- Node.js的process模塊 : http://www.css88.com/archives/4548
注: 【如何配置環(huán)境變量】這一塊的內(nèi)容,是直接引用的 JasperXu的博客 的環(huán)境變量。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
nodejs 十六進(jìn)制字符串型數(shù)據(jù)與btye型數(shù)據(jù)相互轉(zhuǎn)換
這篇文章主要介紹了nodejs 十六進(jìn)制字符串型數(shù)據(jù)與btye型數(shù)據(jù)相互轉(zhuǎn)換,需要的朋友可以參考下2018-07-07
nodejs和npm版本不匹配:ERROR:?npm?v9.5.1?is?known?not?to?run
本文主要介紹了nodejs和npm版本不匹配:ERROR:?npm?v9.5.1?is?known?not?to?run?on?Node.js,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06
node.js基于dgram數(shù)據(jù)報(bào)模塊創(chuàng)建UDP服務(wù)器和客戶端操作示例
這篇文章主要介紹了node.js基于dgram數(shù)據(jù)報(bào)模塊創(chuàng)建UDP服務(wù)器和客戶端操作,結(jié)合實(shí)例形式分析了node.js使用dgram數(shù)據(jù)報(bào)模塊創(chuàng)建UDP服務(wù)器和客戶端,以及進(jìn)行UDP廣播、組播相關(guān)操作技巧,需要的朋友可以參考下2020-02-02
在nodejs中創(chuàng)建child process的方法
這篇文章主要介紹了在nodejs中創(chuàng)建child process的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Node.js實(shí)現(xiàn)讀取Excel數(shù)據(jù)并插入MySQL
這篇文章主要為大家詳細(xì)介紹了Node.js如何實(shí)現(xiàn)讀取Excel數(shù)據(jù)并插入到MySQL數(shù)據(jù)庫中,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11
Node.js中的WebSocket底層實(shí)現(xiàn)
WebSockets是基于HTTP的雙向通信協(xié)議,允許客戶端和服務(wù)器之間實(shí)現(xiàn)實(shí)時(shí)、持久的數(shù)據(jù)交換,本文詳細(xì)介紹了使用JavaScript和Node.js創(chuàng)建WebSockets服務(wù)器和客戶端的過程,感興趣的可以了解一下2024-10-10
Node.js使用Express創(chuàng)建Web項(xiàng)目詳細(xì)教程
如果需要入門使用node.js進(jìn)行web開發(fā),正在學(xué)習(xí) nodejs web開發(fā)指南 的和想快速了解node.js web開發(fā)模式的朋友,相信本文是有一定幫助意義的。2017-03-03

