view slide/slide.html @ 33:c9142e57399f default tip

uodate maintex
author e155702
date Thu, 21 Feb 2019 09:46:47 +0900
parents e2ec8297e712
children
line wrap: on
line source

<!DOCTYPE html>
<html>
<head>
   <meta http-equiv="content-type" content="text/html;charset=utf-8">
   <title>画面配信システム TreeVNC の拡張</title>

<meta name="generator" content="Slide Show (S9) v2.5.0 on Ruby 2.6.1 (2019-01-30) [x86_64-darwin17]">
<meta name="author"    content="Yukiya OSHIRO" >

<!-- style sheet links -->
<link rel="stylesheet" href="s6/themes/projection.css"   media="screen,projection">
<link rel="stylesheet" href="s6/themes/screen.css"       media="screen">
<link rel="stylesheet" href="s6/themes/print.css"        media="print">
<link rel="stylesheet" href="s6/themes/blank.css"        media="screen,projection">

<!-- JS -->
<script src="s6/js/jquery-1.11.3.min.js"></script>
<script src="s6/js/jquery.slideshow.js"></script>
<script src="s6/js/jquery.slideshow.counter.js"></script>
<script src="s6/js/jquery.slideshow.controls.js"></script>
<script src="s6/js/jquery.slideshow.footer.js"></script>
<script src="s6/js/jquery.slideshow.autoplay.js"></script>

<!-- prettify -->
<link rel="stylesheet" href="scripts/prettify.css">
<script src="scripts/prettify.js"></script>

<script>
  $(document).ready( function() {
    Slideshow.init();

    $('code').each(function(_, el) {
      if (!el.classList.contains('noprettyprint')) {
        el.classList.add('prettyprint');
      }
    });
    prettyPrint();
  } );

  
</script>

<!-- Better Browser Banner for Microsoft Internet Explorer (IE) -->
<!--[if IE]>
<script src="s6/js/jquery.microsoft.js"></script>
<![endif]-->



</head>
<body>

<div class="layout">
  <div id="header"></div>
  <div id="footer">
    <div align="right">
      <img src="s6/images/logo.svg" width="200px">
    </div>
  </div>
</div>

<div class="presentation">

  <div class='slide cover'>
    <table width="90%" height="90%" border="0" align="center">
      <tr>
        <td>
          <div align="center">
            <h1><font color="#808db5">画面配信システム TreeVNC の拡張</font></h1>
          </div>
        </td>
      </tr>
      <tr>
        <td>
          <div align="left">
            Yukiya OSHIRO
            並列信頼研
            <hr style="color:#ffcc00;background-color:#ffcc00;text-align:left;border:none;width:100%;height:0.2em;">
          </div>
        </td>
      </tr>
    </table>
  </div>

<div class='slide '>
<!-- === begin markdown block ===

      generated by markdown/1.2.0 on Ruby 2.6.1 (2019-01-30) [x86_64-darwin17]
                on 2019-02-20 15:30:01 +0900 with Markdown engine kramdown (2.0.0)
                  using options {}
  -->
<!-- <\!-- slideshow の command -\-> -->
<!-- slide.htmlでは通常キーでのコマンドが存在している -->

<!-- p,a,s : スライドを自動送り(1,2...) -->
<!--  : スライドを逆方向に自動送り(...,2,1) -->
<!-- n : Page数を on/off -->
<!-- f : 右下ロゴの on/off -->
<!-- t : slide.html.pdf に変更 -->
<!-- c : 右下スライド移動用UIの on/off -->
<!-- d : ロゴ部分の選択…? -->
<!-- [URL](http://~~~) -->
<!-- [FILE](file:///Users/ryokka/~~~) -->
<!-- slideshow build スライド.md -t s6cr -->

<h2 id="section">画面配信システムの活用</h2>
<ul>
  <li>講義や発表の場では、プロジェクタが使用されることが多い。その場合、アクシデント発生の恐れがある</li>
  <li>画面配信システム TreeVNC は、自身の PC 画面を他者の PC に表示するソフトウェアである</li>
  <li>TreeVNC を使用することで、参加者は手元の PC を使用しながら講義を受ける事が可能になる。切り替えの際も、ボタン一つで共有する画面の切替を可能としている</li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="treevnc-">TreeVNC の問題点</h2>
<ul>
  <li>クライアントが接続している状態で、サーバー側が接続を切るとクライアント側が正しく切断されない</li>
  <li>サーバーに接続した際に、画面の操作を許可するかどうか確認するポップアップが Root 側にも表示されてしまう</li>
  <li>画面配信は送信するデータ量が多いため、TreeVNC では無線接続の場合、画面配信の遅延が大きくなってしまう</li>
  <li>現在の TreeVNC のデータ転送方法だと、無線接続で送信するには大きすぎる</li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="section-1">今回の発表</h2>
<ul>
  <li><del>クライアントが接続している状態で、サーバー側が接続を切るとクライアント側が正しく切断されない</del></li>
  <li><del>サーバーに接続した際に、画面の操作を許可するかどうか確認するポップアップが Root 側にも表示されてしまう</del></li>
  <li>画面配信は送信するデータ量が多いため、TreeVNC では無線接続の場合、画面配信の遅延が大きくなってしまう</li>
  <li>現在の TreeVNC のデータ転送方法だと、無線接続で送信するには大きすぎる</li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="section-2">目次</h2>
<ul>
  <li><strong>TreeVNC の概要</strong>
    <ul>
      <li><strong>基本概念</strong></li>
      <li><strong>構造</strong></li>
    </ul>
  </li>
  <li>研究内容
    <ul>
      <li>TreeVNC の改良</li>
      <li>送信データの Blocking</li>
    </ul>
  </li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="treevnc">TreeVNC</h2>
<ul>
  <li>TreeVNC は本研究室で開発している画面配信システム</li>
  <li>VNC (リモートデスクトップソフトウェア) を利用している</li>
  <li>配信側の負荷を分散し、大人数での画面配信が可能</li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="vnc">VNC</h2>
<ul>
  <li>VNC (Virtual Network Computing) は、RFB プロトコルを用いて PC の遠隔操作を行うことを目的としたリモートデスクトップソフトウェア</li>
  <li>サーバー側とクライアント側に分かれており、起動したサーバーにクライアントが接続することで遠隔操作を可能にしている</li>
  <li>全ての Node が一台のサーバーに接続するため負担が大きい</li>
</ul>

<center><img src="./fig/vnc-crop.svg" alt="message" width="400" height="300" /></center>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="rfb-">RFB プロトコル</h2>
<ul>
  <li>RFB (Remote Frame Buffer) プロトコルは、自身の画面をネットワークを通じて送信し他者の画面に表示するプロトコル</li>
  <li>ユーザがいる (画面を表示される) 側と FrameBuffer への更新が行われる (自身の画面を送信する) 側に分かれ、それぞれを RFB クライアント、RFB サーバと呼ぶ</li>
  <li>FrameBuffer は、メモリ上に置かれた画像データのこと</li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="treevnc--1">TreeVNC の構造</h2>
<ul>
  <li>TreeVNC は接続してきたクライアントを Node とし、バイナリツリー状に管理する。</li>
  <li>ルートのノードを Root Node と呼び、その下に新たな Node を接続していく</li>
  <li>Root Node が参照している VNCServer から FrameBufferUpdate を取得し、各 Node に送信する</li>
  <li>バイナリツリー状に接続することで、画像データのコピーを各 Node に負担させることができる</li>
</ul>

<center><img src="./fig/treevnc-crop.svg" alt="message" width="400" height="300" /></center>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="section-3">共有画面切り替え</h2>
<ul>
  <li>従来の VNC では、配信者が切り替わるたびに再起動、再接続を行う必要があった</li>
  <li>TreeVNC では、画面上にある ShareScreen ボタンを押すことで配信者の切り替えが実行できる</li>
  <li>ShareScreen 実行後、Root Node に対し SERVER CHANGE REQUEST というメッセージが送信される。</li>
  <li>メッセージを受け取った Root Node は配信を希望している Node の VNC サーバーと通信を行い、切り替え作業に入る。</li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="section-4">目次</h2>
<ul>
  <li>TreeVNC の概要
    <ul>
      <li>基本概念</li>
      <li>構造</li>
    </ul>
  </li>
  <li><strong>研究内容</strong>
    <ul>
      <li><strong>TreeVNC の改良</strong></li>
      <li><strong>送信データの Blocking</strong></li>
    </ul>
  </li>
</ul>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="multicast">Multicast</h2>
<ul>
  <li>ツリーに無線接続の Node を加えてしまうと配信の遅延に繋がる</li>
  <li>Multicast の実装を提案</li>
  <li>Multicast ならば、Server からの送信は一度で済むため、ツリー構造の形成が必要ない</li>
  <li>従って新しい Node が 無線接続であっても、有線接続のツリーの配信には影響が出ない</li>
</ul>

<center><img src="./fig/interface-crop.svg" alt="message" width="400" height="350" /></center>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="blocking">Blocking</h2>
<ul>
  <li>無線接続の場合、一度に送信できるデータ量が 64kbyte しかないため、それに合わせてデータを分割する必要がある</li>
  <li>大きなデータを小さい単位に分割する
    <ul>
      <li>更新が行われた部分を1行ずつ圧縮していく</li>
      <li>書き込みのために用意した関数に入る限界値まで圧縮を行ない、関数に書き込む</li>
    </ul>
  </li>
</ul>

<center><img src="./fig/tiling-crop.svg" alt="message" width="400" height="250" /></center>

</div>
<div class='slide '>
<!-- _S9SLIDE_  -->

<h2 id="section-5">まとめ</h2>
<ul>
  <li>TreeVNC の改良と Multicast 対応のためのデータの Blocking を実装した。
    <ul>
      <li>VNCServer 側が接続を切断した場合でもクライアントが正しく終了する様にした。</li>
      <li>画面操作の許可を確認する authentication のポップアップが Root 側に表示されない様にした。</li>
      <li>データの Blocking を行うことにより、無線接続での Multicast 対応を行えるようにした。</li>
    </ul>
  </li>
  <li>今後の課題
    <ul>
      <li>Multicast の実装</li>
      <li>Multicast 実行時の遅延の評価</li>
      <li>Packetloss 時の対処</li>
    </ul>
  </li>
</ul>
<!-- === end markdown block === -->
</div>


</div><!-- presentation -->
</body>
</html>