需求
最近需要迁移Node线上服务,于是新申请了两台线上服务器;
部署服务器后,需要验证服务是否正常,办公环境与线上环境网络是隔离的,无法直接访问;但是,线上服务器可通过部署服务器访问,而办公网络是可以访问部署机的;
所以,可通过在部署机上配置代理的方式,办公环境请求部署机,然后把请求代理到线上服务的方式验证服务是否正常。
整个网络结构如下图所示:
Nginx安装
下载
下载页面: http://nginx.org/en/download.html选择版本鼠标右键拷贝链接地址
?安装
?默认安装,非root权限会报如下错误
?默认安装后,查看nginx的安装目录,可以看到安装在/usr/local/nginx目录下
?
1.建议使用指定目录方式安装。如果切换为root权限去安装,后续修改config文件也需要root权限
2.或者root安装后,修改权限为普通用户可操作也行
添加软链
添加软链,使得nginx命令全局能访问,每次运行就不用切换到安装目录中了
?常用命令
- 启动:nginx
- 停止:nginx -s stop
- 重启:nginx -s reload
- 帮助命令: nginx -h
强制停止:
?配置代理
配置两台机器的请求转发,编辑nginx安装目录下的nginx/conf/nginx.conf文件即可
?注意:修改完nginx的配置文件后,需要运行nginx -s reload才能生效
验证
由于线上服务很多都是需要登录的,所以访问时需要使用域名访问,而不能使用IP访问,因为cookie都是跟域名绑定的
解决这个问题很简单,配置本机host即可
?通过上述配置,在本机浏览器上请求xxx.daojia.com即可间接通过部署机上的Nginx访问到线上服务,以此在内网测试服务是否正确;待服务无异常后,把线上流量切过来即可。
到此这篇关于通过Nginx解决网络隔离实践记录详解的文章就介绍到这了,更多相关Nginx 网络隔离内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://segmentfault.com/a/1190000022554783