目录
1. 一些基本概念
1.1 Nginx初步认识
1.2 正向/反向代理
1.3 域名和IP
2. Nginx 安装和配置
2.1 安装
2.2 配置
3. Nginx的使用
3.1 部署静态网页
3.2 反向代理和负载均衡
4 课外知识导读
1. URL和URI
编辑 2. DNS解析过程
1. 一些基本概念
1.1 Nginx初步认识
1.2 正向/反向代理
1. 正向代理
正向代理是位于客户端和原始服务器之间的服务器,为了能够从原始服务器获取请求的内容,客户端需 要将请求发送给代理服务器,然后再由代理服务器将请求转发给原始服务器,原始服务器接受到代理服 务器的请求并处理,然后将处理好的数据转发给代理服务器,之后再由代理服务器转发发给客户端,完 成整个请求过程。
正向代理的典型用途就是为在防火墙内的局域网客户端提供访问Internet的途径 , 比如:
正向代理服务器是为用户服务的
1.3 域名和IP
- 11.22.34.45
2. Nginx 安装和配置
2.1 安装
1. 官方地址 : http://nginx.org/2. Nginx 相关依赖 :OpenSSL: http://www.openssl.org/./configmakemake test (可选)make install ( 使用管理员权限执行该命令 )
密码库使用 https 进行通信的时候使用ZLib 下载 : http://www.zlib.net/数据压缩安装 :./configuremakesudo make installPCRE 下载 : http://www.pcre.org/解析正则表达式安装./configuremakesudo make install
nginx 的安装# nginx 工作时候需要依赖三个库# 三个参数 = 这三个库对应的源码安装目录# 根据自己的电脑的库安装包的位置进行指定./configure --with-openssl = ../openssl-1.0.1t --with-pcre = ../pcre-8.40 --with-zlib = ../zlib-1.2.11makesudo make install
/usr/local/nginxconf - > 存储配置文件的目录html - > 默认的存储网站 ( 服务器 ) 静态资源的目录 [ 图片 , html, js, css]logs - > 存储 log 日志sbin - > 启动 nginx 的可执行程序
/usr/local/nginx/sbin/nginx# 快速启动的方式# 1. 将 /usr/local/nginx/sbin/ 添加到环境变量 PATH 中# 2. /usr/local/nginx/sbin/nginx 创建软连接 , 放到 PATH 对应的路径中 , 比如 : /usr/binln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx
# 假设软连接已经创建完毕sudo nginx # 启动
# 第一种 , 马上关闭sudo nginx -s stop# 第二种 , 等 nginx 作为当前操作之后关闭sudo nginx -s quit
sudo nginx -s reload # 修改了 nginx 的配置文件之后 , 需要执行该命令
测试是否安装成功知道nginx 对应的主机的 IP 地址 - > 192.168.1.100在浏览器中访问该IP 地址看到一个welcom nginx的欢迎界面
2.2 配置
1. Nginx配置文件的位置
/usr/local/nginx/conf/nginx.conf
user nobody; # 启动之后的 worker 进程属于谁- 错误提示 : nginx 操作 xxx 文件时候失败 , 原因 : Permission denied- 将 nobody - > rootworker_processes 1; # 设置 worker 进程的个数 , 最大 == cpu 的核数 ( 推荐 )error_log logs/error.log; # 错误日志 , /usr/local/nginxpid logs/nginx. pid ; # pid 文件 , 里边是 nginx 的进程 ID# nginx 的事件处理events {use epoll; # 多路 IO 转接模型使用 epollworker_connections 1024; // 每个工作的进程的最大连接数}http - > server - > 每个 server 模块可以看做一台 web 服务器server {listen 80; # web 服务器监听的端口 , http 协议的默认端口 https: 默认是443 ftp :21 ssh,sftp 22server_name localhost; # 对应一个域名 , 客户端通过该域名访问服务器charset utf8; # 字符串编码location { // 模块 , 处理客户端的请求}# 客户端 ( 浏览器 ), 请求 :http ://192.168.10.100:80/login. html# 服务器处理客户端的请求服务器要处理的指令如何从 url 中提取 ?- 去掉协议 : http- 去掉 IP / 域名 + 端口 : 192.168.10.100: 80- 最后如果是文件名 , 去掉该名字 : login. html- 剩下的 : /服务器要处理的 location 指令 :location /{处 理动作}
3. Nginx的使用
3.1 部署静态网页
/usr/local/nginx/html
应该在 /usr/local/nginx/mkdir /usr/local/nginx/mydir
在 Nginx 服务器上进行网页部署 , 实现如下访问 :在 /usr/local/nginx/ 创建新的目录 , yundisk 用来存储静态网页
/ - > 服务器的资源根目录 , /usr/local/nginx/yundisklogin.htm-> 放到 yundisk 中
服务器要处理的动作
# 对应这个请求服务器要添加一个 locationlocation 指令 ( / ){# 找一个静态网页root yundisk; # 相对于 /usr/local/nginx/ 来找# 客户端的请求是一个目录 , nginx 需要找一默认显示的网页,就是index.html的一个文件。index index . html index .htm;}# 配置之后重启 nginxsudo nginx -s reload
配置文件的内容
访问地址: http://192.168.80.254/hello/reg.html
hello是什么?
是目录
reg.html放到哪儿?
hello目录中
如何添加location
location /hello/{root yundisk;index xx.html;}
访问地址: http://192.168.80.254/upload/ 浏览器显示upload.html
直接访问一个目录, 得到一默认网页。
upload是一个目录, uplaod.html应该再upload目录中
location /upload/{root yundisk;index upload.html; #index 只有访问目录的时候才会生效,否则已经会访问指定的网页。}
3.2 反向代理和负载均衡
1. 需要客户端 - 1 个Window中的浏览器作为客户端2. 反向代理服务器 -> 1 个window作为反向代理服务器3. web 服务器 -> 2 个ubtu - cat: 192.168.91.130ubuntu - copy: 192.168.91.131
1. 反向代理设置
找 window 上对应的 nginx 的配置文件- conf/nginx. conf# 代理几台服务器就需要几个 server 模块# 客户端访问的 url: http://192.168.1.100/login.htmlserver {listen 80; # 客户端访问反向代理服务器 , 代理服务器监听的端口server_name ubuntu.com; # 客户端访问反向代理服务器 , 需要一个域名location / {# 反向代理服务器转发指令 , http:// 固定proxy_pass http ://robin.test.com;}}# 添加一个代理模块upstream robin.test. com{server 192.168.247.91:130;}# luffyserver {listen 80; # 客户端访问反向代理服务器 , 代理服务器监听的端口server_name hello.com; # 客户端访问反向代理服务器 , 需要一个域名location / {# 反向代理服务器转发指令 , http:// 固定proxy_pass http ://luffy.test.com;}}# 添加一个代理模块upstream luffy.test. com{server 192.168.26.250:80;}}
server {listen 80; # 客户端访问反向代理服务器 , 代理服务器监听的端口server_name localhost; # 客户端访问反向代理服务器 , 需要一个域名location / {# 反向代理服务器转发指令 , http:// 固定的头proxy_pass http ://linux.com;}location /hello/ {# 反向代理服务器转发指令 , http:// 固定的头proxy_pass http ://linux.com;}location /upload/ {# 反向代理服务器转发指令 , http:// 固定的头proxy_pass http ://linux.com;}}# 添加一个代理模块upstream linux. com{server 192.168.247.135: 80 weight =1;server 192.168.26.250: 80 weight =3;}## =====================================web 服务器需要做什么 ?# 192.168.247.135location /{root xxx;index xxx;}location /hello/{root xx;index xxx;}location /upload/{root xxx;index xx;}# 192.168.26.250location /{root xxx;index xxx;}location /hello/{root xx;index xxx;}location /upload/{root xxx;index xx;}
4 课外知识导读
1. URL和URI
1. 概念
URL(Uniform Resource Locator): 统一资源定位符表示资源位置的字符串基本格式 : " 协议 ://IP 地址 / 路径和文件名 "x p://xp.is.co.za/rfc/rfc1808.txthttp://www.ietf.org/rfc/rfc2396.txttelnet://192.0.2.16:80/URN(Uniform Resource Name): 统一资源名称P2P 下载中使用的磁力链接URI(Uniform Resource Identifier): 统一资源标识符是一个紧凑的字符串用来标示抽象或物理资源 , URL 是 URI 的一种让 URI 能成为 URL 的当然就是那个 “ 访问机制 ” , “ 网络位置 ” 。 e.g. http:// or x p:// 。files.hp.comtel:+1-816-555-1212x p://xp.is.co.za/rfc/rfc1808.txt (also a URL)http://www.ietf.org/rfc/rfc2396.txt (also a URL)telnet://192.0.2.16:80/ (also a URL)
UIRI 可以没有协议 , 没有地址 (IP/ 域名 )
2. DNS解析过程
1. DNS解析的过程
1. 在浏览器中输入 www.magedu.com 域名,操作系统会先检查自己本地的 hosts 文件是否有这个网址映射关系,如果有,就先调用这个 IP 地址映射,完成域名解析。2. 如果 hosts 里没有这个域名的映射,则查找本地 DNS 解析器缓存,是否有这个网址映射关系,如果有,直接返回,完成域名解析。Windows 和 Linux 系统都会在本地缓存 dns 解析的记录,提高速度。3. 如果 hosts 与本地 DNS 解析器缓存都没有相应的网址映射关系,首先会找 TCP/IP 参数中设置的首选DNS 服务器,在此我们叫它本地 DNS 服务器,此服务器收到查询时,如果要查询的域名,包含在本地配置区域资源中,则返回解析结果给客户机,完成域名解析,此解析具有权威性。4. 如果要查询的域名,不由本地 DNS 服务器区域解析,但该 DNS 服务器已缓存了此网址映射关系,则调用这个 IP 地址映射,完成域名解析,此解析不具有权威性。5. 如果本地 DNS 服务器本地区域文件与缓存解析都失效,则根据本地 DNS 服务器的设置(没有设置转发器)进行查询,如果未用转发模式,本地 DNS 就把请求发至 13 台根 DNS ,根 DNS 服务器收到请求后会判断这个域名 (.com) 是谁来授权管理,并会返回一个负责该顶级域名服务器的一个 IP 。本地DNS 服务器收到 IP 信息后,将会联系负责 .com 域的这台服务器。这台负责 .com 域的服务器收到请求后,如果自己无法解析,它就会找一个管理 .com 域的下一级 DNS 服务器地址 (magedu.com) 给本地DNS 服务器。当本地 DNS 服务器收到这个地址后,就会找 magedu.com 域服务器,重复上面的动作进行查询,直至找到 www.magedu.com 主机。6. 如果用的是转发模式(设置转发器),此 DNS 服务器就会把请求转发至上一级 ISP DNS 服务器,由上一级服务器进行解析,上一级服务器如果不能解析,或找根 DNS 或把转请求转至上上级,以此循环。不管是本地 DNS 服务器用是是转发,还是根提示,最后都是把结果返回给本地 DNS 服务器,由此 DNS 服务器再返回给客户机。
2. 域名解析服务器
Pod DNS+:首选: 119.29.29.29备选: 182.254.116.116114DNS:首选: 114.114.114.114备选: 114.114.114.115阿里 AliDNS:首选: 223.5.5.5备选: 223.6.6.6
3. hosts文件
# 存储的是域名和 IP 的对应关系-windows 目录 : "C:\Windows\System32\drivers\etc\hosts"