Skip to content

ER-JIA-SHUN/Nginx-Load-balacing-ASCII-real-time

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 
 
 
 
 

Repository files navigation

Nginx Load balacing ASCII real-time

Concept Development

  • 每次看駭客電影中,將自己轉換成為由 0 和 1 組成的圖像。感覺這玩意好酷哦!所以我們想嘗試看看:相片的圖像轉換,以及 Real-time 的畫面轉換

  • 所以我們想弄一個 real-time 將攝影機畫面轉換成為 Ascii Art 的樣子,把該服務架設在 Nginx Web Server 上再由 Nginx 去做 Load balancing 服務資源

  • DEMO 環節 影片連結點我

Implementation Resources

  • JavaScript
  • HTML
  • Nginx

Existing Library/Software

Installation

  • 虛擬機要額外安裝一個 Extension Pack 來開啓攝像頭

  • 去打勾啓動攝像頭

  • 先更新一下軟件

      sudo apt update
      sudo apt upgrade
    
  • 下載 Nginx

      sudo apt-get install nginx
    
  • 下載 p5.js 檔案 點擊這裡

Implementation Process

  • 首先在你喜歡的位置開一個資料夾存放網頁資料

    1. cd /var/www
    2. mkdir lsa
    3. sudo vim ascii_1.html
    
  • 在 ascii_1.html 裡面貼入以下的 HTML 程式碼,其中 h1 的內容為:This Is Server 1. 來代表第一個 Web Server

    <!DOCTYPE html>
    <html lang="en">
      <head>
        <link rel="stylesheet" type="text/css"     href="style.css">
        <script     src="p5.js"></script>
        <meta charset="utf-8" />
        <h1>This Is Server 1.</h1>
      </head>
      <body>
        
        <main>
        </main>
        <script>
          //const density = '           .:░▒▓█'
          //const density = '█▓▒░:.         '
          //const density = '            .:-    i|=+%O#@'
          //const density = '@#O%+=|i-:.                '
          const density = '                                                       _.,-=+:;cba!?0123456789$W#@Ñ'
          //const density = 'Ñ@#W$9876543210?!abc;:+=-,._                                                       '
          //const density = ' .,:irs?@9B&#'
        let video;
        let asciiDiv;
        
    // 開啟一個攝影機、並看到預覽
    function setup() {
      noCanvas();
      video = createCapture(VIDEO);
      video.size(275,110);
      asciiDiv = createDiv();      
    }
    
    
    function draw() {
      video.loadPixels();
      // 要印出的結果
      let asciiImage = '';
      for (let j = 0; j < video.height;j++) {
        for (let i = 0;i < video.width; i++) {
          // pixelIndex = (r,g,b,alpha) alpha:處理透明度(此處不考慮)
          const pixelIndex = (i + j * video.width)     * 4;
          // 抓取單一像素的 RGB 數值,rgb 數字越大越亮。 (0,0,0)->黑;(255,255,255)->白
          const r = video.pixels[pixelIndex + 0];
          const g = video.pixels[pixelIndex + 1];
          const b = video.pixels[pixelIndex + 2];
          // 為了知道該給這格pixel什麼樣的 ascii 符號 (有怎樣的亮度),固取平均值
          const avg = (r + g + b) / 3;
          const len = density.length;
          // 將該 pixel 的亮度,由 0~255,投到 0 ~ density.length中,來找出該用哪一個 ascii 符號來代表這格pixel
          const charIndex = floor(map(avg,0,255,len,0));
          
          
          // 確保空格能夠正確的被印出來
          const c = density.charAt(charIndex);
          if (c == " ") asciiImage += "&nbsp;";
          else asciiImage += c;
        }
        asciiImage  += '<br/>';
      }
      // 刷新含有儲存 ascii art 的 div
      asciiDiv.html(asciiImage);
    }
        </script>
      </body>
    </html>
    
  • 複製多一個 HTML 給第二個 web server 用。 (再到 ascii_2.html 把裡面的 h1 改成 This Is Web Server 2. ,用以做出區分)

    4. sudo cp ascii_1.html ascii_2.html
    5. sudo vim ascii_2.html
    6. sudo vim style.css
    
    • 貼入以下 CSS 的程式碼
    html, body {
      margin: 0;
      padding: 0;
      background-color: #FFF;
      /* color:#FFF; */
      font-family: 'Courier';
      font-size: 6pt;
      line-height: 4pt;
      color: blue;
    }
    
    canvas {
      display: block;
    }
    
  • 切到 Downloads 資料夾,把 Downloads 中的 p5.js 搬到 /var/www/lsa

    7. cd /Downloads
    8. sudo mv p5.js /var/www/lsa
    
  • 去 Nginx 架設一個 Load Balancer 和兩個 Web Servers

    9. cd /etc/nginx/sites-available
    10. sudo vim loadbalancer.conf
    
    • 貼入下程式碼 (loadbalancer.conf)
    upstream lsa{
        random;
        server localhost:8081;
        server localhost:8082;
    }
    server{
        listen 8080;
        listen [::]:8080;
        
        location / {
            proxy_pass http://lsa;
        }
    }
    
    11. sudo vim lsa_1.conf
    
    • 貼入下程式碼 (lsa_1.conf)
    server{
        listen 8081;
        listen [::]:8081;
        
        root /var/www/lsa;
        index ascii_1.html
        
        location / {
            try_files $uri $uri/ =404;
        }
    }
    
    12. sudo vim lsa_2.conf
    
    • 貼入下程式碼 (lsa_2.conf)
    server{
        listen 8082;
        listen [::]:8082;
        
        root /var/www/lsa;
        index ascii_2.html
        
        location / {
            try_files $uri $uri/ =404;
        }
    }
    
  • 把 loadbalancer.conf 和兩個 Web Server.conf Softlink 到 /etc/nginx/sities-enabled

    13. sudo ln -s /etc/nginx/sites-available/loadbalancer.conf /etc/nginx/sites-enabled
    14. sudo ln -s /etc/nginx/sites-available/lsa_1.conf /etc/nginx/sites-enabled
    15. sudo ln -s /etc/nginx/sites-available/lsa_2.conf /etc/nginx/sites-enabled
    16. sudo service nginx restart
    
  • 開啓網頁輸入 127.0.0.1:8080 (loadBalancer) 點擊 Allow

  • Ta Da~ 大功告成~

Usage

  • 主要還是用於興趣開發的範疇,沒有什麽特別的商業價值
  • 可用於影片中做一個濾鏡特效

碰到的問題

  • 因爲 p5.js 的套件它只能在 localhost 底下使用 getUserMedia, 到了其他的私人 ip 下它無法使用 Web Browser 當中自動或手動開起攝影機的權限。
    • 問題: "getUserMedia is not implemented in this browser"
    • 嘗試寫了一個 navigator.mediaDevices.getUserMedia 的 Web APIs 也沒被辦法啟用

Job Assignment

  • Nginx Web Server & Load Balancer:余嘉舜
  • 動態的攝影機畫面轉 Ascii art:蔡清寶
  • github 編寫 5/5 平分

感謝名單

  • 資管三 沈佳龍 同學

References

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published