600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 有关Node环境变量 process.env 的问题

有关Node环境变量 process.env 的问题

时间:2019-02-12 04:00:37

相关推荐

有关Node环境变量 process.env 的问题

web前端|js教程

process.env,Node,变量

web前端-js教程

微商城 源码下载,vscode爬虫实例,ubuntu怎么插入字符,tomcat启动一,sqlite网页管理,discuz 插件教程,写前端用什么框架,autojs 爬虫 小说,php 字符转换,seo广西,缤纷夏日网站导航,网页登录模块,安装模板或插入不是正版,页面展开代替弹窗的网站,sqlserver学生成绩管理系统,测试题小程序源码lzw

前言

这两天在和运维GG搞部署项目的事儿。

电影新闻 asp源码,vscode 块编辑,ubuntu系统怎么让字符高亮,tomcat的外部,基于C语言sqlite,jqeury 横向滚动插件,前端框架配置教程学习,高级爬虫可以爬什么,php mysql 集成,seo推广技能,手机自定义网站导航,网页图像标注插件,台模 模板,转址 程序 源码lzw

碰到一个问题就是,咱们的dev,uat,product环境的问题。

日程管理软件 源码,ubuntu中加压命令,cat导致tomcat无法启动,爬虫 数据 存储,PHP疫情系统源码,做品牌推广十年乐云seo包成功lzw

因为是前后端分离,所以在开发和部署的过程中会有对后端接口的域名的切换问题。折腾了一下午,查询了各种资料这才把这Node环境变量process.env给弄明白。

下面这就做个问题解决的记录。希望能对这个不明白的人有所帮助。

Node环境变量

首先,咱们在做reactvue的单页应用开发的时候,相信大家对配置文件里的process.env并不眼生。

想不起来? 黑人问号.jpg。

就是下面这些玩意儿。

从字面上看,就是这个env属性,在developmentproduction不同环境上,配置会有些不同。

行,那下面我们开始看看这个所谓的process到底是个什么东西。

process(进程)其实就是存在nodejs中的一个全局变量。

然后呢,咱们可以通过这个所谓的进程能拿到一些有意思的东西。

不过我们今天主要是讲讲process.env

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这个字段来判断。(processnode全局属性,直接用就行了)

2.在linux上设置环境变量

export NODE_ENV=dev

然后你就可以去愉快的启动项目玩了。

说在最后

因为我现在这个项目 React 服务端渲染。所以后端的请求转发就没交给nginx进行处理。

像平常的纯单页应用,一般是用nginx进行请求转发的。

本篇成文比较快,哈哈,如果文内有任何的纰漏,还请指点,我也就学习学习啦。

另外,如果这篇小小的文章对你带来帮助,不妨给我点个赞吧,这将是我继续下的一大动力。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。