1、京淘后台的优化
1.1 路径优化
1.1.1 编辑properties配置文件
1.1.2 编辑FileServiceImpl
2、实现商品图片回显
2.1 反向代理
反向代理服务器位于用户与目标服务器之间,但是对于用户而言,反向代理服务器就相当于目标服务器,即用户直接访问反向代理服务器就可以获得目标服务器的资源。同时,用户不需要知道目标服务器的地址,也无须在用户端作任何设定。反向代理服务器通常可用来作为Web加速,即使用反向代理作为Web服务器的前置机来降低网络和服务器的负载,提高访问效率。
特点:
1、反向代理服务器位于用户与目标服务器之间
2、对于用户而言,以为代理服务器就是真实的服务器
3、反向代理机制保护了真实的服务器信息
4、反向代理一般称之为服务端代理
步骤:
1、当用户发起请求时,该请求被代理服务器拦截
2、代理服务器查询自己的配置文件,根据url地址获取真实的服务器信息
3、由代理服务器根据真实的服务器信息,获取数据
4、真实的服务器接收请求之后,将数据返回给代理服务器
5、代理服务器接收到服务器数据之后,将数据回传给用户,本次代理结束
2.2 正向代理
2.2.1 正向代理说明
正向代理,意思是一个位于客户端和原始服务器(origin server)之间的服务器,为了从原始服务器取得内容,客户端向代理发送一个请求并指定目标(原始服务器),然后代理向原始服务器转交请求并将获得的内容返回给客户端。客户端才能使用正向代理。
特点:
1、代理服务器位于用户与真实服务器之间的
2、客户非常清楚自己访问的服务到底是谁?
3、服务器不清楚访问自己的服务器到底是谁,以为只是代理服务器访问
4、正向代理称之为客户端代理,保护了客户的信息
2.3 Nginx
2.3.1 Nginx服务器介绍
Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。
其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力在同类型的网页服务器中表现较好,中国大陆使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝 等。
特点:
1、占用内存少,不超过2M
2、并发能力强 5万/秒 tomcat150-220个/秒
3、开发语言 C语言
2.3.2 nginx下载
2.3.3 nginx安装
启动: 首先右键以管理员身份运行,之后程序闪退表示服务器启动正常
2.3.4 检查Nginx服务启动项
nginx启动时,会启动2个进程项,其中一个
1、主进程 主要为用户提供反向代理服务 占用内存大的
2、守护进程 防止主进程意外关闭 占用内存小的
2.3.5 启动正常测试
2.4 NGINX入门案例说明
2.4.1 配置文件说明
http{
#必须在http协议之内进行配置
server{
listen 80;
server_name "监听时域名地址";
location /{
root "反向代理的是一个目录";
}
}
server{}
}
2.5 NGINX实现图片回显
2.5.1 编辑Nginx.conf文件
图片url地址:
#配置图片代理服务器http://image.it.com:80
server{
listen 80;
server_name "image.it.com";
location / {
root E:/neweclipse/javafour/images;
}
}
2.5.2 nginx命令
命令:
1、启动命令 start nginx
2、重启命令 nginx -s reload
3、停止命令 nginx -s stop
2.5.3 编辑hosts文件
介绍:HOSTS文件是操作系统为了方便开发,在本地形成的一个域名与IP的映射的文件,但是该文件支队本机有效
位置:C:\Windows\System32\drivers\etc\hosts
文件内容:
#IP 域名 映射关系
127.0.0.1 image.jt.com
127.0.0.1 manage.jt.com
127.0.0.1 www.jt.com
127.0.0.1 sso.jt.com
127.0.0.1 localhost
2.5.4 关于nginx回显图片报错问题说明
2.6 实现域名的代理
2.6.1 业务需求
需求:需要通过http://manage.jt.com域名访问l...:8080的服务器
操作:
1、修改hosts文件
2、修改nginx的配置文件
2.6.2 修改nginx.conf配置文件
3、nginx高级用法
3.1 nginx负载均衡机制
说明为了提升后台服务器的处理能力,可以增加服务器,实现负载均衡的策略
3.2 动态获取服务器端口号
请求路径:http://manage.jt.com/getPort...
package com.jt.controller;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class PortController {
@Value("${server.port}")
private String port;
/**
* 获取端口号信息
*/
@RequestMapping("/getPort")
public String getPort(){
return "当前访问的服务器的端口号为:"+port;
}
}
3.3 项目打包
3.3.1 利用maven方式打包
3.3.2 利用压缩工具打包
将xxx.war改为xxx.zip之后利用压缩工具修改配置文件,之后再次改为xxx.war即可
3.3.3 项目发布
命令:java -jar 8081.war 会占用一个终端窗口,在运行时,终端不能关闭的
3.3.4 释放资源的组合键
ctrl + c
3.4 nginx负载均衡测试
3.4.1 轮训策略
说明: 按照nginx.conf中配置文件的顺序依次访问
#配置商品后台服务器
server{
listen 80;
server_name manage.jt.com;
location / {
#代理真实服务器地址
#proxy_pass http://localhost:8091;
#映射到集群
proxy_pass http://jtWindows;
}
}
#配置tomcat服务器集群 1.默认 轮询策略
upstream jtWindows {
server 127.0.0.1:8081;
server 127.0.0.1:8082;
server 127.0.0.1:8083;
}
3.4.2 权重策略
说明:由于公司的物理服务器可能性有高有低,为了让高新能的服务器处理更多的数据
#配置tomcat服务器集群 1.默认 轮询策略 2.权重策略
upstream jtWindows {
server 127.0.0.1:8081 weight=6;
server 127.0.0.2:8082 weight=3;
server 127.0.0.3:8083 weight=1;
}
3.4.3 IPHASH策略
说明:如果需要将服务器与IP地址进行绑定时,使用该策略
#配置tomcat服务器集群 1.默认 轮询策略 2.权重策略 3.ip_hash策略
upstream jtWindows {
ip_hash;
server 127.0.0.1:8081 weight=6;
server 127.0.0.2:8082 weight=3;
server 127.0.0.3:8083 weight=1;
}
原理: