Skip to content

一個可以將儲存在任一地方的圖片進行縮放和套用濾鏡,而不用額外儲存圖片的簡易 proxy server

License

Notifications You must be signed in to change notification settings

shlason/imgproxy

Repository files navigation

imgproxy

一個可以將儲存在任一地方的圖片進行縮放和套用濾鏡,而不用額外儲存圖片的簡易 proxy server。

API 文件:點我

在左下方 Original image 輸入欲縮放的 image URL,線上 Demo: 點我

imgproxy demo image

動機

例如有個網站是專門搜集攝影作品,但攝影作品的圖片檔案普遍都非常大,若每次在前端顯示作品縮圖之類,不需要原圖畫質的情境時,會耗費很多不必要的網路流量且載入慢導致使用體驗相對不佳,這個問題可以在上傳作品時就分成很多不同 size 的圖片來儲存,在不同情境就使用相對應 size,但這樣就會多耗費空間來為每個作品做不同 size 的圖片儲存。

解法

imgproxy 可以藉由 QS 來指定特定圖片要取得什麼樣的 size,以及縮放的規則,而不用特別把圖片分為不同 size 一一儲存,不僅不用額外耗費儲存空間也增加了彈性,日後不管要什麼 size 的圖片都可以支援。

因為影像處理的部分,相對都比較耗費機器的效能,所以使用 Cloudflare CDN 來做快取,變成只有在全新的請求時才需處理,用以減緩機器的負擔。

API 使用上,例如我有一個攝影作品 A,在顯示作品 A 的縮圖時可以這樣做:

https://imgproxy.sidesideeffect.io/api/image?url={IMAGE_A_URL}&width={W}&height={H}&resize=fit&blur=0

IMAGE_A_URL: 作品 A 原圖的 URL
W:           欲縮放的寬度
H:           欲縮放的高度
並且使用 fit 的方式來 resize 不導致變形及不套用模糊濾鏡

潛在問題

若同時有多個全新的請求,並且圖片又非常大的情況下,可能機器負擔會非常大,這時候可能可以考慮把這個服務架在 AWS Lambda 上面,並一樣處理 CDN,目前該服務是建在 AWS EC2 上面。

技術棧

  • Go
  • Gin (管理路由和 middleware)
  • h2non/bimg (影像處理)
  • gopkg.in/ini.v1 (用來讀取設定檔 configs.ini)
  • swaggo/swag (產 API 文件)
  • autocert (產 SSL 憑證)
  • github Actions (用以 build 專案和部署到 EC2 上)
  • Cloudflare DNS
  • Cloudflare CDN
  • AWS EC2

參考

以前做專案時曾遇過類似問題,當初看到 imgproxy github 並在當時使用類似的方式解決了,因此想要自己試著做一個簡易的版本看看。

About

一個可以將儲存在任一地方的圖片進行縮放和套用濾鏡,而不用額外儲存圖片的簡易 proxy server

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published