「インストール - マウス・キーボード共有ソフトウェア」の版間の差分

提供:MochiuWiki : SUSE, EC, PCB
ナビゲーションに移動 検索に移動
 
(同じ利用者による、間の8版が非表示)
18行目: 18行目:
<br><br>
<br><br>


== Synergy ==
== Deskflow (旧 Synergy Core) ==
Synergyは有償ソフトウェアであるが、一部の機能 (通信の暗号化機能) を除いて、無償でも使用することができる。<br>
Deskflowは、Synergy3の無償の公式アップストリームプロジェクトある。<br>
Deskflowプロジェクトは、誰もが協力できるコミュニティ主導の開発を育成するために設立されている。<br>
<br>
<br>
==== パッケージ管理システムからインストール (非推奨) ====
Deskflowを使用することにより、Windows、MacOS、Linux上の複数のPC間で1つのマウスとキーボードを共有することが可能である。(映像出力なしのソフトウェアKVM)<br>
Synergyのバージョンが古い場合があるため、非推奨である。<br>
<br>
  sudo zypper install libdns_sd qsynergy synergy
==== パッケージ管理システムからインストール ====
# RHEL
-
# SUSE
-
# Raspberry Pi OS / Mobian
  -
<br>
<br>
==== ソースコードからインストール ====
==== ソースコードからインストール ====
まず、Synergyのビルドに必要な依存関係のライブラリをインストールする。<br>
まず、Deskflowのビルドに必要な依存関係のライブラリをインストールする。<br>
<br>
<u>※注意</u><br>
<u>Qt 6.5以降、CMake 3.24以降、OpenSSL 3.0以降が必要となることに注意する。</u><br>
<br>
  # RHEL
  # RHEL
  sudo dnf groupinstall "Development Tools"
  sudo dnf install epel-release
  sudo dnf install epel-release cmake3 boost-static libcurl-devel openssl-devel libXtst-devel \
sudo dnf config-manager --set-enabled crb
                    
  sudo dnf install cmake make ninja-build gcc-c++ gtk3-devel \
                  # Qt 5を使用する場合
                  glib2-devel gdk-pixbuf2-devel libcurl-devel libnotify-devel libei-devel   \
                  qt5-qtbase-devel qt5-qtdeclarative-devel
                   libportal-devel openssl-devel libXtst-devel libxkbfile-devel pugixml-devel \
                   qt6-qtbase-devel qt6-qttools-devel \
                  # Qt 6を使用する場合
                  gtest-devel gmock-devel           \
                   qt6-qtbase-devel qt6-core-devel qt6-widgets-devel qt6-network-devel qt6-dbus-devel qt6-qtdeclarative-devel
                  tomlplusplus-devel cli11-devel
   
   
  # SUSE
  # SUSE
  sudo zypper install glib2-devel gdk-pixbuf-devel avahi-compat-mDNSResponder-devel dbus-1-devel libcurl-devel libnotify-devel \
  sudo zypper install make cmake ninja gcc-c++ glib2-devel gtk3-devel                \
                    libopenssl-devel libopenssl-1_1-devel libavahi-devel fixesproto-devel libportal-devel pugixml-devel       \
                    gdk-pixbuf-devel avahi-compat-mDNSResponder-devel dbus-1-devel \
                     libXrandr-devel libXext-devel libXfixes-devel libXinerama-devel libXi-devel libXtst-devel xextproto-devel \
                    libcurl-devel libnotify-devel libopenssl-devel libavahi-devel fixesproto-devel libportal-devel pugixml-devel   \
                     libxkbcommon-devel libxkbfile-devel inputproto-devel recordproto-devel libSM-devel                       \
                     libXrandr-devel libXext-devel libXfixes-devel libXinerama-devel libXi-devel libXtst-devel xextproto-devel     \
                     libxkbcommon-devel libxkbfile-devel inputproto-devel recordproto-devel libSM-devel                             \
                     # Qt 5を使用する場合
                     libei-devel cli11-devel tomlplusplus-devel                                                                    \
                     libqt5-qtbase-common-devel libQt5Core-devel libQt5Gui-devel libQt5Widgets-devel libQt5Network-devel      \
                     qt6-base-devel qt6-core-devel qt6-widgets-devel qt6-network-devel qt6-dbus-devel qt6-linguist-devel qt6-tools-devel
                    libQt5DBus-devel libqt5-linguist-devel
   
   
                    # Qt 6を使用する場合
# Raspberry Pi OS / Mobian
                    qt6-base-devel qt6-core-devel qt6-widgets-devel qt6-network-devel qt6-dbus-devel qt6-linguist-devel
  apt install cmake build-essential ninja-build libglib2.0-dev libgtk-3-dev \
              libgdk-pixbuf-2.0-dev libnotify-dev libpugixml-dev libssl-dev \
              libei-dev libportal-dev libtomlplusplus-dev libcli11-dev      \
              xorg-dev libx11-dev libxtst-dev libxkbfile-dev                \
              qt6-base-dev qt6-tools-dev                                    \
              libgtest-dev libgmock-dev
<br>
<br>
* 各バージョンのソースコードからインストールする場合
* 各バージョンのソースコードからインストールする場合
*: [https://github.com/symless/synergy-core/releases SynergyのGithub]からソースコードをダウンロードする。
*: [https://github.com/deskflow/deskflow/releases DeskflowのGithub]からソースコードをダウンロードする。
*: ダウンロードしたファイルを解凍する。
*: ダウンロードしたファイルを解凍する。
*: <code>tar xf synergy-core-<バージョン>.tar.gz</code>
*: <code>tar xf deskflow-<バージョン>.tar.gz</code>
*: <code>cd synergy-core-<バージョン></code>
*: <code>cd deskflow-<バージョン></code>
*: <br>
*: Synergyのビルドに必要なサブモジュールをダウンロードする。
*: <code>git clone https://github.com/mohabouje/WinToast ext/WinToast</code>
*: <code>git clone https://github.com/google/googletest.git ext/googletest</code>
*: <code>git clone https://github.com/zeux/pugixml ext/pugixml</code>
*: <br>
*: <br>
*: Synergyをビルドおよびインストールする。
*: Deskflowをビルドおよびインストールする。
*: <code>mkdir build && cd build</code>
*: <code>mkdir build && cd build</code>
*: <code>cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=<Synergyのインストールディレクトリ> ..</code>
*: <code>cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=<Deskflowのインストールディレクトリ> ..</code>
*: <code>make -j $(nproc) または cmake --build . -j $(nproc)</code>
*: <code>make -j $(nproc) または cmake --build . -j $(nproc)</code>
*: <code>make install または cmake --install .</code>
*: <code>make install または cmake --install .</code>
<br>
<br>
* <code>git clone</code>コマンドを使用する場合
* <code>git clone</code>コマンドを使用する場合
*: <code>git clone https://github.com/symless/synergy-core.git</code>
*: <code>git clone https://github.com/deskflow/deskflow.git</code>
*: <code>cd synergy-core</code>
*: <code>cd deskflow</code>
*: 最新安定版 : <code>git checkout master</code>
*: 最新開発版 : <code>git checkout vX.Y.Z</code>
*: <br>
*: <br>
*: Synergyをビルドおよびインストールする。
*: Deskflowをビルドおよびインストールする。
*: <code>cd synergy-core && mkdir build && cd build</code>
*: <code>mkdir build && cd build</code>
*: <br>
*: <br>
*: <code>cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=<Synergyのインストールディレクトリ> ..</code>
*: <code>cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=<Synergyのインストールディレクトリ> ..</code>
80行目: 90行目:
*: <code>make install または cmake --install .</code>
*: <code>make install または cmake --install .</code>
<br>
<br>
Synergyの実行ファイルが存在するディレクトリに、以下のようなシェルスクリプトを作成する。<br>
任意のディレクトリにインストールした場合、Deskflowの実行ファイルが存在するディレクトリに、以下に示すようなシェルスクリプトを作成する。<br>
  vi /<Synergyの実行ファイルがあるディレクトリ>/bin/synergy.sh
  vi /<Deskflowの実行ファイルがあるディレクトリ>/bin/deskflow.sh
<br>
<br>
  <syntaxhighlight lang="sh">
  <syntaxhighlight lang="sh">
  # /<Synergyの実行ファイルがあるディレクトリ>/bin/synergy.shファイル
  # /<Deskflowの実行ファイルがあるディレクトリ>/bin/deskflow.shファイル
   
   
  #!/usr/bin/env sh
  #!/usr/bin/env sh
   
   
  appname="synergy"
  appname="deskflow"
   
   
  # use -f to make the readlink path absolute
  # use -f to make the readlink path absolute
103行目: 113行目:
  export LD_LIBRARY_PATH="$dirname/../lib64:${LD_LIBRARY_PATH}"
  export LD_LIBRARY_PATH="$dirname/../lib64:${LD_LIBRARY_PATH}"
   
   
  # Run Synergy binary
  # Run Deskflow binary
  "${dirname}/${appname}" "$@"
  "${dirname}/${appname}" "$@"
  </syntaxhighlight>
  </syntaxhighlight>
<br>
<br>
Windowsの場合は、Githubにあるインストーラをダウンロードしてインストールする。<br>
Windowsの場合は、Githubにあるインストーラをダウンロードしてインストールする。<br>
インストールした後、Synergyの設定を行う。<br>
インストールした後、Deskflowの設定を行う。<br>
<br>
<br>
==== Synergyのアンインストール ====
==== Deskflowのアンインストール ====
* Windowsの場合
* Windowsの場合
*# [プログラムの追加と削除](または[アプリと機能])で、Synergyをアンインストールする。<br>この時、"アプリとその関連情報がアンインストールされます"というメッセージが表示されるので、再度、[アンインストール]ボタンを押下する。
*# [プログラムの追加と削除](または[アプリと機能])で、Deskflowをアンインストールする。<br>この時、"アプリとその関連情報がアンインストールされます"というメッセージが表示されるので、再度、[アンインストール]ボタンを押下する。
*# [アプリを終了する必要があります]メッセージ、および、アプリを自動的に終了させるかどうかを尋ねられるので、これを選択する。
*# [アプリを終了する必要があります]メッセージ、および、アプリを自動的に終了させるかどうかを尋ねられるので、これを選択する。
*# 次に、regeditを実行して、以下に示すレジストリキーを削除する。(存在する場合)
*# 次に、regeditを実行して、以下に示すレジストリキーを削除する。(存在する場合)
*#* HKEY_CURRENT_USER\Software\Deskflow\Deskflow
*#* HKEY_CURRENT_USER\Software\Symless
*#* HKEY_CURRENT_USER\Software\Symless
*#* HKEY_CURRENT_USER\Software\Synergy
*#* HKEY_CURRENT_USER\Software\Synergy
134行目: 145行目:
*# パッケージ管理システムを使用して、Synergyを削除する。
*# パッケージ管理システムを使用して、Synergyを削除する。
*# 次に、以下のコマンドを実行して、Synergyの設定を削除する。
*# 次に、以下のコマンドを実行して、Synergyの設定を削除する。
*#* <code>rm -rf ~/.config/Deskflow/</code>
*#* <code>rm -rf ~/.config/Symless/</code>
*#* <code>rm -rf ~/.config/Symless/</code>
*#* <code>rm -rf ~/.config/Synergy/</code>
*#* <code>rm -rf ~/.config/Synergy/</code>
156行目: 168行目:
<br>
<br>
一方で、Synergy 3は有料版のみの提供となり、以前のバージョンにあったOSS版は提供されていない。<br>
一方で、Synergy 3は有料版のみの提供となり、以前のバージョンにあったOSS版は提供されていない。<br>
Synergy 3 (3台まで可能) は$29.00、Synergy 3 Ultimate (15台まで可能) は$49.00となっている。<br>
<br>
<u>※注意 1</u><br>
<u>Synergy 3では、GLIBC 2.34以降が必要となることに注意する。</u><br>
<br>
<br>
Synergy 3はWaylandもサポートしているが、libeiライブラリが必要となることに注意する。<br>
<u>※注意 2</u><br>
また、libeiライブラリをサポートしているDEについては、GNOME 46以降、あるいは、KDE Plasma 6.1以降が必要となることが多い。<br>
<u>Synergy 3はWaylandもサポートしているが、libeiライブラリが必要となることに注意する。</u><br>
<u>また、libeiライブラリをサポートしているDEについては、GNOME 46以降、あるいは、KDE Plasma 6.1以降が必要となることが多い。</u><br>
<br>
<br>
以下に示すようなlibeiライブラリをサポートしていないLinuxディストリビューションにおいて、Synergy 3を使用する場合はXorgに切り替える必要がある。<br>
以下に示すようなlibeiライブラリをサポートしていないLinuxディストリビューションにおいて、Synergy 3を使用する場合はXorgに切り替える必要がある。<br>
393行目: 410行目:
== ファイヤーウォールの設定 ==
== ファイヤーウォールの設定 ==
ファイヤーウォールのポート開放を行う。<br>
ファイヤーウォールのポート開放を行う。<br>
# 一般的な設定
  sudo firewall-cmd --permanent --add-port=24800/tcp
  sudo firewall-cmd --permanent --add-port=24800/tcp
  または
   
# KVM (libvirtd) を使用している場合
  sudo firewall-cmd --permanent --zone=libvirt --add-port=24800/tcp
  sudo firewall-cmd --permanent --zone=libvirt --add-port=24800/tcp
   
   
# Friewalldの設定を反映
  sudo firewall-cmd --reload
  sudo firewall-cmd --reload
<br>
<br>
434行目: 454行目:
  または
  または
  sudo shutdown -r now
  sudo shutdown -r now
<br>
<br><br>
 
== コンソールの使用 ==
== コンソールの使用 ==
  # Barrier Client
  # Barrier Client

2025年1月15日 (水) 01:16時点における最新版

概要

Synergy / 3およびBarrierは、ネットワークを介して複数のコンピュータ間でマウスとキーボードを共有するためのソフトウェア (Input Device Sharing Software) である。

これは、以下に示すような特徴がある。

  • 1つのキーボードとマウスで複数のPCの操作
    画面の端にマウスを移動させて、接続された別のPCの画面に自然にカーソルが移動する。
    これにより、複数のPCを使用する場合でも、物理的なキーボードやマウスの切り替えが不要になる。
  • ネットワーク経由での動作
    SSLによる暗号化通信を採用しており、データの安全性が確保されている。
    また、パスワード保護機能により、許可されていない接続を防ぐことができる。
  • クリップボードの共有等の追加機能
    クリップボードの共有機能も搭載されており、あるPCでコピーしたテキストや画像を別のPCにペーストできる。
    ドラッグ&ドロップによるファイル共有も可能であり、異なるOSのコンピュータ間でもスムーズにファイルを転送できる。


PCの配置関係や共有する機能の詳細な調整が可能である。

Windows、MacOS、Linux等の異なるOS間でも利用することが可能である。


Deskflow (旧 Synergy Core)

Deskflowは、Synergy3の無償の公式アップストリームプロジェクトある。
Deskflowプロジェクトは、誰もが協力できるコミュニティ主導の開発を育成するために設立されている。

Deskflowを使用することにより、Windows、MacOS、Linux上の複数のPC間で1つのマウスとキーボードを共有することが可能である。(映像出力なしのソフトウェアKVM)

パッケージ管理システムからインストール

# RHEL
-

# SUSE
-

# Raspberry Pi OS / Mobian
-


ソースコードからインストール

まず、Deskflowのビルドに必要な依存関係のライブラリをインストールする。

※注意
Qt 6.5以降、CMake 3.24以降、OpenSSL 3.0以降が必要となることに注意する。

# RHEL
sudo dnf install epel-release
sudo dnf config-manager --set-enabled crb
sudo dnf install cmake make ninja-build gcc-c++ gtk3-devel \
                 glib2-devel gdk-pixbuf2-devel libcurl-devel libnotify-devel libei-devel    \
                 libportal-devel openssl-devel libXtst-devel libxkbfile-devel pugixml-devel \
                 qt6-qtbase-devel qt6-qttools-devel \
                 gtest-devel gmock-devel            \
                 tomlplusplus-devel cli11-devel

# SUSE
sudo zypper install make cmake ninja gcc-c++ glib2-devel gtk3-devel                \
                    gdk-pixbuf-devel avahi-compat-mDNSResponder-devel dbus-1-devel \
                    libcurl-devel libnotify-devel libopenssl-devel libavahi-devel fixesproto-devel libportal-devel pugixml-devel   \
                    libXrandr-devel libXext-devel libXfixes-devel libXinerama-devel libXi-devel libXtst-devel xextproto-devel      \
                    libxkbcommon-devel libxkbfile-devel inputproto-devel recordproto-devel libSM-devel                             \
                    libei-devel cli11-devel tomlplusplus-devel                                                                     \
                    qt6-base-devel qt6-core-devel qt6-widgets-devel qt6-network-devel qt6-dbus-devel qt6-linguist-devel qt6-tools-devel

# Raspberry Pi OS / Mobian
  apt install cmake build-essential ninja-build libglib2.0-dev libgtk-3-dev \
              libgdk-pixbuf-2.0-dev libnotify-dev libpugixml-dev libssl-dev \
              libei-dev libportal-dev libtomlplusplus-dev libcli11-dev      \
              xorg-dev libx11-dev libxtst-dev libxkbfile-dev                \
              qt6-base-dev qt6-tools-dev                                    \
              libgtest-dev libgmock-dev


  • 各バージョンのソースコードからインストールする場合
    DeskflowのGithubからソースコードをダウンロードする。
    ダウンロードしたファイルを解凍する。
    tar xf deskflow-<バージョン>.tar.gz
    cd deskflow-<バージョン>

    Deskflowをビルドおよびインストールする。
    mkdir build && cd build
    cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=<Deskflowのインストールディレクトリ> ..
    make -j $(nproc) または cmake --build . -j $(nproc)
    make install または cmake --install .


  • git cloneコマンドを使用する場合
    git clone https://github.com/deskflow/deskflow.git
    cd deskflow

    Deskflowをビルドおよびインストールする。
    mkdir build && cd build

    cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=<Synergyのインストールディレクトリ> ..
    make -j $(nproc) または cmake --build . -j $(nproc)
    make install または cmake --install .


任意のディレクトリにインストールした場合、Deskflowの実行ファイルが存在するディレクトリに、以下に示すようなシェルスクリプトを作成する。

vi /<Deskflowの実行ファイルがあるディレクトリ>/bin/deskflow.sh


 # /<Deskflowの実行ファイルがあるディレクトリ>/bin/deskflow.shファイル
 
 #!/usr/bin/env sh
 
 appname="deskflow"
 
 # use -f to make the readlink path absolute
 dirname="$(dirname -- "$(readlink -f -- "${0}")" )"
 
 if [ "$dirname" = "." ]; then
    dirname="${PWD}/${dirname}"
 fi
 
 cd $dirname
 
 # Initialize interpreter path
 export PATH="$dirname:$PATH"
 export LD_LIBRARY_PATH="$dirname/../lib64:${LD_LIBRARY_PATH}"
 
 # Run Deskflow binary
 "${dirname}/${appname}" "$@"


Windowsの場合は、Githubにあるインストーラをダウンロードしてインストールする。
インストールした後、Deskflowの設定を行う。

Deskflowのアンインストール

  • Windowsの場合
    1. [プログラムの追加と削除](または[アプリと機能])で、Deskflowをアンインストールする。
      この時、"アプリとその関連情報がアンインストールされます"というメッセージが表示されるので、再度、[アンインストール]ボタンを押下する。
    2. [アプリを終了する必要があります]メッセージ、および、アプリを自動的に終了させるかどうかを尋ねられるので、これを選択する。
    3. 次に、regeditを実行して、以下に示すレジストリキーを削除する。(存在する場合)
      • HKEY_CURRENT_USER\Software\Deskflow\Deskflow
      • HKEY_CURRENT_USER\Software\Symless
      • HKEY_CURRENT_USER\Software\Synergy
      • HKEY_LOCAL_MACHINE\SOFTWARE\Synergy

    4. 以下のディレクトリが存在する場合は、削除する。
      • C:\ProgramData\Symless
      • C:\ProgramData\Synergy
      • C:\ProgramData\Synergy v2
      • %USERPROFILE%\AppData\Local\Synergy
      • %USERPROFILE%\AppData\Local\Symless

    5. 次に、SystemConfig.iniファイルを削除する。
      この時、以前に保存した設定は失われる。
      C:\Program Files\Synergy\SystemConfig.ini

    6. 最後に、Windowsを再起動する。

  • Linuxの場合
    1. パッケージ管理システムを使用して、Synergyを削除する。
    2. 次に、以下のコマンドを実行して、Synergyの設定を削除する。
      • rm -rf ~/.config/Deskflow/
      • rm -rf ~/.config/Symless/
      • rm -rf ~/.config/Synergy/
      • rm -rf ~/.synergy/
      • rm -rf ~/.symless/

    3. 次に、SystemConfig.iniファイルを削除する。
      この時、以前に保存した設定は失われる。
      sudo rm -rf /usr/local/etc/Symless/SystemConfig.ini



Synergy 3

Synergy 3は、UIデザインが大幅に刷新されて、より直感的な操作が可能になった。
ウィザード形式の設定補助が追加されて、ビギナーでも簡単に設定できるようになっている。

また、接続の安定性も向上しており、Synergy 1では時々接続が切れる問題が報告されていたが、Synergy 3ではネットワークプロトコルが改善されており安定した接続を維持できる。
特に、Wi-Fi環境下での信頼性が大きく向上している。

TLS 1.3による暗号化が標準実装されて、Synergy 1では暗号化機能は別途設定が必要だったが、Synergy 3ではデフォルトで有効になっている。

クリップボード共有機能も強化され、より大きなサイズのデータや多様な形式のデータを扱えるようになった。
また、ドラッグ&ドロップによるファイル転送の信頼性も向上している。

一方で、Synergy 3は有料版のみの提供となり、以前のバージョンにあったOSS版は提供されていない。
Synergy 3 (3台まで可能) は$29.00、Synergy 3 Ultimate (15台まで可能) は$49.00となっている。

※注意 1
Synergy 3では、GLIBC 2.34以降が必要となることに注意する。

※注意 2
Synergy 3はWaylandもサポートしているが、libeiライブラリが必要となることに注意する。
また、libeiライブラリをサポートしているDEについては、GNOME 46以降、あるいは、KDE Plasma 6.1以降が必要となることが多い。

以下に示すようなlibeiライブラリをサポートしていないLinuxディストリビューションにおいて、Synergy 3を使用する場合はXorgに切り替える必要がある。

  • Ubuntu 22.04以前
  • Linux Mint 21以前
  • Fedora 38以前
  • Debian 12以前
  • RHEL 9 / Rocky Linux 9 / AlmaLinux 9以前
  • CentOS Stream


Synergy 3のインストール

Synergyの公式Webサイトにアクセスして、Synergy 3をダウンロードする。
Synergy 3をインストールする。

# RHEL 9
-

# SUSE
sudo zypper install ./synergy-<バージョン>-linux-<Synergyのコードネーム>-x64.rpm


この時、GPGキーの署名に関する警告が出力される場合がある。
この警告を無視する場合は、[I]キーを入力する。

synergy-... (Plain RPM files cache): Signature failed ...
Abort, retry, ignore? [a/r/i] (a):


Synergy 3のアンインストール

# RHEL 9
-

# SUSE
sudo zypper remove synergy



Barrier (非推奨)

2021年以降、Barrierの開発は止まっているため、非推奨とする。

パッケージ管理システムからインストール

まず、以下のコマンドを実行して、LinuxにBarrierをインストールする。

sudo zypper install barrier


次に、BarrierのGiHubにアクセスして、Windows向けのBarrierの実行ファイルをダウンロードしてインストールする。
インストール後、Barrierの設定を行う。

ソースコードからインストール

まず、Barrierをビルドするため、依存関係のライブラリをインストールする。

# RHEL (EPELリポジトリの追加が必要)
sudo dnf groupinstall "Development Tools"

sudo dnf install 'dnf-command(config-manager)'
sudo dnf config-manager --set-enabled PowerTools

sudo dnf install cmake3 libcurl-devel avahi-compat-libdns_sd-devel libX11-devel libXtst-devel desktop-file-utils openssl-devel \
                 qt5-qtbase-devel

# SUSE
sudo zypper install --type pattern devel_basis
sudo zypper install libdrm-devel libglvnd-devel libICE-devel \
                    libcurl-devel avahi-compat-mDNSResponder-devel libXtst-devel libopenssl-devel \
                    libSM-devel libXinerama-devel libXrandr-devel Mesa-devel \
                    libQt5Core-devel libQt5Gui-devel libQt5Network-devel libqt5-qtbase-common-devel libQt5Widgets-devel


次に、BarrierのGiHubにアクセスして、Barrierのソースコードをダウンロードする。
ダウンロードしたファイルを解凍して、ビルド向けディレクトリを作成する。

# Tarballからビルドする場合
tar xf barrier-<バージョン>-release.tar.gz
cd barrier-<バージョン>-release && mkdir build && cd build

# Gitからビルドする場合
git clone https://github.com/debauchee/barrier.git barrier && cd barrier
git submodule update --init --recursive 
./clean_build.sh
cd build


※注意
Tarballをダウンロードした時、Barrierディレクトリのext/gmockディレクトリ、ext/gtestディレクトリ、ext/gulrak-filesystemディレクトリが空の場合、
以下のモジュールのソースコードをダウンロードする必要がある。

# Tarballのモジュールをダウンロードする場合
wget https://github.com/google/googletest/archive/refs/tags/release-<バージョン>.tar.gz
wget https://github.com/gulrak/filesystem/archive/refs/tags/<バージョン>.tar.gz
tar xf googletest-release-<バージョン>.tar.gz
tar xf filesystem-<バージョン>.tar.gz

# Gitを使用してモジュールをダウンロードする場合
git clone https://github.com/google/googletest.git
git clone https://github.com/gulrak/filesystem


Barrierのビルドに必要なソースコードを、Barrierディレクトリのext/gmockディレクトリ、ext/gtestディレクトリ、ext/gulrak-filesystemディレクトリにコピーする。

# Tarballのモジュールをダウンロードした場合
cp -r googletest-release-<バージョン>/googlemock <Barrierディレクトリ>/ext/gmock
cp -r googletest-release-<バージョン>/googletest <Barrierディレクトリ>/ext/gtest
cp -r filesystem-<バージョン>/* <Barrierディレクトリ>/ext/gulrak-filesystem

# Gitを使用してモジュールをダウンロードした場合
cp -r googletest/googlemock/* <Barrierディレクトリ>/ext/gmock
cp -r googletest/googletest/* <Barrierディレクトリ>/ext/gtest
cp -r filesystem/* <Barrierディレクトリ>/ext/gulrak-filesystem


Barrierをビルドおよびインストールする。

# Tarballからインストールする場合
cmake  -DCMAKE_INSTALL_PREFIX=${HOME}/InstallSoftware/Barrier -DCMAKE_BUILD_TYPE=Release ..
make -j $(nproc)
make install

# Gitからインストールする場合
make DESTDIR=${HOME}/InstallSoftware/Barrier install 


Barrierの起動スクリプトを作成する。

vi ~/InstallSoftware/Barrier/barrier.sh


 # ~/InstallSoftware/Barrier/barrier.sh
 
 #!/usr/bin/env sh
 
 appname="barrier"
 
 # use -f to make the readlink path absolute
 dirname="$(dirname -- "$(readlink -f -- "${0}")" )"
 
 if [ "$dirname" = "." ]; then
    dirname="${PWD}/${dirname}"
 fi
 
 cd ${dirname}
 
 # Initialize interpreter path
 export PATH="${dirname}:${PATH}"
 export LD_LIBRARY_PATH="/<Qtのインストールディレクトリ>/<Qtのバージョン>/gcc_64/lib:${LD_LIBRARY_PATH}"
 
 # Run Barrier binary
 "${dirname}/${appname}" "$@"


Barrierの起動スクリプトに実行権限を付加する。

chmod u+x ~/InstallSoftware/Barrier/barrier.sh


Barrierの実行に必要な依存関係のパッケージをインストールする。

sudo zypper install libdns_sd


Barrierのデスクトップエントリファイルを、~/.local/share/applicationsディレクトリに作成する。

# ~/.local/share/applications/Barrier.desktop

[Desktop Entry]
Type=Application
Name=Barrier <バージョン>
GenericName=Barrier
Comment=Keyboard and mouse sharing solution
Exec=/home/<ユーザ名>/InstallSoftware/Barrier/bin/barrier.sh
Icon=/home/<ユーザ名>/InstallSoftware/Barrier/barrier
Terminal=false
Categories=Utility;
Keywords=keyboard;mouse;sharing;network;share;


次に、BarrierのGiHubにアクセスして、Windows向けのBarrierの実行ファイルをダウンロードする。
KVMのゲストOSであるWindowsに、Barrierをインストールする。

Barrierのインストール完了後、Barrierの設定を行う。

Windowsにおいて、Barrierを自動起動する場合は以下の手順を行う。

  1. まず、[スタート]ボタンを押下して、起動時に実行するソフトウェアを右クリックする。
  2. コンテキストメニューから[その他] - [ファイルの場所を開く]を選択して、ソフトウェアのショートカットが保存されているディレクトリを開く。
    もし、[ファイルの場所を開く]オプションが表示されない場合、そのソフトウェアは起動時に実行できないことを意味する。
  3. 次に、[Super]キー + [R]キーを同時押下して、shell:startupと入力、[OK]ボタンを押下する。
  4. [スタートアップ]ディレクトリが開くので、ソフトウェアのショートカットが保存されているディレクトリから、ショートカットを[スタートアップ]ディレクトリにコピーする。


Waylandの場合

Barrierは、Wayland上でにおいてはグラフィカルで起動することができない。
そのため、自動起動する場合は、コンソールまたはSystemdサービスユニットを作成して実行する必要がある。

コンソールから通常起動する場合、以下に示すコマンドを実行する。

# ゲストOS側 (クライアント側)
barrierc --name <クライアントのスクリーン名>              \
         --display <ディスプレイ番号>                   \
         -f <サーバのIPアドレスまたはホスト名>:<ポート番号> \
         --disable-crypto --daemon


コンソールから自動起動する場合は、~/.config/autostart/Barrier.desktopファイルを以下に示す内容で作成する。

 # ~/.config/autostart/Barrier.desktopファイル
 
 [Desktop Entry]
 Type=Application
 Name=StartBarrier
 Exec=bash -c 'barrierc --name <クライアントのスクリーン名> --display <ディスプレイ番号> -f <サーバのIPアドレスまたはホスト名>:<ポート番号> --disable-crypto --daemon
 Icon=dialog-scripts


Systemdサービスユニットとして起動する場合、/etc/systemd/system/barrier.serviceファイルを以下に示す内容で作成する。
これは、X11が:0にあると仮定している。

SystemdサービスユニットではマルチユーザでBarrierが使用できないため、ユーザサービスを使用する。

※注意
Systemdサービスユニットとして、スーパーユーザでBarrierを実行することによりセキュリティ上の懸念が存在する。
ログに記録する前にBarrierを使用する必要がある場合(DMで使用する場合)は、この方法が唯一の選択肢である。
ログイン画面でBarrierを使用する必要が無い場合は、デスクトップエントリファイルを作成して自動起動することを推奨する。

 # /etc/systemd/system/barrier.serviceファイル
 
 [Unit]
 Description=Barrier Client daemon
 After=network.target
 
 [Service]
 User=<ユーザ名>
 Group=<グループ名>
 ExecStart=barrierc --name <クライアントのスクリーン名> --display <ディスプレイ番号> -f <サーバのIPアドレスまたはホスト名>:<ポート番号> --disable-crypto --debug INFO
 Restart=always
 
 [Install]
 WantedBy=multi-user.target


Barrierのアンインストール

  • Windows
    1. Barrierをアンインストールする前に、Barrierを終了する。
      Barrierを起動したままでアンインストールした場合、ほとんどのBarrierに関するファイルが残ってしまうため注意すること。
    2. Barrierのサービスを停止するため、管理者権限でPowershellまたはコマンドプロンプトを起動して、net stopコマンドを実行する。
      これは、sc stopコマンドでは非同期で実行されるため、sc deleteコマンドが失敗して、アンインストール後にbarrierd.exeが残るからである。
    3. net stopコマンドを実行する。
      net stopコマンドは、Barrierのサービスが停止するまで同期で実行するため、sc deleteコマンドが成功する。
    4. [設定] - [アプリ]画面または[コントロールパネル] - [プログラムと機能]画面から、Barrierをアンインストールする。
    5. 次に、C:\Program Files\BarrierフォルダおよびC:\ProgramData\Barrierフォルダを削除する。
    6. C:\Users\<ユーザ名>\AppData\Local\Barrierディレクトリを削除する。
    7. C:\Users\<ユーザ名>\AppData\Local\Tempディレクトリに存在する"Barrier."から始まるファイル群を削除する。
    8. regeditを実行して、\HKEY_USERS\S-<Windows11の現在のビルド番号>\SOFTWARE\Debaucheeを削除する。
    9. %LocalAppData%\Barrierフォルダ(レジストリ設定、Barrierの設定ファイル、証明書、フィンガープリント)を削除する。
    10. 必要ならば、Barrierに関するファイヤーウォールのルールを削除する。

  • Linux
    1. まず、Barrierのインストールディレクトリを削除する。
      rm -rf <Barrierのインストールディレクトリ>
    2. 次に、Barrierの設定ファイルが存在するディレクトリを削除する。
      rm -rf ~/.local/share/barrier
      rm -rf ~/.config/Debauchee



ファイヤーウォールの設定

ファイヤーウォールのポート開放を行う。

# 一般的な設定
sudo firewall-cmd --permanent --add-port=24800/tcp

# KVM (libvirtd) を使用している場合
sudo firewall-cmd --permanent --zone=libvirt --add-port=24800/tcp

# Friewalldの設定を反映
sudo firewall-cmd --reload


SUSEの場合および上記のコマンドで接続できない場合は、以下の設定を行う。

まず、/usr/lib/firewalld/services/barrier.xmlファイルを作成する。
(このファイルは不要の可能性があることに注意すること)

sudo vi /usr/lib/firewalld/services/barrier.xml


 <?xml version="1.0" encoding="utf-8"?>
    <service>
    <short>Synergy</short>
    <description>Share a mouse and keyboard on KVM.</description>
    <port protocol="tcp" port="24800"/>
 </service>


次に、/usr/lib/firewalld/zones/libvirt.xmlファイルにおいて、
</zone>タグの上部に<port port="24800" protocol="tcp"/>を追記する。

sudo nano /usr/lib/firewalld/zones/libvirt.xml


 <?xml version="1.0" encoding="utf-8"?>
 <zone target="ACCEPT">
 
    <!-- ...略 -->
 
    <port port="24800" protocol="tcp"/>
 </zone>


最後に、上記の設定を有効にするため、ファイアーウォールを再読み込みまたはPCを再起動する。
または、PCを再起動する。

sudo firewall-cmd --reload
sudo systemctl restart firewalld
または
sudo shutdown -r now



コンソールの使用

# Barrier Client
barrierc --daemon --name <クライアントのスクリーン名> <サーバのIPアドレス>

# Barrier Server
barriers --daemon --address <クライアントのIPアドレス> --name <クライアントのスクリーン名> \
         --config <Barrierの設定ファイルのパス>

# Synergy Micro Client
# Wayland向け
waynergy --host <サーバIPアドレス> --name <クライアントのPC名> --logfile <ログファイルのパス>