NGIXN
- Nginx学习
反向代理、负载均衡 - 初识Nginx
- 下载安装文件
- 官网下载地址:http://nginx.org/en/download.html
- 使用情景
- 我们公司项目刚刚上线的时候,并发量小,用户使用的少,所以在低并发的情况下,一个jar包启动应用就够了,然后内部tomcat返回内容给用户。
- 但是慢慢的,使用我们平台的用户越来越多了,并发量慢慢增大了,这时候一台服务器满足不了我们的需求了。
- 于是我们横向扩展,又增加了服务器。这个时候几个项目启动在不同的服务器上,用户要访问,就需要增加一个代理服务器了,通过代理服务器来帮我们转发和处理请求。
- 我们希望这个代理服务器可以帮助我们接收用户的请求,然后将用户的请求按照规则帮我们转发到不同的服务器节点之上。这个过程用户是无感知的,用户并不知道是哪个服务器返回的结果,我们还希望他可以按照服务器的性能提供不同的权重选择。保证最佳体验!所以我们使用了Nginx。
- 什么是Nginx?
- Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。2011年6月1日,nginx 1.0.4发布。
- 其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。在全球活跃的网站中有12.18%的使用比率,大约为2220万个网站。
- Nginx 是一个安装非常的简单、配置文件非常简洁(还能够支持perl语法)、Bug非常少的服务。Nginx 启动特别容易,并且几乎可以做到7*24不间断运行,即使运行数个月也不需要重新启动。你还能够不间断服务的情况下进行软件版本的升级。
- Nginx代码完全用C语言从头写成。官方数据测试表明能够支持高达 50,000 个并发连接数的响应。
- Nginx作用?
Http代理,反向代理:作为web服务器最常用的功能之一,尤其是反向代理。
- 正向代理
理解:相当于vpn一样,需要我们客户端去连接vpn,vpn才会帮我们代理,是作用在我们客户端的一种代理
- 图例
- 反向代理
理解;就像我们访问www.baidu.com 我们只访问了这一个地址,但是百度的服务器肯定不只是一个,那是怎么做到我们访问一个地址就可以转发发到不同服务器上的呢?nginx会拦截我们的所有请求,nginx后边会有很多服务器,根据服务器的权重进行负载均衡将拦截的请求分配到不同的服务器上。
- 图例:
- 负载均衡
- 说明:Nginx提供的负载均衡策略有2种:内置策略和扩展策略。内置策略为轮询,加权轮询,Ip hash。扩展策略,就天马行空,只有你想不到的没有他做不到的。
- 轮询
请求过来以后,会依次分配给不同的服务器(一个一个来)
- 图例 :
- 加权轮询
理解:有点服务器是64G、有的服务器是8G的,如果过来大量的请求,轮询的话可能64G的抗的住,但是8G的服务器就抗不住了,所以能者多劳,谁牛逼,谁多抗一些,如何让更多的请求分配给64G的服务器呢,设置各个服务器的权重即可。
- 图例:
- iphash
对客户端请求的ip进行hash操作,然后根据hash结果将同一个客户端ip的请求分发给同一台服务器进行处理,可以解决session不共享的问题。
- 图例:
- 动静分离
在我们的软件开发中,有些请求是需要后台处理的,有些请求是不需要经过后台处理的(如:css、html、jpg、js等等文件),这些不需要经过后台处理的文件称为静态文件。让动态网站里的动态网页根据一定规则把不变的资源和经常变的资源区分开来,动静资源做好了拆分以后,我们就可以根据静态资源的特点将其做缓存操作。提高资源响应的速度。
- 图例:
- Nginx简单入门
- 安装-macOS
- brew install nginx
系统安装了 brew的情况下 - nginx -v
查看nginx是否安装成功
- 演示:
- 启动Nginx
- sudo nginx
备注:端口号是在配置文件 nginx.conf 里面配置的,默认端口是 8080 ,配置文件的位置 /usr/local/etc/nginx
- 演示:
- 遇到的问题:
- 说明:nginx.conf文件配置的nginx服务的端口被占用
- 启动 成功
- 配置Nginx监听端口
- vim /usr/local/etc/nginx/nginx.conf(编辑nginx.conf文件,修改server配置项下的listen属性监听的端口即可)
- 关闭nginx
- sudo nginx -s stop
- 重新加载nginx
- sudo nginx -s reload
- 可能遇到的问题
- 端口被占用
nginx: [emerg] bind() to 0.0.0.0:80 failed (48: Address already in use)
- 解决方法:修改 nginx.conf 文件里的端口号
- 权限不够
nginx: [alert] could not open error log file: open() “/usr/local/var/log/nginx/error.log” failed (13: Permission denied)
- 解决方法:在命令前加上 sudo,这时可能会要求输入密码,密码就是电脑的开机密码啦~
- cd /usr/local/cellar/nginx/1.12.1/bin➜ bin sudo brew services start nginxbin chmod a+x ./nginxchmod: Unable to change file mode on ./nginx: Operation not permitted//将nginx文件添加权限➜ bin sudo chmod a+x ./nginx➜ bin sudo ./nginxnginx: [emerg] getgrnam("root") failed in /usr/local/etc/nginx/nginx.conf:2//修改nginx.conf文件,然后重新启动nginx➜ 1.12.1 cd bin➜ bin sudo ./nginx➜ bin sudo nginx -s reload➜ bin sudo nginx -s stop
- 拓展:安装 homebrew
- 复制以下命令,终端粘贴,回车即可
- /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
- 常用命令
- nginx -s reload ----- 重新加载配置
- nginx -s reopen ----- 重启
- nginx -s stop ----- 停止
- nginx -s quit ----- 退出
- nginx -v ----- 查看版本
- nginx -V ----- 查看nginx的所有文件的位置
- -v 和-V的区别:
- nginx -c filename ----- 指定配置文件
- nginx -h ----- 帮助
- 图解Nginx
- 图例: