1. 檔案上傳優化
1.1 url優化
說明: 如果需要通過網路虛擬路徑訪問服務器.則應該按照如下的配置實作.
- 本地磁盤路徑: D:\JT-SOFT\images\2020\09\30\a.jpg
- 網路虛擬路徑: http://image.jt.com\2020\09\30\a.jpg
1.2 編輯pro組態檔

1.3 完成屬性的動態賦值
package com.jt.service;
import com.jt.vo.ImageVO;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.PropertySource;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;
import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashSet;
import java.util.Set;
import java.util.UUID;
@Service
@PropertySource("classpath:/properties/images.properties") //容器動態加載指定的組態檔
public class FileServiceImpl implements FileService{
//由于屬性的值后期可能會發生變化,所以應該動態的獲取屬性資料. 利用pro組態檔
@Value("${image.rootDirPath}")
private String rootDirPath; // = "D:/JT-SOFT/images";
@Value("${image.urlPath}")
private String urlPath; // = "http://image.jt.com";
//1.2 準備圖片的集合 包含了所有的圖片型別.
private static Set<String> imageTypeSet;
static {
imageTypeSet = new HashSet<>();
imageTypeSet.add(".jpg");
imageTypeSet.add(".png");
imageTypeSet.add(".gif");
}
/**
* 完善的校驗的程序
* 1. 校驗是否為圖片
* 2. 校驗是否為惡意程式
* 3. 防止檔案數量太多,分目錄存盤.
* 4. 防止檔案重名
* 5. 實作檔案上傳.
* @param uploadFile
* @return
*/
@Override
public ImageVO upload(MultipartFile uploadFile) {
//0.防止有多余的空格 所以先做去空格的處理
rootDirPath.trim();
urlPath.trim();
//1.校驗圖片型別 jpg|png|gif..JPG|PNG....
//1.1 獲取當前圖片的名稱 之后截取其中的型別. abc.jpg
String fileName = uploadFile.getOriginalFilename();
int index = fileName.lastIndexOf(".");
String fileType = fileName.substring(index);
//將資料轉化為小寫
fileType = fileType.toLowerCase();
//1.3 判斷圖片型別是否正確.
if(!imageTypeSet.contains(fileType)){
//圖片型別不匹配
return ImageVO.fail();
}
//2.校驗是否為惡意程式 根據寬度/高度進行判斷
try {
//2.1 利用工具API物件 讀取位元組資訊.獲取圖片物件型別
BufferedImage bufferedImage = ImageIO.read(uploadFile.getInputStream());
//2.2 校驗是否有寬度和高度
int width = bufferedImage.getWidth();
int height = bufferedImage.getHeight();
if(width==0 || height==0){
return ImageVO.fail();
}
//3.分目錄存盤 yyyy/MM/dd 分隔
//3.1 將時間按照指定的格式要求 轉化為字串.
String dateDir = new SimpleDateFormat("/yyyy/MM/dd/")
.format(new Date());
//3.2 拼接檔案存盤的目錄物件
String fileDirPath = rootDirPath + dateDir;
File dirFile = new File(fileDirPath);
//3.3 動態創建目錄
if(!dirFile.exists()){
dirFile.mkdirs();
}
//4.防止檔案重名 uuid.jpg 動態拼接
//4.1 動態生成uuid 實作檔案名稱拼接 名.后綴
String uuid =
UUID.randomUUID().toString().replace("-", "");
String realFileName = uuid + fileType;
//5 實作檔案上傳
//5.1 拼接檔案真實路徑 dir/檔案名稱.
String realFilePath = fileDirPath + realFileName;
//5.2 封裝物件 實作上傳
File realFile = new File(realFilePath);
uploadFile.transferTo(realFile);
//實作檔案上傳成功!!! http://image.jt.com\2020\09\30\a.jpg
String url = urlPath + dateDir + realFileName;
return ImageVO.success(url,width,height);
} catch (IOException e) {
e.printStackTrace();
return ImageVO.fail();
}
}
}
2 反向代理機制說明
2.1 為什么需要反向代理
需求:當完成檔案上傳時,業務回傳頁面的是虛擬地址路徑
url地址: http://image.jt.com/2020/09/30/a.jpg
真實圖片地址: file:///D:/JT-SOFT/image/2020/09/30/d534bed912c748b0ac979ee40222490a.jpg
問題: 如何讓用戶通過url訪問 找到真實的磁盤地址的圖片.
2.2 反向代理機制
2.2.1 反向代理介紹
反向代理服務器位于用戶與目標服務器之間,但是對于用戶而言,反向代理服務器就相當于目標服務器,即用戶直接訪問反向代理服務器就可以獲得目標服務器的資源,同時,用戶不需要知道目標服務器的地址,也無須在用戶端作任何設定,反向代理服務器通常可用來作為Web加速,即使用反向代理作為Web服務器的前置機來降低網路和服務器的負載,提高訪問效率,
概括:
1.位于用戶(客戶端)-服務器之間.
2.用戶訪問反向代理服務器,以為是真實的服務器資訊.
3.用戶根本不清楚真實的服務器資訊到底是誰.
4.一般反向代理機制保護了真實的服務器資訊,所以也稱之為服務器端代理.

2.3 正向代理機制
2.3.1 需求引入
1.寬帶: 電信運營商 賬號/密碼 只能被一臺機器使用.
2.路由器: 在家庭的內部創建了局域網 使得局域網中的設備可以通過路由器的功能與外界通信.
2.3.2 正向代理介紹
正向代理,意思是一個位于客戶端和原始服務器(origin server)之間的服務器,為了從原始服務器取得內容,客戶端向代理發送一個請求并指定目標(原始服務器),然后代理向原始服務器轉交請求并將獲得的內容回傳給客戶端,客戶端才能使用正向代理,
總結:
1.正向代理位于客戶與服務器之間
2.客戶端在發起請求之前 確定了目標服務器的地址.
3.服務器不清楚到底是哪臺客戶端訪問的我,以為只是路由器訪問的.
4.正向代理保護了客戶的資訊,所以也稱之為 客戶端代理

2.4 Nginx
2.4.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 tomcat服務器大約占用600M
2.并發能力強 3-5萬次/秒 tomcat服務器大約 150-220之間
2.4.2 Nginx安裝使用

注意事項:
1. 不要將nginx放到C盤及系統目錄中 注意中文路徑和空格.
2. nginx服務器啟動的速度特別快, 視窗會閃退 只啟動一次即可
3. nginx啟動會占用80埠.
4. nginx命令的運行必須在nginx.exe所在的目錄中執行.
2.4.2 Nginx命令
1).啟動命令 start nginx
2).重啟命令 nginx -s reload
3).停止命令 nginx -s stop
2.4.3 Nginx服務器啟動項說明

2.4.4 關于nginx反向代理說明
http {
# 一個反向代理就是一個server
server {
#監聽 80埠
listen 80;
#監聽的域名 域名不能重復.
server_name localhost;
#執行的反向代理的動作 / 攔截所有的路徑
location / {
# root關鍵字 代理的是一個目錄
root html;
#默認跳轉頁面
index index.html index.htm;
}
}
}
2.5 Nginx實作圖片回顯
2.5.1 NGINX配置
# 圖片服務器代理 image.jt.com:80
server {
listen 80;
server_name image.jt.com;
location / {
# 轉向目錄
root D:/JT-SOFT/images;
}
}
2.5.2 修改hosts檔案
1.HOSTS檔案的說明:

2.HOSTS檔案的位置

3).以超級管理員身份運行


# 京淘配置
#左側寫IP地址 右側寫域名 中間使用空格分隔
127.0.0.1 image.jt.com
127.0.0.1 manage.jt.com
#實作 nginx的
#192.168.126.129 image.jt.com
#192.168.126.129 manage.jt.com
127.0.0.1 www.jt.com
#Bug 有時在使用該軟體時可能會出現丟失字母的現象.
127.0.0.1 sso.jt.com
3.nginx實作tomcat集群部署
3.1 專案部署

3.2 服務器反向代理
#配置京淘后臺管理服務器
# manage.jt.com localhost:8091服務器
server {
listen 80;
server_name manage.jt.com;
location / {
#映射服務器
proxy_pass http://localhost:8091;
}
}
修改nignx服務器之后,重啟nginx

3.3 動態獲取當前服務器埠號
@RestController
public class PortController {
//從spring服務器中動態的獲取埠號
@Value("${server.port}")
private Integer port;
@RequestMapping("/getPort")
public String getPort(){
return "當前服務器訪問的埠號:"+port;
}
}
3.4 專案打包


之后從專案的target目錄中動態獲取jar包檔案 準備集群部署.

3.4 專案發布命令
注意事項: 當前的命令執行 會占用dos命令視窗 列印控制臺資訊. 當dos命令視窗關閉 服務器停止.
退出dos命令視窗: ctrl + c
java: java -jar 8081.war

3.4 nginx負載均衡實作
3.4.1 輪詢機制
說明: 按照組態檔的順序 依次訪問服務器.
#配置京淘后臺管理服務器
# manage.jt.com localhost:8091服務器
server {
listen 80;
server_name manage.jt.com;
location / {
#映射服務器
#proxy_pass http://localhost:8091;
proxy_pass http://jtWindows;
}
}
# 配置tomcat服務器集群 1.輪詢策略
upstream jtWindows {
#server代表服務器地址
server 127.0.0.1:8081;
server 127.0.0.1:8082;
}
3.4.2 權重機制
說明: 按照權重的設定,讓性能更優的服務器多處理請求.
# 配置tomcat服務器集群 1.輪詢策略 2.權重策略
upstream jtWindows {
#server代表服務器地址
server 127.0.0.1:8081 weight=8;
server 127.0.0.1:8082 weight=2;
}
3.4.3 IPHASH策略(了解)
由于某些資料與服務器進行了系結,則后來必須要求用戶訪問指定的服務器時,使用IPHASH策略
# 配置tomcat服務器集群 1.輪詢策略 2.權重策略 3.iphash策略
upstream jtWindows {
#server代表服務器地址
ip_hash;
server 127.0.0.1:8081 weight=8;
server 127.0.0.1:8082 weight=2;
}
作業
1.安裝VMware虛擬機程式

2.檢查網卡設定
如果沒有網卡 則換一個vmwar版本安裝…

3. 啟動Linux系統



問題描述:
進入BIOS系統中 開啟虛擬化設定即可. 主板系統 開機 F1/F2…

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/147436.html
標籤:AI
上一篇:Php零基礎的話好學嗎
