Prog/分散ビルド/distcc
の編集
[
トップ
] [
編集
|
差分
|
履歴
|
添付
|
リロード
] [
新規
|
一覧
|
検索
|
最終更新
|
ヘルプ
]
-- 雛形とするページ --
App
App/archiver
App/audio
App/audio/audacity
App/audio/mpg321
App/audio/puddletag
App/base64
App/Browser
App/column
App/diff-patch
App/downloader
App/ffmpeg
App/ffprobe
App/find
App/gimp
App/gnuplot
App/ImageMagick
App/info
App/inxi
App/LibreOffice
App/locate
App/md5
App/Music
App/Music/frescobaldi
App/Music/MuseScore
App/OCR
App/od
App/OpenOffice.org
App/pagers
App/pdf
App/QRコード
App/ripgrep
App/screen
App/script
App/sed
App/selenium
App/signal-desktop
App/skype
App/sylpheed
App/tmux
App/ttyrec
App/uniq
App/UUID
App/wget
App/xargs
App/テキスト処理
App/仮想化
App/仮想化/Docker
App/仮想化/qemu
App/仮想化/webos
AutoTicketLinkName
BracketName
CentOS
CentOS/yum
CrossCompile
Debian
Debian/kernel
Debian/kernel/ver8-or-older
Debian/Plan9関連
Debian/ver5
Debian/ver6
Debian/ver7
Debian/ver8
Debian/ver9
Debian/ver10
Debian/ver11
Debian/ver12
Debian/X
Debian/X/日本語
Debian/パッケージ管理
Deveice/Sensor/MotionSensor
Device
Device/Mouse
Device/Net/wifi
Device/Scanner
Device/Sensor
Device/Sensor/MotionSensor
Device/tty
Device/xmodmap
Editor
Editor/atom
Editor/binary
Editor/binary/beav
Editor/binary/hexedit
Editor/emacs
Editor/emacs/clang-format
Editor/emacs/flycheck
Editor/emacs/gdb-mode
Editor/emacs/github/copilot
Editor/emacs/html-mode
Editor/emacs/lisp
Editor/emacs/lsp-mode
Editor/emacs/markdown-mode
Editor/emacs/neotree
Editor/emacs/package-install
Editor/emacs/sdic
Editor/emacs/speedbar
Editor/emacs/XEmacs
Editor/emacs/ローカルビルド
Editor/emacs/多言語
Editor/fte
Editor/vi
FormattingRules
FrontPage
Help
InterWiki
InterWikiName
InterWikiSandBox
iPhone
Lang
Lang/C++
Lang/C++/Boost
Lang/C++/C++11
Lang/C++/C++11/thread
Lang/C++/C++11/コンテナ
Lang/C++/C++11/コンテナ/string
Lang/C++/C++11/初期化子
Lang/C++/C++17
Lang/C++/C++20
Lang/C++/error
Lang/C++/macro
Lang/C++/template
Lang/C++/コンテナ
Lang/C++/処理系
Lang/C-Sharp
Lang/Go
Lang/html
Lang/html/5
Lang/html/5/canvas
Lang/html/css
Lang/Java
Lang/Java/jar
Lang/Objective-C
Lang/Pascal
Lang/Perl
Lang/Perl/CGI
Lang/Perl/thread
Lang/Perl/utf-8
Lang/pike
Lang/Python
Lang/Python/Class
Lang/Python/Error
Lang/Python/import対象パス
Lang/Python/pip
Lang/Python/基本文法
Lang/Python/開発環境
Lang/Rust
Lang/sed
Lang/shell
Lang/shell/bash
Lang/shell/bash/設定
Lang/shell/bash/設定/command-not-found
Lang/Tcl_Tk_Expect
Lang/Tcl_Tk_Expect/Ctrl-キーマップ
Lang/TypeScript
Lang/xml
Mac
Memo
memo
MenuBar
midi
Multimedia
Net
Net/apache
Net/apache2
Net/dig
Net/dns/server
Net/domain
Net/http/アクセス制御
Net/iptables
Net/IRC
Net/Jenkins
Net/lighttpd
Net/mail
Net/mail/X-Face
Net/news
Net/news/gnus
Net/ntp
Net/pukiwiki
Net/pukiwiki/plugin
Net/resolv.conf
Net/SPAM
Net/ss
Net/tcpdump
Net/traceroute
Net/twitter
Net/vpn
Net/web
Net/webAPI
Net/wifi
Net/wifi/AP
Net/監視
otherlinks
PHP
Plan9
PPC
PPC/LinuxPPC
PPC/MkLinux
Prog
Prog/AI
Prog/autotools
Prog/cmake
Prog/Compiler/gcc
Prog/CrossReferencer
Prog/debug
Prog/debug/gdb
Prog/debug/lldb
Prog/debug/ltrace
Prog/debug/memory
Prog/debug/strace
Prog/formatter/clang-format
Prog/GoogleTest
Prog/Gtk
Prog/IDE
Prog/IDE/Geany
Prog/ldd
Prog/make
Prog/nm
Prog/Profiler
Prog/Qt
Prog/readelf
Prog/Sound
Prog/StaticCodeAnalysis
Prog/StaticCodeAnalysis/cppcheck
Prog/strip
Prog/TagSystem
Prog/TagSystem/cscope
Prog/TagSystem/ctags-exuberant
Prog/TagSystem/ebrowse
Prog/TagSystem/etags
Prog/TagSystem/gtags
Prog/TagSystem/id-utils
Prog/TagSystem/lctags
Prog/TagSystem/rtags
Prog/TagSystem/SilentBob
Prog/X/X11
Prog/プロセス間通信
Prog/プロセス間通信/SharedMemory
Prog/プロセス間通信/singal
Prog/人為的なシグナル
Prog/分散ビルド/distcc
Prog/逆アセンブル
PukiWiki
PukiWiki/1.4
PukiWiki/1.4/Manual
PukiWiki/1.4/Manual/Plugin
PukiWiki/1.4/Manual/Plugin/A-D
PukiWiki/1.4/Manual/Plugin/E-G
PukiWiki/1.4/Manual/Plugin/H-K
PukiWiki/1.4/Manual/Plugin/L-N
PukiWiki/1.4/Manual/Plugin/O-R
PukiWiki/1.4/Manual/Plugin/S-U
PukiWiki/1.4/Manual/Plugin/V-Z
RecentDeleted
RS232C
SandBox
Security
Security/aide
Security/chkrootkit
Security/clamav
Security/gpg
Security/pkcs
Security/rkhunter
Security/ssh
Security/test
Security/パスワード解析
System
System/Audio
System/beep
System/bluetooth
System/cpu
System/dm-crypt
System/fs
System/fs/ext2-3
System/fs/mount
System/fs/nfs
System/fs/tmpfs
System/fs/xfs
System/fs/大容量のファイルを高速に作成する
System/fs/強制物理フォーマット
System/grub
System/Hardware情報
System/HDD/IDE/チューニング
System/input
System/iostat
System/Kernel
System/Kernel/Module
System/locale
System/memory
System/OpenCL
System/os
System/power/battery
System/Process
System/random
System/rpm
System/runlevel
System/signal
System/sudo
System/swap
System/USB-Boot
System/user
System/シリアル接続
System/環境変数
TeX
TeX/MusiXTeX
tools
Top/Editor/emacs/python開発環境
transcription/old
Ubuntu
VersionCtl
VersionCtl/git
VersionCtl/git/Gerrit
VersionCtl/git/Gerrit/old
VersionCtl/git/git-gutter+
VersionCtl/git/git-imerge
VersionCtl/git/magit
VersionCtl/git/magit/2.1.0
VersionCtl/git/magit/2.8.0
VersionCtl/git/magit/2.13.1
VersionCtl/git/magit/v3.2.1
VersionCtl/git/magit/v3.3.0
VersionCtl/git/subversion からの移行
VersionCtl/git/subversion とのコマンド対比
VersionCtl/git/tig
VersionCtl/git/統計
VersionCtl/hg
VersionCtl/Mercurial
VersionCtl/repo
VersionCtl/Subversion
WikiEngines
WikiName
WikiWikiWeb
Windows
Windows/cmd
X
X/DisplayManager
X/DisplayManager/gdm3
X/DisplayManager/lightdm
X/font
X/font/old
X/GNOME3
X/input
X/input/OnScreenKeyboard
X/input/キーアサインを変更する
X/input/グラゴル文字
X/input/日本語
X/input/日本語/ATOK X3
X/input/日本語/ibus
X/input/日本語/uim
X/KDE
X/remote
X/screensaver
X/terminal
X/terminal/mlterm
X/terminal/urxvt
X/terminal/uxterm
X/vnc
X/vnc/tigervnc
X/WindowManager
X/WindowManager/9wm
X/WindowManager/amiwm
X/WindowManager/awesome
X/WindowManager/CDE
X/WindowManager/cinnamon
X/WindowManager/dwm
X/WindowManager/flwm
X/WindowManager/i3
X/WindowManager/jwm
X/WindowManager/matchbox
X/WindowManager/MATE
X/WindowManager/mlvwm
X/WindowManager/qvwm
X/WindowManager/ratpoison
X/WindowManager/ude
X/WindowManager/WindowMaker
X/WindowManager/xfce4
X/xdotool
X/Xnest
X/xrdp
X/xvfb
YukiWiki
スタジオ・ホール
旅
旅/Czech
旅/三重
旅/京都・滋賀
旅/兵庫
旅/千葉
旅/各務
旅/和歌山
旅/埼玉
旅/山形
旅/岐阜
旅/岡山
旅/岩手
旅/島根
旅/愛媛
旅/新潟
旅/東京
旅/栃木
旅/神奈川
旅/秋田
旅/群馬
旅/茨城
旅/長野・山梨
旅/静岡
旅/静岡/伊豆
未整理
食
食/チェコ
食/各国
食/料理
食/激辛
食/蕎麦
食/郷土料理
#topicpath * 目次 [#p89c0df5] #contents(); /////////////////////////////////////////////////////////////////////////////// * distcc [#distcc] - distcc は、C/C++/Objective-C/Objective-C++ のビルドをネットワーク上の複数の host に分散して行う機能を実現する。 /////////////////////////////////////////////////////////////////////////////// * setup [#setup] //============================================================================= ** 前提 [#rf3261d3] - distcc によるクラスタを構成する各 host は、同じバージョンのコンパイラがインストールされている必要がある。 - -march=native オプションは使えない -- CGG 4.3.0 からサポートされたもので、CPU自動判別と最適化の機能を有効にするオプション。 -- このオプションを使用すると、それぞれのプロセッサでの最適化されたコードが生成され、それらが混在してしまうことになる。(クラスタを構成する host が全て同じ CPU を積んでいるなら問題なさそう) //============================================================================= ** setup (master, slave 共通) [#setup-common] - 全てのマシンに distcc パッケージをインストールする - /etc/default/distcc -- 記述例 # Defaults for distcc initscript # sourced by /etc/init.d/distcc # # should distcc be started on boot? # # マシンの起動時に distccd を自動起動する場合は true にする。 STARTDISTCC="true" # # Which networks/hosts should be allowed to connect to the daemon? # You can list multiple hosts/networks separated by spaces. # Networks have to be in CIDR notation, e.g. 192.168.1.0/24 # Hosts are represented by a single IP address # # distcc の命令を受けるホストを IP address の範囲で指定 ALLOWEDNETS="192.168.0.0/24" # # Which interface should distccd listen on? # You can specify a single interface, identified by it's IP address, here. # # LISTENER="127.0.0.1" # distcc の命令を listen するインターフェース(=自機の IP address) LISTENER="192.168.100.12" # # You can specify a (positive) nice level for the distcc process here # # 引き受ける Job の優先度(高:-20〜19:低) NICE="10" # # You can specify a maximum number of jobs, the server will accept concurrently # # 引き受ける job の上限数(マシンの性能・運用方針によって設定する) JOBS="4" # # Enable Zeroconf support? # If enabled, distccd will register via mDNS/DNS-SD. # It can then automatically be found by zeroconf enabled distcc clients # without the need of a manually configured host list. # # zeloconf 環境を構築している場合は true にする。 ZEROCONF="false" //============================================================================= ** setup (master) [#setup-master] *** 環境変数 DISTCC_HOSTS の設定 [#kcb503c7] - distcc の命令を受けるホストの "IP address/多重度" を指定する。多重度は省略すると 4 になる。 - 以下のいずれかの方法で設定する。 -- 環境変数を直接設定する $ export DISTCC_HOSTS="192.168.0.0/8 192.169.1.0/4 localhost" --- 複数エントリを指定する場合は、エントリ間を半角スペースで区切る -- ${HOME}/.distcc/hosts に記載する 192.168.0.0/8,lzo 192.169.1.0/4,cpp,lzo localhost --- 複数エントリを指定する場合は、エントリ間を半角スペースで区切る --- --randomize を指定したい場合も、 ${HOME}/.distcc/hosts に記載すれば良い。 --- , の後に、各ホストに対するオプションを指定出来る |~option |~description |~remark | |lzo |TCP 又は SSH で転送するこのホストで LZO 圧縮を有効にする | | |cpp |distcc-pump mode をこのホストに対して有効にする | | |auth |GSSAPI-based mutual authentication をこのホストで有効にする | | -- 注意 --- DISTCC_HOSTS の設定に於いて、環境変数(方法1)と ${HOME}/.distcc/hosts (方法2)の両方を設定した場合、distcc 起動直前に設定している方法1での設定が優先され、それ以外の設定は無視される。 |~option |~description |~remark | |--randomize |job を投げる対象ホストのオーダーをランダムにする |指定しない場合、jpb を投げられるホストは環境変数 DISTCC_HOSTS で先に指定された順に偏重する | |+zeroconf | |distcc のビルド時に avahi support が有効になっているときのみ使える | - gcc の置き換え -- 何らかの方法で、"gcc" を "distcc gcc" に置き換える。 -- 方法1:Makefile の記載を変える (変更前) CC := gcc (変更後) CC := distcc gcc -- &aname(compiler-wrapper){方法2:コマンドを置き換える};(${HOME}/bin/gcc に wrapper を作る) --- 環境変数で、${HOME}/bin 配下を優先的に見に行くようにする $ export PATH=${HOME}/bin:${PATH} --- ${HOME}/bin/gcc #!/bin/bash distcc gcc ${@} -- 方法3:configure で設定する場合 CC="distcc gcc" CXX="distcc g++" ./configure //============================================================================= ** setup (slave) [#setup-slave] //============================================================================= ** monitor [#monitor] - distccmon-gnome -- GUI の distcc モニタ -- distccmon-gnome パッケージでインストールする。 - distccmon-text -- CUI の distcc モニタ - distcc パッケージに含まれている。 /////////////////////////////////////////////////////////////////////////////// * ccache と併用する [#e1245eda] + ccache パッケージを master ホストにインストールする + コンパイラコマンドを置換する -- 方法1:Makefile の記載を変える (変更前) CC := gcc (変更後) CC := ccache distcc gcc -- [[方法2:コマンドを置き換える>#compiler-wrapper]] で設定する置き換えコマンドの中身を下記のようにする(ccache を追記): #!/bin/bash ccache distcc gcc ${@} -- 方法3:configure で設定する場合 CC="ccache distcc gcc" CXX="ccache distcc g++" ./configure /////////////////////////////////////////////////////////////////////////////// * gcc wrapper [#g5a218a3] - ${HOME}/bin/gcc (or g++, clang, clang++, gobjc, gobjc++) #!/bin/bash IS_MONITOR_EXISTS=$(pgrep distccmon-gnome | wc -l); if [ ${IS_MONITOR_EXISTS} -eq 0 ]; then DISPLAY=${DISPLAY} distccmon-gnome & fi unset IS_MONITOR_EXISTS; CMD_CCHACHE= IS_CCACHE_EXISTS=$(which ccache | wc -l); if [ ${IS_CCACHE_EXISTS} -ne 0 ]; then CMD_CCHACHE=ccache fi ${CMD_CCACHE} distcc gcc ${@} /////////////////////////////////////////////////////////////////////////////// * 参考リンク [#c326f890]
#topicpath * 目次 [#p89c0df5] #contents(); /////////////////////////////////////////////////////////////////////////////// * distcc [#distcc] - distcc は、C/C++/Objective-C/Objective-C++ のビルドをネットワーク上の複数の host に分散して行う機能を実現する。 /////////////////////////////////////////////////////////////////////////////// * setup [#setup] //============================================================================= ** 前提 [#rf3261d3] - distcc によるクラスタを構成する各 host は、同じバージョンのコンパイラがインストールされている必要がある。 - -march=native オプションは使えない -- CGG 4.3.0 からサポートされたもので、CPU自動判別と最適化の機能を有効にするオプション。 -- このオプションを使用すると、それぞれのプロセッサでの最適化されたコードが生成され、それらが混在してしまうことになる。(クラスタを構成する host が全て同じ CPU を積んでいるなら問題なさそう) //============================================================================= ** setup (master, slave 共通) [#setup-common] - 全てのマシンに distcc パッケージをインストールする - /etc/default/distcc -- 記述例 # Defaults for distcc initscript # sourced by /etc/init.d/distcc # # should distcc be started on boot? # # マシンの起動時に distccd を自動起動する場合は true にする。 STARTDISTCC="true" # # Which networks/hosts should be allowed to connect to the daemon? # You can list multiple hosts/networks separated by spaces. # Networks have to be in CIDR notation, e.g. 192.168.1.0/24 # Hosts are represented by a single IP address # # distcc の命令を受けるホストを IP address の範囲で指定 ALLOWEDNETS="192.168.0.0/24" # # Which interface should distccd listen on? # You can specify a single interface, identified by it's IP address, here. # # LISTENER="127.0.0.1" # distcc の命令を listen するインターフェース(=自機の IP address) LISTENER="192.168.100.12" # # You can specify a (positive) nice level for the distcc process here # # 引き受ける Job の優先度(高:-20〜19:低) NICE="10" # # You can specify a maximum number of jobs, the server will accept concurrently # # 引き受ける job の上限数(マシンの性能・運用方針によって設定する) JOBS="4" # # Enable Zeroconf support? # If enabled, distccd will register via mDNS/DNS-SD. # It can then automatically be found by zeroconf enabled distcc clients # without the need of a manually configured host list. # # zeloconf 環境を構築している場合は true にする。 ZEROCONF="false" //============================================================================= ** setup (master) [#setup-master] *** 環境変数 DISTCC_HOSTS の設定 [#kcb503c7] - distcc の命令を受けるホストの "IP address/多重度" を指定する。多重度は省略すると 4 になる。 - 以下のいずれかの方法で設定する。 -- 環境変数を直接設定する $ export DISTCC_HOSTS="192.168.0.0/8 192.169.1.0/4 localhost" --- 複数エントリを指定する場合は、エントリ間を半角スペースで区切る -- ${HOME}/.distcc/hosts に記載する 192.168.0.0/8,lzo 192.169.1.0/4,cpp,lzo localhost --- 複数エントリを指定する場合は、エントリ間を半角スペースで区切る --- --randomize を指定したい場合も、 ${HOME}/.distcc/hosts に記載すれば良い。 --- , の後に、各ホストに対するオプションを指定出来る |~option |~description |~remark | |lzo |TCP 又は SSH で転送するこのホストで LZO 圧縮を有効にする | | |cpp |distcc-pump mode をこのホストに対して有効にする | | |auth |GSSAPI-based mutual authentication をこのホストで有効にする | | -- 注意 --- DISTCC_HOSTS の設定に於いて、環境変数(方法1)と ${HOME}/.distcc/hosts (方法2)の両方を設定した場合、distcc 起動直前に設定している方法1での設定が優先され、それ以外の設定は無視される。 |~option |~description |~remark | |--randomize |job を投げる対象ホストのオーダーをランダムにする |指定しない場合、jpb を投げられるホストは環境変数 DISTCC_HOSTS で先に指定された順に偏重する | |+zeroconf | |distcc のビルド時に avahi support が有効になっているときのみ使える | - gcc の置き換え -- 何らかの方法で、"gcc" を "distcc gcc" に置き換える。 -- 方法1:Makefile の記載を変える (変更前) CC := gcc (変更後) CC := distcc gcc -- &aname(compiler-wrapper){方法2:コマンドを置き換える};(${HOME}/bin/gcc に wrapper を作る) --- 環境変数で、${HOME}/bin 配下を優先的に見に行くようにする $ export PATH=${HOME}/bin:${PATH} --- ${HOME}/bin/gcc #!/bin/bash distcc gcc ${@} -- 方法3:configure で設定する場合 CC="distcc gcc" CXX="distcc g++" ./configure //============================================================================= ** setup (slave) [#setup-slave] //============================================================================= ** monitor [#monitor] - distccmon-gnome -- GUI の distcc モニタ -- distccmon-gnome パッケージでインストールする。 - distccmon-text -- CUI の distcc モニタ - distcc パッケージに含まれている。 /////////////////////////////////////////////////////////////////////////////// * ccache と併用する [#e1245eda] + ccache パッケージを master ホストにインストールする + コンパイラコマンドを置換する -- 方法1:Makefile の記載を変える (変更前) CC := gcc (変更後) CC := ccache distcc gcc -- [[方法2:コマンドを置き換える>#compiler-wrapper]] で設定する置き換えコマンドの中身を下記のようにする(ccache を追記): #!/bin/bash ccache distcc gcc ${@} -- 方法3:configure で設定する場合 CC="ccache distcc gcc" CXX="ccache distcc g++" ./configure /////////////////////////////////////////////////////////////////////////////// * gcc wrapper [#g5a218a3] - ${HOME}/bin/gcc (or g++, clang, clang++, gobjc, gobjc++) #!/bin/bash IS_MONITOR_EXISTS=$(pgrep distccmon-gnome | wc -l); if [ ${IS_MONITOR_EXISTS} -eq 0 ]; then DISPLAY=${DISPLAY} distccmon-gnome & fi unset IS_MONITOR_EXISTS; CMD_CCHACHE= IS_CCACHE_EXISTS=$(which ccache | wc -l); if [ ${IS_CCACHE_EXISTS} -ne 0 ]; then CMD_CCHACHE=ccache fi ${CMD_CCACHE} distcc gcc ${@} /////////////////////////////////////////////////////////////////////////////// * 参考リンク [#c326f890]
テキスト整形のルールを表示する