view Todo.txt @ 204:d9d234715853

TreeManager for each interface
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Fri, 27 Jun 2014 21:37:20 +0900
parents f5abf6ba9957
children 614db20d8fab
line wrap: on
line source

Fri Jun 27 15:19:39 JST 2014
    
    拡大縮小ボタンのバグを取る。

    Multi-Network-Treeの作成
    socketからNetMaskを検出
    NetworkごとにTreeManagerを作成
    複数のNetworkをもつNodeでは新しいNewtworkにTreeManagerを作成
    FindRootにはTreeMangerが応答する
    下位のNodeのChangeVnCServerはそのTreeManagerが処理する
    上位にHostameがからのChangerVnCserverを投げる
    UpdateRectanleを上位のNetwoekに投げる
    RootではUpdateRectangleを送り返す

    myRfbProtoのwaitForReady()で新しいnetworkinterfaceを検出する
    treeManagerをnetworkのhashmapで持つ。
    setTreeManagerにnetworkの引数を追加する

    findRootで重複したrootを見つけたときに、
    一番小さいアドレスだけをrootにする。
    それ以外には、duplicated rootを送る。
    この際、duplicated rootを送られたrootは生かしておくが、
    find rootへの応答はやめる。
    lostParentがきたら、find rootへの応答を再開する。
    この際、生かしておくduplicated rootは二つに限る。
    
    findRootReplyにはVNCServerのhostとportを含める。
    両方共nullだった場合は両方別のものとして表示する。
    異なるVNCServerはduplicate扱いしない。

    duplicate root を受け取ったrootは、
    rootであることをやめて、自分の子供にrequestWhereToConnectを送信する。

    requestWhereToConnectを受け取ったnodeは
    whererToConnectを再度送信する。

    中間rootが死んだときには
    下位のnodeはduplicated rootにつなげ直す。
    もしduplicatedListになかったら、あきらめる。


Thu Jun 25 20:55:00 JST 2014
    
    share screenした際に、rootのviewerが消えない。
    殺しきれていないThreadがある。


Thu Jun 19 08:12:02 JST 2014

    Share Button を押した際に、JFrameのTitleを更新する。 Done
    SwingViewerWindow.javaのsetRemoteDesktopName メソッドを呼べば解決するはず。
    
    サーバが切り替わった際、画面のサイズ等の情報を送信する。(INIT_DATA) Done

    -dオプションでviewerを別にあげるのをやめる。
    2つめのviewerの表示が滞るのをデバッグする
    shareボタンを禁止するrootのオプションを、パネルから設定出来るように。
    shareしたTreeVNCのパネルをinvisibleにする。
    shareする画面の大きさをHDサイズに限定するのをdefaultにする。
    fullサイズを転送するオプションに。
    checkdelayの機能を。


Fri Jun 13 17:29:02 JST 2014
    
    AcceptThreadをMultiThread化する。(deadlockを防ぐため)
    TreeNodeが死んだときに、最後のNodeをそこに置き換える。
    clientをつなげたときにscreen sharingするバグを直す。
    無線LAN等の複数のネットワークを使えるようにする。
    無線LAN同士でtreeを構成しないようにパターンマッチをする。

Sat Jun  7 11:47:56 JST 2014

    Multicast で root を探す  (FIND_ROOT)
    その時に、自分の proxy port/host を付けておく
    root は、それを client address/port として覚えておく (clients)
    root は、そこに接続に来て、「自分のproxy  port」を返す。(FIND_ROOT_REPLY)
        これを check box に登録する
    client は、それを選択して、root の proxy port に接続に行く (WHERE_TO_CONNECT)
    そこから、root は、どこに接続に行くかを教えてくれる (CONNECT_TO)
    今度は、そこにclientとして接続する   (VERSION_MESSAGE )

        FIND_ROOT         (client multicast )           :    int port; String hostname  (client's address)

    proxy port への接続では、client は自分から書かずに server からの version message を待つ
    普通のVNCは cliet からは VERSION_MESSAGE が行くが、Tree VNC では、

        FIND_ROOT_REPLY   (root to client proxy port)   :    int port; String hostname  (root's address)
        WHERE_TO_CONNECT  (clinet to root proxy port)   :    int port; String hostname  (client's address)
        CONNECT_TO        (root to client )             :    int port; String parentAddress (parent's address)
        CONNECT_TO_AS_LEADER  (root to client )         :    int port; String parentAddress (parent's address)

    が来ることになる。

    切断時は、子供のleaderが root のproxy port に聞きに行く

        LOST_PARENT            (client to root)         :    int port; String hostname

    root は、接続変更が必要な node の proxy に CONNECT_TO を送る (木経由では送れない。切断されているので)

    最終的な切断時では、 LOST_PARENT が大量に出てしまうはず。なので、CONNECT_TO は連続しては送らない。

    reportLastNode は CONNECT_TO で良い。(10001 port)
    lostNodeConnection でも CONNECT_TO を使う

    LOST_PARENT と PARENT_NOT_FOUND の違いはなんだ? LOST_PARENT は leader が出すようだけど。

    CONNECT_TO で parentNum とか treeNum を送る必要はない。root 内部で接続アドレスから判断する。
    なので、LOST_PARENT  は hostname と port だけでよい。

Fri May 23 19:32:24 JST 2014

    checkdelay を再実装する

    reconnect message が port 10001 を使っているが、これでは複数clientをホストで動かした時に動かない。
    どのportを使うかをrootに教える必要がある。

    9999も使われているようだ。

    普通にclientに接続に行けば、version handshake からスタートするはず。そこに、reconnection プロトコルを
    挟める。MyRfbProto.readVersionMsg()。

    Recconection は 
        root は    AcceptClient
        client は  EchoClient
    で行われている(らしい)。まず、この名前をまともなものにする。

    reconnection は木の最後のノードを穴の空いたところに接続することで行われる。これは、逐次で行う必要がある。
    最後には、ほとんどは一斉に切断されるので、そこで破綻しないように注意する。

    root が client のノードとportを持っているかどうかが重要だが。


Thu May 22 21:20:39 JST 2014

    1) zlibの同期が外れてる。
        VncProxyService.javaのinhelitClients の中で
        resetDecoderを呼び出せばいいが.... 
    2) DesktopSize ではなく、同じプロトコルで initData を送る方が良い。
    2) initData の中の名前を見て、自分だったら、shareしたclientのscreenをhideする。
   

Wed May 22 16:14:25 JST 2014

    1) 10001, 10002 における固定Portをなくす
    2) 木を上に登る通信
    3) ClientをCloseしないでresizeする
    
    Update rectangle で desktop size を変更可能
    このままで、pixel formatが変更されない
    なのでserverInit をもう一度送るのがよいのではないか

    4) display modeでClient view(proxy + view)をあげる

Wed Aug 29 23:32:36 JST 2012

  ReceiverTask の framebufferUpdateMessage を、TreeTask に再現しないとだめ。

Wed Aug 29 22:27:25 JST 2012

  MyRfbProxy の os が初期化されていない (削除する方が良い)

  initData が null ( 設定された時に、設定するべき)