Nginx
-
概述:
-
什么是Nginx:Nginx 是一款高性能的 http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器 由俄罗斯的程序设计师伊戈尔·西索夫(Igor Sysoev)所开发,官方测试 nginx 能够支支撑 5 万并发链接,并且 cpu、内存等资源消耗却非常低,运行非常稳定
-
Nginx 应用场景:
- http 服务器。Nginx 是一个 http 服务可以独立提供 http 服务。可以做网页静态服务器
- 虚拟主机。可以实现在一台服务器虚拟出多个网站 例如个人网站使用的虚拟主机
- 反向代理,负载均衡。当网站的访问量达到一定程度后,单台服务器不能满足用户的请求时,需要用多台服务器集群可以使用 nginx 做反向代理 并且多台服务器可以平均分担负载,不会因为某台服务器负载高宕机而某台服务器闲置的情况
-
-
安装 和 使用:
- 在Windows中:
- 在Windows环境中进行安装:非常的简单 就是 下载压缩文件进行解压不要安装到有中文的路径中 安装完成之后的目录结构如下图:
- 使用也同样的非常简单:安装完成之后点击
nginx.exe
有黑窗口一闪而过(不是出现错误了)表示的是已经启动成功进行测试 在浏览器中输入loaclhost
出现下面页面表示启动成功
- 在Windows环境中进行安装:非常的简单 就是 下载压缩文件进行解压不要安装到有中文的路径中 安装完成之后的目录结构如下图:
- 在Linux中:(比较的复杂)
- 安装环境准备:安装步骤不需要记住 需要的时候来博客中看就行
- 首先需要安装gcc的环境:
yum install gcc-c++
- 需要第三方的开发包
-
PCRE:PCRE(Perl Compatible Regular Expressions)是一个 Perl 库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库
yum install -y pcre pcre-devel
注:pcre-devel 是使用 pcre 开发的一个二次开发库nginx 也需要此库
-
zlib:zlib 库提供了很多种压缩和解压缩的方式,nginx 使用 zlib 对 http 包的内容进行 gzip,所以需要在 linux 上安装 zlib 库。
yum install -y zlib zlib-devel
-
OpenSSL:OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。nginx 不仅支持http 协议,还支持 https(即在 ssl 协议上传输 http),所以需要在 linux安装 openssl 库
yum install -y openssl openssl-devel
-
- Nginx下载:从官方网站 下载 这里选择的是1.8.0的版本
- Nginx安装:
- 把 nginx 的源码包nginx-1.8.0.tar.gz上传到 linux 系统
- 解压:
tar zxvf nginx-1.8.0.tar.gz
- 进入nginx-1.8.0目录 使用 configure 命令创建 makeFile 文件
- Makefile是一种配置文件, Makefile 一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为 makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令
- configure参数:
- 进行编译:
make
- 安装:
make install
- 首先需要安装gcc的环境:
- 安装环境准备:安装步骤不需要记住 需要的时候来博客中看就行
- 在Windows中:
-
Nginx启动与访问
-
启动的步骤:
-
启动nginx 之前,上边将临时文件目录指定为
/var/temp/nginx/client
, 需要在/var下创建此目录mkdir /var/temp/nginx/client -p
-
进入到Nginx目录下的sbin目录
cd /usr/local/ngiux/sbin
-
输入命令启动Nginx
./nginx
-
启动后查看进程
ps aux|grep nginx
-
-
访问:浏览器地址栏输入IP即可访问(默认为80端口)
-
关闭 nginx:两种方式
./nginx -s stop ./nginx -s quit
-
重启:先关闭后启动 刷新配置文件
./nginx -s reload
-
-
Nginx静态网站部署:
- 静态网站的部署:就是将静态资源上传到服务器的
/usr/local/nginx/html
下即可访问 - 配置虚拟主机:
- 端口绑定:
-
资源上传
-
修改Nginx 的配置文件:
/usr/local/nginx/conf/nginx.conf
(修改了配置文件需要进行配置文件的重新) 重启之后需要将配置文件重加载nginx -s reload
server { listen 80; # 监听的端口 默认的是80 端口 server_name localhost; # 域名或ip location / { # 访问路径配置 root regist;# 根目录 index regist.html; # 默认首页 } error_page 500 502 503 504 /50x.html; # 错误页面 location = /50x.html { root html; } }
-
- 域名绑定:
- 什么是域名:域名(Domain Name),是由一串用“点”分隔的字符组成的Internet上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置,地理上的域名,指代有行政自主权的一个地方区域)。域名是一个IP地址上有“面具” 。域名的目的是便于记忆和沟通的一组服务器的地址(网站,电子邮件,FTP等)。域名作为力所能及难忘的互联网参与者的名称。域名按域名系统(DNS)的规则流程组成。在DNS中注册的任何名称都是域名。域名用于各种网络环境和应用程序特定的命名和寻址目的。通常,域名表示互联网协议(IP)资源,例如用于访问因特网的个人计算机,托管网站的服务器计算机,或网站本身或通过因特网传送的任何其他服务。世界上第一个注册的域名是在1985年1月注册的(百度百科)
- 域名与IP绑定:一个域名对应一个 ip 地址,一个 ip 地址可以被多个域名绑定
-
可以修改 hosts 文件(C:\Windows\System32\drivers\etc)配置域名和 ip 的映射关系,如果 hosts 文件中配置了域名和 ip 的对应关系,不需要走dns 服务器 修改完成之后 将localhost 替换成相应的域名
192.168.177.129 www.hmtravel.com
192.168.177.129 regist.hmtravel.com
-
- 端口绑定:
- 静态网站的部署:就是将静态资源上传到服务器的
-
Nginx反向代理与负载均衡
-
反向代理
-
什么是反向代理:反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器 简单的说 正向代理隐藏真实客户端,反向代理隐藏真实服务端 知乎上的老哥确实牛的
-
配置反向代理:修改配置文件进行配置 重启之后进行测试需要注意的是域名须配置域名指向
server { listen 80; # 监听的端口 server_name www.hmtravel.com; # 域名或ip location / { # 访问路径配置 # root index;# 根目录 proxy_pass http://tomcat;# index index.html index.htm; # 默认首页 } }
-
-
负载均衡
- 什么是负载均衡负载均衡 建立在现有网络结构之上,它提供了一种廉价有效透明的方法扩展网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性 负载均衡,英文名称为Load Balance,其意思就是分摊到多个操作单元上进行执行,例如Web服务器、FTP服务器、企业关键应用服务器和其它关键任务服务器等,从而共同完成工作任务
-
配置负载均衡:需要的就是将上面的tomcat复制三份,修改端口分别为8080 ,8081,8082 分别启动这三个tomcat服务修改配置文件:
upstream tomcat-travel { server 192.168.177.129:8080; server 192.168.177.129:8081; server 192.168.177.129:8082; } server { listen 80; # 监听的端口 server_name www.hmtravel.com; # 域名或ip location / { # 访问路径配置 # root index;# 根目录 proxy_pass http://tomcat-travel; index index.html index.htm; # 默认首页 } error_page 500 502 503 504 /50x.html; # 错误页面 location = /50x.html { root html; } }
-