学好Nginx,走遍天下都不怕(学好一门手艺走遍天下都不怕)
ztj100 2025-07-03 20:57 3 浏览 0 评论
说到Nginx,大家可能会闪过几个画面
1、这不是后端运维要用到技术吗,前端为啥要学这个
2、我学Nginx也没啥用啊
3、学了Nginx我能涨薪吗
4、。。。
一、简介
我个人拙见,前端本身就是一个很杂,且边界比较模糊的职业。若是在大公司,当然前端可能只需要专注页面上的业务开发,部署项目这块会交给一些专业的运维同事,轮不到你来操心这些事情。但很遗憾,大部分程序员不在大公司工作,多数就职于中小型的小厂。那么在小厂的话,很大概率上公司是没有运维人员的,前端项目的部署和运维很可能就会交给前端同学来管理。再退一步讲,平时我们接一些私活或者自己玩一些项目,都是需要部署到线上服务器。那么就可以选择我们好用的Nginx,借用官方的解释——“Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务“
二、需要的环境
学习Nginx需要什么环境呢?
1、买一个云服务器(腾讯云 or 阿里云)价格有点贵,就我目前而言,买的是腾讯的99元包年,最近好像有活动(非广告)
2、自己找个电脑搭建一下服务器的环境
3、搞个虚拟机,但是配置及其麻烦,新手不建议尝试
我买的服务器操作系统是CentOS 7.6 64位
通过服务器提供的yum去安装一些工具库
远程登录服务器 ssh root@IP(这里的IP就是你购买服务器的IP地址),腾讯服务器里可以让你选择密码登录还是密钥登录,我选择添加本地密钥登录,这样比较方便,不用每次都输入密码。进入服务器之后就是这样的画面
服务器远程界面
然后输入下面这段代码,安装相应的工具包和库
yum -y install gcc gcc-c++ autoconf pcre-devel make automake yum -y install wget httpd-tools vim
基本上没什么大问题就会显示“Complete!”
恭喜你,服务器环境基本安装完毕~
三、搭建Nginx配置
个人建议,可以先去Nginx官方文档先看看,了解一下Nginx再开始下面的阅读,我尽量不说理论知识,讲一些实操,因为我觉得理论知识我说的肯定不如官网来得细致。
首先看看服务器内yum内的Nginx源的版本
yum list | grep nginx
这个版本不是很高,我们可以使用官方提供的源。
在终端输入如下
vim /etc/yum.repos.d/nginx.repo
然后填入下列代码,注意,我的centos是7.x版本,所以我写的是7,同学们可以按照自己的版本来
保存退出
然后安装 nginx
yum install nginx nginx -v
运行上面指令之后,能得到最新的nginx版本如下
只能用舒服二字形容,一切顺利安装好nginx,玩归玩,闹归闹,一定要把nginx掌握好~~~
四、Nginx的配置文件
通过‘rpm -ql nginx’ 指令查看nginx都安装到了哪些目录
几个关键的位置要注意一下:‘/etc/nginx’、'/etc/nginx/conf.d' 、‘/etc/nginx/nginx.conf’
解释一下‘/etc/nginx/nginx.conf’,因为这个是nginx的主配置,比较重要
输入命令行
cd /etc/nginx vim nginx.conf
#运行用户,默认即是nginx,可以不进行设置 user nginx; #Nginx进程,一般设置为和CPU核数一样 worker_processes 1; #错误日志存放目录 error_log /var/log/nginx/error.log warn; #进程pid存放位置 pid /var/run/nginx.pid; events { worker_connections 1024; # 单个后台进程的最大并发数 } http { include /etc/nginx/mime.types; #文件扩展名与类型映射表 default_type application/octet-stream; #默认文件类型 #设置日志模式 log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; #nginx访问日志存放位置 sendfile on; #开启高效传输模式 #tcp_nopush on; #减少网络报文段的数量 keepalive_timeout 65; #保持连接的时间,也叫超时时间 #gzip on; #开启gzip压缩 include /etc/nginx/conf.d/*.conf; #包含的子配置项位置和文件
再解释一下主文件中的子文件,就是上面这个include下的.conf文件
进入 '/etc/nginx/conf.d/' 这个文件夹,再通过vim或者cat打开
server { listen 80; #配置监听端口 server_name localhost; //配置域名 #charset koi8-r; #access_log /var/log/nginx/host.access.log main; location / { root /usr/share/nginx/html; #服务默认启动目录 index index.html index.htm; #默认访问文件 } #error_page 404 /404.html; # 配置404页面 # redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; #错误状态码的显示页面,配置后需要重启 location = /50x.html { root /usr/share/nginx/html; } # proxy the PHP scripts to Apache listening on 127.0.0.1:80 # #location ~ \.php$ { # proxy_pass http://127.0.0.1; #} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 # #location ~ \.php$ { # root html; # fastcgi_pass 127.0.0.1:9000; # fastcgi_index index.php; # fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; # include fastcgi_params; #} # deny access to .htaccess files, if Apache's document root # concurs with nginx's one # #location ~ /\.ht { # deny all; #} }
这里的root表示,项目文件是放在'/usr/share/nginx/html'下面,那么我们就去看看这里有啥呢
就这俩玩意儿,也就是一个默认的index文件和报错的时候会展示的50x.html页面
通过安全组的配置,允许浏览器访问服务器地址的80端口,下面就是我的腾讯云服务器的默认首页
安全组的配置会有些复杂,需要一些网络协议的知识,不过腾讯云提供了视频教程,大家可以看看地址在这里
这里还有一个小问题,就是当你们配置好default.conf的时候,需要重启nginx才能运行新改的配置,这里在服务器里运行指令 'nginx -s reload' 会报错‘nginx: [error] open() "/var/run/nginx.pid" failed (2: No such file or directory)’, 这个时候可以如下
// 先输入 nginx nginx -s reload
或者是如果你使用iTerm的话,可以配置.bashrc文件,添加一个alias的配置来简化运行nginx指令;或者是通过指令 ‘systemctl start nginx.service’ 启动nginx服务,通过指令 ‘ps aux | grep nginx’ 查看nginx是否是否启动;还有很多nginx的指令,大家自行去官网查看,这里不多bb了。
五、亲手配置404错误页面
打开default.conf文件进行编辑
添加一个errorpage配置,然后再去配置 /usr/share/nginx/html里面的404_error.html
直接输入指令'vim 404_error.html'就会直接创建html文件
保存退出之后,记得重启一下nginx,然后去浏览器随便输入一个未知的路径,就能看到404页面如下
还能将位置页面指向另一个网址,default.conf如下设置
刷新刚才的浏览器页面,就会跳转到百度的首页去了
六、权限配置
简单的说,就是我想让谁能访问我的服务器,谁禁止访问我的浏览器
关键词是 ‘allow’和'deny'
顾名思义,allow就是允许谁访问,deny就是禁止谁访问
首先看看自己的ip地址,通过这个网址来获取
我的ip地址是'112.10.54.90',那么我来禁止我的ip访问服务器
location / { root /usr/share/nginx/html; index index.html index.htm; deny 112.10.54.90; }
重启nginx之后,访问ip地址首页,结果如下
403禁止访问
还可以更精准的定位某个路径下不可访问,如下设置
location =/admin { deny all }
不再演示了,自行操作,光看可不行,请自己多多练习,看别人bb没用的
七、虚拟主机的设置
三种形式
1、基于端口号配置
2、基于域名配置
3、基于IP配置
工作中一般是不会基于IP配置的,因为哪来那么多钱买那么多IP呢,多数都是通过域名来配置,设置一下二级域名,做一个反向代理啥的。通过端口号也不多,因为我总不能在域名后面加个端口号把,十分难看且不雅。
着重讲一讲通过域名配置的情况,大家可以去买个域名玩一玩,几块几十块就有一个属于自己的船新域名,多的不说,去万网买一个吧。买完之后,通过解析添加一条记录如下
域名解析记录
同理再添加一条记录,主机记录命名为nginx2
那么现在我就有两个二级域名
1、nginx.chennick.wang
2、nginx2.chennick.wang
那么用第一个域名指向默认的nginx首页,用第二个新建一个虚拟主机
第一个域名的配置
第二个域名的配置
回去设置一下第二个域名的index2.html
index2.html
nginx.chennick.wang
nginx2.chennick.wang
玩到这儿,基本上你也就差不多入门了nginx的配置了
八、Nginx反向代理
反向代理对前端而言,是非常有用的,因为前端的跨域问题跨域通过反向代理来解决。废话不多说,进入正题。
如何配置反向代理呢,配置如下
server{ listen 80; server_name nginx2.chennick.wang; location / { proxy_pass https://www.baidu.com/; } }
上述配置,在浏览器访问nginx2.chennick.wang这个域名的时候,展示的页面是https://www.baidu.com/的页面,如下图所示
反向代理到百度
还有一些对PC端和移动端的判断,类似浏览器的userAgent去判断,然后根据PC和Mobile返回不同的站点,这里就不展开多说了,东西都差不多,看文档就行。
最后再多说一句,小伙伴们一定要自己去亲手写一写,光蹭一蹭不进去,是不行滴
文章借鉴了胖哥的Nginx系列教程,同学们想看视频的话可以移步到胖哥那儿看免费视频教程
一个前端必会的 Nginx免费教程 (共11集)jspang.com
PS:(补充于2019年9月4日快下班的时候)
在云端服务器配置node环境:
这里推荐大家使用nvm去安装node,版本随时可以升级降级,非常友好,不过不建议在服务器随便升降版本,很危险。。。
具体方法:
1、通过 wget 下载nvm的sh脚本
wget -qO- https://raw.githubusercontent.com/creationix/nvm/v0.33.6/install.sh | bash
2、先更新一下bash_profile文件
source ~/.bash_profile
3、安装完成以后使用 nvm - v 来测试安装是否成功
nvm -v
4、安装成功以后会显示版本号和nvm 相关命令等提示
nvm install v12.6.0 nvm use v12.6.0 nvm alias default v12.6.0
然后就能在全局使用npm
有需要下载资料的可以私信1噢
相关推荐
- 人生苦短,我要在VSCode里面用Python
-
轻沉发自浅度寺量子位出品|公众号QbitAI在程序员圈子里,VisualStudioCode(以下简称VSCode)可以说是目前最火的代码编辑器之一了。它是微软出品的一款可扩展的轻量...
- 亲测可用:Pycharm2019.3专业版永久激活教程
-
概述随着2020年的到来,又有一批Pycharm的激活码到期了,各位同仁估计也是在到处搜索激活方案,在这里,笔者为大家收录了一个永久激活的方案,亲测可用,欢迎下载尝试:免责声明本项目只做个人学习研究之...
- Python新手入门很简单(python教程入门)
-
我之前学习python走过很多的歧途,自学永远都是瞎猫碰死耗子一样,毫无头绪。后来心里一直都有一个做头条知识分享的梦,希望自己能够帮助曾经类似自己的人,于是我来了,每天更新5篇Python文章,喜欢的...
- Pycharm的设置和基本使用(pycharm运行设置)
-
这篇文章,主要是针对刚开始学习python语言,不怎么会使用pycharm的童鞋们;我来带领大家详细了解下pycharm页面及常用的一些功能,让大家能通过此篇文章能快速的开始编写python代码。一...
- 依旧是25年最拔尖的PyTorch实用教程!堪比付费级内容!
-
我真的想知道作者到底咋把PyTorch教程整得这么牛的啊?明明在内容上已经足以成为付费教材了,但作者偏要免费开源给大家学习!...
- 手把手教你 在Pytorch框架上部署和测试关键点人脸检测项目DBFace
-
这期教向大家介绍仅仅1.3M的轻量级高精度的关键点人脸检测模型DBFace,并手把手教你如何在自己的电脑端进行部署和测试运行,运行时bug解决。01.前言前段时间DBFace人脸检测库横空出世,...
- 进入Python的世界02外篇-Pycharm配置Pyqt6
-
为什么这样配置,要开发带UI的python也只能这样了,安装过程如下:一安装工具打开终端:pipinstallPyQt6PyQt6-tools二打开设置并汉化点击plugin,安装汉化插件,...
- vs code如何配置使用Anaconda(vscode调用anaconda库)
-
上一篇文章中(Anaconda使用完全指南),我们能介绍了Anaconda的安装和使用,以及如何在pycharm中配置Anaconda。本篇,将继续介绍在vscode中配置conda...
- pycharm中conda解释器无法配置(pycharm配置anaconda解释器)
-
之前用的好好的pycharm正常配置解释器突然不能用了?可以显示有这个环境然后确认后可以conda正在配置解释器,但是进度条结束后还是不成功!!试过了pycharm重启,pycharm重装,anaco...
- Volta:跨平台开发者的福音,统一前端js工具链从未如此简单!
-
我们都知道现在已经进入了Rust时代,不仅很多终端常用的工具都被rust重写了,而且现在很多前端工具也开始被Rust接手了,这不,现在就出现了一款JS工具管理工具,有了它,你可以管理多版本的js工具,...
- 开发者的福音,ElectronEgg: 新一代桌面应用开发框架
-
今天给大家介绍一个开源项目electron-egg。如果你是一个JS的前端开发人员,以前面对这项任务桌面应用开发在时,可能会感到无从下手,甚至觉得这是一项困难的挑战。ElectronEgg的出现,它能...
- 超强经得起考验的低代码开发平台Frappe
-
#挑战30天在头条写日记#开始进行管理软件的开发来讲,如果从头做起不是不可以,但选择一款免费的且经得起时间考验的低代码开发平台是非常有必要的,将大幅提升代码的质量、加快开发的效率、以及提高程序的扩展性...
- 一文带你搞懂Vue3 底层源码(vue3核心源码解析)
-
作者:妹红大大转发链接:https://mp.weixin.qq.com/s/D_PRIMAD6i225Pn-a_lzPA前言vue3出来有一段时间了。今天正式开始记录一下梗vue3.0.0-be...
- 基于小程序 DSL(微信、支付宝)的,可扩展的多端研发框架
-
Mor(发音为/mr/,类似more),是饿了么开发的一款基于小程序DSL的,可扩展的多端研发框架,使用小程序原生DSL构建,使用者只需书写一套(微信或支付宝)小程序,就可以通过Mor...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 人生苦短,我要在VSCode里面用Python
- 亲测可用:Pycharm2019.3专业版永久激活教程
- Python新手入门很简单(python教程入门)
- Pycharm的设置和基本使用(pycharm运行设置)
- 依旧是25年最拔尖的PyTorch实用教程!堪比付费级内容!
- 手把手教你 在Pytorch框架上部署和测试关键点人脸检测项目DBFace
- 进入Python的世界02外篇-Pycharm配置Pyqt6
- vs code如何配置使用Anaconda(vscode调用anaconda库)
- pycharm中conda解释器无法配置(pycharm配置anaconda解释器)
- Volta:跨平台开发者的福音,统一前端js工具链从未如此简单!
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)