Debian Edu / Skolelinux Buster 10+edu0 マニュアル 2019-05-16


目次

1. Debian Edu 10+edu0 コード名 Buster のマニュアル
2. Debian Edu と Skolelinux について
2.1. 簡単な歴史と名前が2つある理由
3. 全体の構成
3.1. ネットワーク構成
3.1.1. デフォルトのネットワーク設定
3.1.2. 主サーバー (tjener)
3.1.3. 主サーバーで動作するサービス
3.1.4. LTSP サーバー
3.1.5. シンクライアント
3.1.6. ディスクレスワークステーション
3.1.7. ネットワーククライアント
3.2. 管理
3.2.1. インストール
3.2.2. ファイルシステムのアクセス設定
4. 要件
4.1. ハードウェア要件
4.2. 動作確認済みのハードウェア
5. ネットワーク設定の要件
5.1. デフォルト設定
5.2. インターネットルーター
6. インストールとダウンロードの選択肢
6.1. 追加情報のありか
6.2. Debian Edu 10+edu0 コード名 Buster 用インストールメディアのダウンロード
6.2.1. amd64もしくはi386
6.2.2. i386 及び amd64 用のnetinst ISOイメージ
6.2.3. i386 及び amd64 用 BD ISO イメージ
6.2.4. ダウンロードしたイメージの検証
6.2.5. ソース
6.3. メールによる CD / DVD のリクエスト
6.4. Debian Edu のインストール
6.4.1. 主サーバーのインストールの場合
6.4.2. デスクトップ環境の選択肢
6.4.3. インストールにおけるモジュラー構成
6.4.4. インストール方法と選択肢
6.4.5. インストールの手順
6.4.6. いくつかの注意事項
6.4.7. CD / Blu-ray ディスクの代わりにUSBフラッシュドライブを利用したインストール
6.4.8. ネットワーク (PXE) 越しのインストールとディスクレスクライアントのブート
6.4.9. 独自イメージ
6.5. スクリーンショットツアー
7. さあ始めよう
7.1. 開始までの最小手順
7.1.1. 主サーバーで動作するサービス
7.2. GOsa² の紹介
7.2.1. GOsa² のログインと概観
7.3. GOsa² によるユーザー管理
7.3.1. ユーザーの追加
7.3.2. ユーザの検索、変更、削除
7.3.3. パスワード設定
7.3.4. 高度なユーザ管理
7.4. GOsa² によるグループ管理
7.4.1. コマンドラインによるグループ管理
7.5. GOsa² によるマシン管理
7.5.1. マシンの検索、削除
7.5.2. 既存マシンの変更 / ネットグループの管理
8. プリンタ管理
8.1. ワークステーションに接続されたプリンターの利用方法
9. 時刻の同期
10. パーティション全体の拡張
11. 保守
11.1. ソフトウェアの更新
11.1.1. セキュリティ更新に関する通知を受け取り続ける
11.2. バックアップ管理
11.3. サーバ監視
11.3.1. Munin
11.3.2. Icinga
11.3.3. Sitesummary
11.4. Debian Edu の独自化に関するさらなる情報
12. アップグレード
12.1. アップグレードに関する一般的な注意
12.2. Debian Edu Stretch からアップグレードする場合
12.2.1. 主サーバーをアップグレードします
12.2.2. ワークステーションのアップグレード
12.2.3. LTSP chroot 環境のアップグレード
12.2.4. LTSP chroot 環境の再生成
12.2.5. 64ビットPCクライアント用のLTSP chroot環境の追加方法
12.3. Debian Edu / Skolelinux の(Stretch より古い)旧バージョン からのアップグレード
13. HowTo
14. 管理一般 HowTo
14.1. 設定履歴: バージョン管理システム git を使って /etc/ を追跡
14.1.1. 使用例
14.2. パーティションのサイズ変更
14.2.1. 論理ボリューム管理
14.3. GOsa² を利用するための主サーバーへのグラフィカル環境のインストール
14.4. ldapvi の利用
14.5. Kerberos対応NFS
14.5.1. 実際の手順
14.6. Standardskriver
14.7. LDAP GUI JXplorer
14.8. コマンドラインツール ldap-createuser-krb
14.9. stable-updates の利用
14.10. backports を利用した、より新しいソフトウェアのインストール
14.11. CDや類似イメージからのアップグレード
14.12. 自動での残存プロセスの掃除
14.13. セキュリティ更新の自動インストール
14.14. 夜間自動マシンシャットダウン
14.14.1. shutdown-at-night の設定方法
14.15. ファイアウォールの先に置かれている Debian-Edu サーバへのアクセス
14.16. サービスマシンの追加による主サーバーの負荷分散
14.17. wiki.debian.org の HowTo
15. 高度な管理 HowTo
15.1. GOsa² によるユーザの独自設定
15.1.1. 年次グループ内のユーザ作成
15.2. その他のユーザ独自設定
15.2.1. 全ユーザのホームディレクトリ内へのディレクトリ作成
15.2.2. USBメモリやCD、DVDへの簡単アクセス
15.3. ストレージ専用サーバの利用
15.4. SSHログインアクセスの制限
15.4.1. LTSP クライアント無しでの準備
15.4.2. LTSP クライアントの準備
15.4.3. 更に複雑な場合のセットアップでの注意点
16. デスクトップ HowTo
16.1. 多国語対応デスクトップ環境のセットアップ
16.2. DVDの再生
16.3. 手書きフォント
17. ネットワーククライアント HowTo
17.1. シンクライアント及びディスクレスワークステーションについて
17.1.1. LTSP クライアントの種類の選択
17.2. PXEメニューの設定
17.2.1. PXEインストールの設定
17.2.2. PXEインストール用独自リポジトリの追加
17.2.3. (主サーバーと LTSP サーバーの) 複合サーバーのPXEメニュー変更
17.2.4. 主サーバーと LTSP サーバーの分離
17.2.5. 異なる LTSP クライアントネットワークの利用
17.2.6. 32ビットクライアント向けのLTSP chroot 環境の追加方法
17.3. ネットワーク設定の変更
17.4. LTSP の詳細
17.4.1. LDAP (及び lts.conf) での LTSP クライアントの設定
17.4.2. 全てのLTSPクライアントのデスクトップ環境を LXDE を強制する方法
17.4.3. Desktop autoloader
17.4.4. LTSP サーバ群の負荷分散
17.4.5. LTSP クライアントのオーディオ
17.4.6. LTSP クライアントに接続されたプリンターの利用
17.4.7. NBDの代わりにNFSを使う方法
17.4.8. LTSP 環境のアップグレード
17.4.9. ログイン遅延とセキュリティ
17.5. ネットワークへの Windows マシンの接続 / Windows との統合
17.5.1. ドメインへの参加
17.6. リモートデスクトップ
17.6.1. Xrdp
17.6.2. X2Go
17.6.3. 利用できるリモートデスクトップクライアント
18. Debian Edu の Samba
18.1. さあ始めよう
18.1.1. ファイルへの Samba 経由のアクセス
18.2. ドメインメンバー権
18.2.1. Windows のホスト名
18.3. ドメインへの最初のログオン
19. クラスルーム HowTo
19.1. プログラミングを教える
19.2. 生徒の監視
19.3. 生徒のネットワークアクセスの制限
20. ユーザ向け HowTo
20.1. パスワード変更
20.2. Java
20.2.1. 単体 Java アプリケーションの実行
20.3. メールの利用
20.3.1. Thunderbird
20.3.2. ディスクレスワークステーションでメールを読むための Kerberos 資格情報の取得
20.4. 音量調整
21. 貢献
21.1. 地域での貢献
21.2. 国際的な貢献
21.3. 文書の著者及び翻訳者
22. サポート
22.1. ボランティアベースのサポート
22.1.1. 英語
22.1.2. ノルウェー語
22.1.3. ドイツ語
22.1.4. フランス語
22.2. 商業的なプロのサポート
23. Debian Edu Buster の新機能
23.1. Debian Edu 10+edu0 コード名 Buster の新機能
23.1.1. インストールの変更
23.1.2. ソフトウェアの更新
23.1.3. 文書や翻訳の更新
23.1.4. 前のリリースからの他の変更点
23.1.5. 既知の問題
24. 著作権と著者
25. 翻訳の著作権と著者
26. この文書の翻訳
26.1. この文書の翻訳方法
26.1.1. POファイルを使った翻訳
26.1.2. ウェブブラウザを使ったオンラインでの翻訳
27. 付録A - GNU General Public License
27.1. Debian Edu 10+edu0 コード名 Buster のマニュアル
27.2. GNU GENERAL PUBLIC LICENSE
27.3. TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION
28. 付録B - Buster の Debian Edu Live CD/DVD (まだありません)
28.1. 「スタンドアロン」 イメージに収録されている機能
28.2. Workstation イメージに収録されている機能
28.3. 翻訳や地域サポートの有効化
28.4. 知っておくべき事柄
28.5. イメージの既知の問題
28.6. ダウンロード
29. 付録 C- 過去のリリースの機能について
29.1. 2017年6月17日にリリースされた Debian Edu 9+edu0 Stretch の新機能
29.1.1. インストールの変更
29.1.2. ソフトウェアの更新
29.1.3. 文書や翻訳の更新
29.1.4. 前のリリースからの他の変更点
29.2. 2016年7月2日にリリースされた Debian Edu 8+edu0 コード名 Jessie の新機能
29.2.1. インストールの変更
29.2.2. ソフトウェアの更新
29.2.3. 文書や翻訳の更新
29.2.4. 前のリリースからの他の変更点
29.3. 2013年9月28日にリリースされた Debian Edu 7.1+edu0 コード名 Wheezy の新機能
29.3.1. ユーザから見える変更点
29.3.2. インストールの変更
29.3.3. ソフトウェアの更新
29.3.4. 文書や翻訳の更新
29.3.5. LDAP 関連の変更点
29.3.6. 他の変更点
29.3.7. 既知の問題
29.4. 更に古いリリースについての情報
29.4.1. もっと古いリリースについてのさらなる情報

1. Debian Edu 10+edu0 コード名 Buster のマニュアル

Debian Edu のログイン画面

このマニュアルは Debian Edu Buster 10+edu0 リリース用です。

http://wiki.debian.org/DebianEdu/Documentation/Buster の wikiで、バージョンは頻繁に更新されています。

翻訳debian-edu-doc パッケージの一部で、ウェブサーバーにもインストールできますし、インターネット上でもご利用になれます。

2. Debian Edu と Skolelinux について

Debian Edu 別名 Skolelinux は Debian ベースの Linux ディストリビューションで、徹底的に学校ネットワーク向けに設定された、そのまま使える環境を提供します。

基本的な環境構成の情報は全体の構成の章と、 ハードウェア要件の章とネットワーク設定の要件の章にあります。

学校サーバーのインストールが完了すれば、学校ネットワークに必要となるサービスは全て準備され、システムは利用可能になっています。 必要なことは、ユーザーやマシンを追加することだけです。操作は快適なウェブUIである GOsa² で可能ですし、その他の LDAP エディタで設定することもできます。 PXE を利用するネットワークブート環境も、既に準備できています。一度CDや Blu-ray ディスク、あるいはUSBフラッシュドライブから主サーバーの初期インストールが完了した後は、他のマシンは全てネットワーク経由でインストールできるのです。これには「ローミングワークステーション」(通常ノートPCやネットブックで、学校ネットワークから切り離しても使えるもの) や、従来のシンクライアント等のディスクレスマシン向けの PXE ブート機能等も含みます。

GeoGebra、Kalzium、KGeography、GNU SolfegeやScratchなどの教育向けアプリケーションはデスクトップに初期設定で収録されています。Debianでは他にも多数の教育向けアプリケーションが ご利用いただけます。

2.1. 簡単な歴史と名前が2つある理由

Skolelinux は Debian Edu プロジェクトによって作成された Linux ディストリビューションです。Debian Pure Blends ディストリビューションの一つであり、公式の Debian サブプロジェクトです。

Debian Edu / Skolelinux は徹底的に学校用ネットワーク向けに設定された環境を簡単に提供する Debian ブランドなのです。

経緯として、2001年7月2日にノルウェーで Skolelinux プロジェクトが創設され、同時期に Raphaël Hertzog さんがフランスで Debian-Edu を始めました。2003年に2つのプロジェクトは名前を残した形で統合しました。「Skole」も 「(Debian-) Education」もそれぞれの地域でわかりやすい語だったからです。

ノルウェーで最初に主な対象とした団体は 6〜16 歳の年齢層を扱う学校でした。現在このシステムは世界各国で利用されていますが、導入されているほとんどはノルウェー、スペイン、ドイツ、そしてフランスです。

3. 全体の構成

この節では Skolelinux の全体像や提供するネットワーク構成とサービスについて説明します。

3.1. ネットワーク構成

Debian Edu のネットワーク接続形態

図はネットワーク接続形態の例です。 Debian Edu / Skolelinux のデフォルトでは、ネットワークに通常のワークステーションや LTSP サーバー (それと関係するシンクライアントやディスクレスワークステーション) は複数想定されています。 ただし「主サーバーは一つだけ」です。 ワークステーションの数はお好みで設定できます (無くてもいいですし、多数でも大丈夫です)。 LTSP サーバーについても同様で、それぞれが別のネットワークを構成するため、クライアントと LTSP サーバーの間の通信が他のネットワークサービスに悪影響を及ぼすことはありません。LTSPの詳細は別の章のHowToをご覧ください。

主サーバーが学校ネットワークごとに1台だけというのは、主サーバーが DHCP を提供するという技術的な理由です(ネットワーク中に1台のマシンだけが可能です)。 サービスを主サーバーから他のマシンに移動させることは可能です。別のマシンでサービスを提供させた上で、そのサービスがそのコンピューターにあることを示す DNS エイリアスを設定することで実現できます。

Skolelinuxの標準設定では、構成を単純で分かりやすくするために、インターネットとの通信は「ゲートウェイ」と呼ばれる独立したルーターを経由します。 インターネットルーターの章で「ゲートウェイ」の構築方法やお手持ちのものを流用できるかを解説しています。

3.1.1. デフォルトのネットワーク設定

主サーバーの DHCP は 10.0.0.0/8 ネットワークを提供し、PXE ブートによる 新しいサーバーやワークステーションのインストール、シンクライアントやディスクレスワークステーションの起動、memtest の実行、ローカルハードディスクからのブート等を選択できるようになっています。

ただしこれらは個別対応のために修正されることが前提です。詳細は 関連するHOWTO をご覧になってください。

LTSP サーバーの DHCPは、2つの専用ネットワーク (192.168.0.0/24 と 192.168.1.0/24 が初期設定です) だけを対象とします。これを変更する必要は滅多にありません。

サブネットの設定は全て LDAP に格納されます。

3.1.2. 主サーバー (tjener)

Skolelinux ネットワークには主サーバー (「tjener」とも呼ばれますがこれはノルウェー語で「サーバー」という意味です) が1台必要です。デフォルトでIPアドレス 10.0.2.2 を割り当てられ、「主サーバー」のプロファイルを選択することでインストールされます。「主サーバー」のプロファイルに加えて 「LTSP サーバー」 や「ワークステーション」のプロファイルを選択してインストールすることも可能です (必須ではありません)。

3.1.3. 主サーバーで動作するサービス

シンクライアントの制御を例外として、初期設定ではサービスは全て主サーバーに設定されます。 性能の低下を防ぐため、 LTSP サーバーは複数あるべきです (同一のマシンに「主サーバー」と「 LTSP サーバー」のプロファイルを両方インストールすることは可能です)。 専用の DNS 名が全サービスに割り当てられますが、IPv4 だけで提供されます。DNS 名を割り当てられているので、個々のサービスを主サーバーから異なるマシンに移動するのは簡単です。単純に主サーバーのサービスを止めて、そのサービスを提供する新しいマシンを参照するように DNSの 設定を変更するだけです (もちろん最初にそのサービス用のマシンを準備しないといけません)。

セキュリティ確保のため、ネットワークでパスワードを送る接続は全て暗号化されています。平文のままのパスワードがネットワークに送られることはありません。

以下は Skolelinux ネットワークにデフォルトで用意されるサービスと、それぞれの DNS 名を示した表です。設定ファイルでは可能な限りサービスを全てDNS名 (ドメイン名は含めません) で参照しているため、学校で利用しているドメイン名 (DNS のドメインを独自に持っている場合) やIPアドレスを変更するのは容易です。

サービスの一覧

サービスの説明

技術名称やパッケージ名

DNS サービス名

中央ログ収集

rsyslog

syslog

ドメイン名サービス

DNS (BIND)

domain

自動ネットワーク設定機能

DHCP

bootps

時刻の同期

NTP

ntp

ネットワーク経由のホームディレクトリ提供

SMB / NFS

homes

電子メール

IMAP (Dovecot)

postoffice

ディレクトリサービス

OpenLDAP

ldap

ユーザーの管理

GOsa²

---

ウェブサーバー

Apache/PHP

www

中央バックアップ

sl-backup, slbackup-php

backup

ウェブキャッシュ

プロキシ (Squid)

webcache

印刷

CUPS

ipp

安全なリモートログイン

OpenSSH

ssh

自動設定

CFEngine

cfengine

LTSP サーバー

LTSP

ltsp

NBD (ネットワークブロックデバイス) サーバー

NBD

---

マシン及びサービスの監視、エラー報告や状態の確認、履歴のウェブでの確認、電子メールでのエラー報告

Munin、Icinga、Sitesummary

sitesummary

各ユーザーのファイルはサーバー上のそれぞれのホームディレクトリに保存されます。ホームディレクトリにはどのマシンからもアクセス可能です。ユーザーはどのマシンからでも同一のファイルにアクセスできます。サーバーはオペレーティングシステムについても柔軟です。Unix クライアント向けには NFS、Windows 及び Macintosh クライアント向けには SMB を経由したアクセスを提供します。

メールはデフォルトでローカル配送 (つまり学校内) だけが使えるように設定されます。学校に専用のインターネット回線がある場合には、インターネットへメールを送信することも可能です。クライアントのメールは (「スマートホスト」を使って) サーバーに送信される設定になり、ユーザーは IMAP 経由で個人のメールにアクセスできます。

中央ユーザーデータベースで認証及び承認を行うため、どのサービスにも同一のユーザ名とパスワードを使ってアクセスできます。

校内からのアクセスが多いウェブサイトへのアクセス速度の改善とトラフィック集中の回避のため、ウェブプロキシサーバー (Squid) を利用します。ルーターでのウェブ関連の通信ブロックと組み合わせれば、マシン個別にインターネットアクセスを管理できます。

クライアントのネットワーク設定は DHCP を使って自動的に行われます。通常のクライアントは全てプライベート用のサブネット 10.0.0.0/8 に接続され、それに応じたIPアドレスが割り当てられます。一方でシンクライアントは、担当する LTSP サーバーに別のサブネット 192.168.0.0/24 を経由して接続します (このためLTSP クライアントのネットワーク通信が他のネットワークサービスに悪影響を与えることはありません)。

中央ログ収集機能が設定され、全てのマシンは各々の syslog メッセージをログサーバーに送るように設定されます。syslog サービスはローカルネットワーク内部から来るメッセージだけを受け付けるように設定されています。

DNS サーバーのデフォルトは、実際の 外部DNS ドメインが用意されるまでは、学校ネットワーク内部でのみ利用するドメイン「*.intern」 を用意します。DNS サーバーはキャッシュ機能も設定されるため、性能面を気にせずネットワーク上の全マシンでメインの DNS サーバーとして利用できます。

生徒や教員はウェブサイトを公開できます。ユーザー認証機能や、ページやサブディレクトリへのアクセスを特定のユーザーやグループに制限する機能は、ウェブサーバーが提供します。サーバーサイドプログラミング機能もあるため、ユーザーは動的なウェブページも作成できます。

ユーザーやマシンの情報は中央管理で一括変更でき、自動的にネットワーク上の全コンピュータに反映されます。これには中央ディレクトリサーバーが用いられます。ディレクトリはユーザーやユーザーグループ、マシン、マシングループの情報を持つことになります。ユーザーの混乱を避けるため、ファイルグループ、メーリングリスト、ネットワークグループに違いは全くありません。ネットワークグループを構成するマシン群はユーザーグループやメーリングリストと同一の名前空間を利用するということです。

サービスやユーザーの管理は主にウェブ経由で、標準的な手順に沿って行います。Skolelinux に収録されているウェブブラウザでも実行できます。管理システムから特定のタスクについて、個々のユーザーやユーザグループに権限委譲することもできるようになっています。

NFS に特有の問題を回避するのためと、問題発生時の解決を容易にするため、複数のマシンでの時刻同期が必要になります。 Skolelinux サーバーはローカルの Network Time Protocol (NTP) サーバーとして設定されるので、全てのワークステーションやクライアントはサーバーと時刻同期します。ネットワーク全体での正確な同期時刻を確保するため、サーバー自体もインターネットからNTP経由で時刻を同期するようにしてください。

プリンターは都合のいい場所でメインのネットワークに直接接続するか、ネットワーク内のサーバー、ワークステーション、あるいはLTSP サーバーに接続します。プリンターへのアクセスは個々のユーザーの所属グループ毎に制御できます。これはプリンターに対するクォータ設定とアクセス制御で実装しています。

3.1.4. LTSP サーバー

1つの Skolelinux ネットワークに多数の LTSP サーバー (Stretch以前はシンクライアントサーバと呼んでいました) を配置できます。「LTSP サーバー」のプロファイルを用いてインストールできます。

LTSP サーバーは syslog をシンクライアントやワークステーションから受け取り、中央ログ収集サーバーに送るように設定されます。

注意:

  • シンクライアントは、サーバーにあるプログラムだけで構成されます。

  • ディスクレスワークステーションは、サーバーのLTSP chroot 環境にあるプログラムだけで構成されます。

  • LTSPクライアントには軽量なデスクトップ環境を使うべきです。インストール時に設定できます。詳細は インストールの章をご覧になってください。

  • LTSPクライアントのルートファイルシステムは、NBD(Network Block Device)で構成されます。LTSP chroot 環境を変更した後には、関連する NBD イメージも生成し直さないといけません。その場合にはLTSP サーバーで ltsp-update-image を実行してください。

3.1.5. シンクライアント

シンクライアントの設定を用いると、普通のPCを(X-)端末として機能させることもできます。つまり、マシンはローカルのハードドライブを利用せず、PXE を使ってサーバーから直接ブートします。シンクライアント機能の実装には Linux ターミナルサーバープロジェクト (LTSP) を用いています。

シンクライアントを用いると非力なマシンも活用できます。プログラムは全て LTSP サーバーで効率的に実行されるためです。仕組みは次のようになっています。まずDHCP と TFTP を使ってネットワークを構築し、シンクライアントはネットワーク経由で起動します。次に LTSP サーバーのNBDを使ってファイルシステムがマウントされます。最後に X ウィンドウシステムが起動します。ディスプレイマネージャ (LDM) はSSHのX転送機能を使って LTSP サーバーに接続します。ネットワーク上のデータはすべて暗号化されています。

3.1.6. ディスクレスワークステーション

ディスクレスワークステーションについては「ステートレスワークステーション」等、他の用語も利用されています。このマニュアルでは明確にするため「ディスクレスワークステーション」とします。

ディスクレスワークステーションではソフトウェアは全て、PCそれぞれにインストールされたオペレーティングシステムを使わずに動作します。つまりクライアントマシンはサーバーのハードドライブによって直接起動してます。クライアントマシンのハードドライブにインストールされたソフトウェアを利用することはありません。

ディスクレスワークステーションは少々古い程度の比較的高性能なハードウェアを、シンクライアント並に低い保守コストで活用できる優れた手段です。ソフトウェアの保守管理はサーバーで行われます。クライアントでローカルにインストールしたソフトウェアを保守する必要はありません。ホームディレクトリやシステム設定もサーバーに保管されます。

3.1.7. ネットワーククライアント

このマニュアルでは「ネットワーククライアント」という用語はシンクライアントとディスクレスワークステーションの両方と、 Mac OS や Windows を実行しているコンピュータを意味します。

3.2. 管理

Skolelinux インストーラによりインストールされる Linux マシンはすべて、中央コンピュータ、ほとんどの場合は主サーバーから管理できます。SSH を経由して全マシンへのログインでき、すべてのマシンへの完全なアクセスが可能です。ただしroot権限を得るにはkinitを実行してKerberos TGTを得る必要があります。

ユーザー情報は全て LDAP ディレクトリに保管されます。ユーザーアカウントの更新はこのデータベースに対して行われ、クライアントのユーザー認証にもこれが利用されます。

3.2.1. インストール

インストール用メディアのイメージは現在 netinstイメージ とBDイメージの2種類があります。どちらのイメージも USB メモリなどからでも起動できます。

任意のメディアからサーバーを一旦インストールしてしまえば、他のクライアントは全てネットワークからブートし、ネットワーク経由でインストールできるようにするのが狙いです。

netinst イメージはインストール時にインターネットへのアクセスが必要です。

インストール過程での質問事項はあまりありません。目的の言語 (例えば日本語や英語) 、マシンのプロファイル (「主サーバー」、「ワークステーション」、「LTSP サーバー」等)程度です。ほとんどの設定は全て自動的に設定され、インストール後にシステム管理者により中央から変更することになります。

3.2.2. ファイルシステムのアクセス設定

Skolelinux のユーザーアカウントには、ファイルサーバー上のファイルシステムが割り当てられます。それ (ホームディレクトリ) にはユーザーの設定ファイルや文書、メール、ウェブページが保存されます。システム上の他のユーザーも読むことができるファイル、インターネットの誰からでも読み取れるファイル、そのユーザー以外の誰からも読み取れないファイルなど、アクセス権限は設定管理してください。

ユーザーディレクトリや共有ディレクトリに利用する全てのディスクに関して、インストールしたシステムの全コンピューターの間で一意の固有名でアクセスできるようにするため、/skole/ホスト/ディレクトリ/ としてマウントする方法があります。初期状態では、ディレクトリ/skole/tjener/home0/ 1つだけがファイルサーバーに作成され、ユーザーアカウントは全てそこに作成されます。特定のユーザーグループや使い方によって、必要に応じてディレクトリを追加することもできます。

通常の UNIX 権限を利用してファイルへの共有アクセスができるようにするためには、ユーザーはそれぞれ個人がデフォルトで属する基本グループに加えて、追加で共有グループ (例えば "students" グループ) にも属する必要があります。新しく作成される項目をユーザーのグループからもアクセスできるように、適切な umask (002 や 007) を設定し、作業ディレクトリが setgid されていてファイルが正しいグループ権限を引き継ぐようになっていれば、グループメンバー間での制御されたファイル共有ができます。

新しく作成されたファイルの初期アクセス設定はポリシーの問題です。Debian のデフォルト umask は 022 (上記で説明したようにグループからのアクセスを許可しない) ですが Debian Edu では 002 をデフォルトとしています - これはファイルは誰からも読み取れる状態で作成され、後からユーザが介入して操作すれば削除できるということです。代わりに (/etc/pam.d/common-session を編集することで) umask を 007 に変更する方法もあります - これは読み取りアクセスをまずブロックしておき、必要な場合にはユーザによる操作で読み取れるようにするという方法です。前者は知識の共有を奨励し、システムをより透過的にするのに対し、後者の方法では望まない秘密情報読み取りの危険を減らします。前者の問題は自分が作成したものが他のあらゆるユーザからアクセスできるということがユーザにとって明確ではない点です。他のユーザのディレクトリを調べて他人のファイルを自分が読み取れるということからしかそれに気づけないかもしれません。後者の問題は秘密情報の有無を問わず自分のファイルをアクセスできるようにする人はほとんどいないことで、特定の問題 (主に設定の問題) を他の人がどのように解決しているのか調べようとするような詮索好きなユーザにしかその内容が役に立たない点です。

4. 要件

Skolelinux という解法には準備の方法がいくつもあります。単一のPCだけにインストールすることも、地域にあるいくつもの学校を中央から運営するようにもできます。この柔軟性から、ネットワーク構成要素やサーバ、クライアントマシンの設定は大きく変わります。

4.1. ハードウェア要件

様々なプロファイルの目的についてはネットワーク構成の章で説明しています。

/!\ LTSP を利用するつもりであれば LTSP ハードウェア要件の wiki ページに目を通してください。

  • Debian Edu / Skolelinux を実行するコンピュータとして、32ビット時代の古いプロセッサーを搭載しているものか (Debian アーキテクチャー名は「i386」で、686 クラスまでのプロセッサです)、 または最近の64ビット対応 x86 プロセッサー (Debian アーキテクチャー名は「amd64」)が必要になります。

  • 「主サーバー」や「 LTSP サーバー」プロファイルを利用するマシンでは、RAM容量の目安としてはシンクライアント30台で最低 12GiB、50-60台では最低 20 GiB を推奨します。

  • シンクライアントには 、端的にはRAM が 256 MiBある400MHz程度のプロセッサー でも動作しますが、多くのRAMとより高速なプロセッサーを搭載したマシンを推奨します。

    • LTSP クライアントではネットワーク越しのswapが自動的に有効化されています。swap容量は 512 MiBになっていますが、必要に応じて主サーバーの /etc/ltsp/nbdswapd.conf の SIZE 変数で調整できます。

    • ディスクレスワークステーションにハードドライブがある場合、ネットワーク経由のswapよりもかなり高速であるため、swapにはそれを利用することを勧めます。

  • ワークステーション、ディスクレスワークステーション、単独システムのマシンには、1500MHz以上で動作するCPUと、1025MBのRAMが絶対的な最低限度の要件となります。最近のウェブブラウザや LibreOffice を使う場合には、2048MB以上のRAMを推奨します。

    • RAM容量の少ないワークステーションでswap容量不足していると、スペルチェック機能が 原因でLibreOffice が動作停止することがあります。頻繁に動作が停止する場合は、システム管理者はスペルチェック機能を無効化することも検討してください。

  • 要求される最小ディスク容量はインストールするプロファイルにより異なります:

    • 「主サーバー」 +「 LTSP サーバー」の複合プロファイルの場合: 70GiB (更にユーザーアカウント用の容量が必要です)。

    • 「LTSP サーバ」プロファイル: 50GiBは必要です。

    • 「ワークステーション」や「スタンドアロン」プロファイル: 30 GiBは必要です。

  • デフォルトのネットワーク構成で利用する場合、LTSP サーバーにはネットワークカードが2つ必要です:

    • eth0 は中心ネットワーク (10.0.0.0/8) に接続し、

    • eth1 は LTSP クライアント側用です (デフォルトは 192.168.0.0/24)。変更は可能です)。

  • ノートPCはモバイルワークステーションなので、要件は「ワークステーション」プロファイルと同一です。

4.2. 動作確認済みのハードウェア

テスト済みハードウェアの一覧を http://wiki.debian.org/DebianEdu/Hardware/ で提供してはいますが、完全ではありません。 :)

http://wiki.debian.org/InstallingDebianOn は Debian を特殊なハードウェアにインストール、設定、利用する方法を記録した成果です。そういったハードウェアの導入を考えている人がサポート状況を確認したり、既に所有しているハードウェアを最大限活用する方法を探すことに利用できます。

Debian でサポートされているハードウェアの優れたデータベースとして http://kmuto.jp/debian/hcl/ があります。

5. ネットワーク設定の要件

5.1. デフォルト設定

デフォルトのネットワーク構成で利用する場合は以下のようになります。

  • 主サーバ ー、tjener が1つだけ必要です。

  • ワークステーションは中心ネットワークに数百台も配置可能です。

  • 中心ネットワークには多数の LTSP サーバーも配置できます。LDAP では2つ (DNS、DHCP)のサブネットが事前設定されていますが、更に追加することもできます。

  • シンクライアントやディスクレスワークステーションは、各 LTSP サーバーのネットワークに数百台は配置可能です。

  • その他のマシンも、動的IPアドレスの割り当てになりますが、数百台配置可能です。

  • インターネットへのアクセスにはルーターやゲートウェイが必要です(以下参照)。

5.2. インターネットルーター

インターネットへの接続には、外部インターフェイスがインターネットに接続していて、内部インターフェイスにIPアドレス 10.0.0.1、ネットマスク netmask 255.0.0.0 を設定できるルーターかゲートウェイが必要です。

ルーターで DHCP サーバーを動作させるべきではありません。DNSサーバーを動作させることはできますが、その必要はなく、また利用もされません。

ルーターはあるけれども、必要な設定ができない (権限を持っていないとか、技術的な理由等)場合には、ネットワークインターフェイスを2つ備えたシステムに Debian Edu の「最小 (Minimal)」プロファイルをインストールして「ゲートウェイ」にできます。

端的にはDebian Eduインストール中に「最小」プロファイルを選ぶだけです。

インストール後の操作例:

  • /etc/network/interfaces を調整します。

  • ホスト名は "gateway" に固定します。

  • 10.0.0.0/8 向けのIP転送とNATを有効にします。

  • オプションでファイアウォールやトラフィック調整ツールをインストールしてもよいです。

 #!/bin/sh
 # プロファイル「最小 (Minimal)」のシステムをゲートウェイ/ファイアウォールにするスクリプト例
 #
 sed -i 's/auto eth0/auto eth0 eth1/' /etc/network/interfaces
 sed -i '/eth1/ s/dhcp/static/' /etc/network/interfaces
 echo 'address 10.0.0.1' >> /etc/network/interfaces
 echo 'netmask 255.0.0.0' >> /etc/network/interfaces
 hostname -b gateway
 hostname > /etc/hostname 
 service networking stop
 service networking start
 sed -i 's#NAT=#NAT="10.0.0.0/8"#' /etc/default/enable-nat 
 service enable-nat restart
 # ファイアウォール (shorewall や ufw) やトラフィック調整
 # ツールをインストールするのもいいかもしれません。
 #apt update
 #apt install shorewall
 # または
 #apt install ufw
 #apt install wondershaper  

ルーターやアクセスポイントのファームウェアを別のものに変更したい場合は、 OpenWRT を勧めますが、もちろん元のファームウェアも利用できます。元のファームウェアを利用する方が簡単です。OpenWRT を使うことで選択や制御の幅が広がります。OpenWRT のウェブページ、サポートされているハードウェアで一覧を確認してください。

異なるネットワーク設定も可能ではあります (手順はChange subnet in Debian Edu / SkolelinuxのWikiにあります)。ただ、貴校の既存のネットワーク構成の都合でやらざるを得ないのでなければ、異なる設定にするよりもデフォルトのネットワーク構成にしておくことを勧めます。

6. インストールとダウンロードの選択肢

6.1. 追加情報のありか

実際に運用環境のシステムをインストールを始める前に 、Debian Busterリリースノートを、まずはご一読ください。Debian Busterに関する詳細な情報は Busterのインストールマニュアルをご覧になってください。

ぜひDebian Edu/Skolelinuxをご検討ください。お役に立ちます。 :-)

中央サーバーのインストールを始める前に、まずはハードウェアとネットワークの要件と、全体的な構成についての章をご一読ください。

/!\ このマニュアルのさあ始めようの章も必ず読んでください。初めてのログインについて説明しています。

6.2. Debian Edu 10+edu0 コード名 Buster 用インストールメディアのダウンロード

/!\ Buster自体はまだ開発途上にあります。正式リリースになっているかは https://wiki.debian.org/DebianEdu/Status/Buster でご確認いただけます。

6.2.1. amd64もしくはi386

amd64i386のどちらもDebianのx86 CPUのアーキテクチャ名で、AMDやIntelなどが開発してきたものです。 amd64は64ビットアーキテクチャで、i386は32ビットアーキテクチャとなります。新規にご利用の場合はamd64を前提にしてください。 i386は古いコンピューターのご利用にのみ用いてください。

6.2.2. i386 及び amd64 用のnetinst ISOイメージ

netinst ISOイメージは i386 とamd64 のマシンへのインストールのどちらにも対応します。CDやDVD、USB フラッシュドライブからのインストールにも利用できます。netinstイメージを用いる場合、インストールにはインターネットへのアクセスが必要です。

Busterのリリースイメージは以下からダウンロードできます。

6.2.3. i386 及び amd64 用 BD ISO イメージ

この ISO イメージは 約5GBもありますが、 インターネットへの接続無しにamd64 や i386 マシンへのインストールが可能です。netinstイメージと同様に十分なサイズの USB フラッシュドライブやディスクメディアで使えます。

Busterのリリースイメージは以下からダウンロードできます。

6.2.4. ダウンロードしたイメージの検証

イメージ検証の詳細な手順については、Debian-CD FAQをご覧になってください。

6.2.5. ソース

ソースコードは通常のDebianアーカイブと同様に様々な方法で入手できます。http://get.debian.org/cdimage/release/current/source/

6.3. メールによる CD / DVD のリクエスト

インターネット接続が低速な場合のため、専用のCDやDVDをメディア料金と配達料金で提供しています。まずはEメールでcd@skolelinux.noにご連絡ください。提供メディアの料金や配達料金の見積もりなどを致します。 :) CD や DVD の送り先を忘れずにメールに含めるようにしてください。

6.4. Debian Edu のインストール

Debian Edu のインストールを行う際には、いくつか選択すべきことがあります。それほど多くはありませんので安心してください。インストールでの複雑な過程は、大幅に簡素化できています。それでも Debian Edu は Debian であり、お望みなら 57,000 超のパッケージもご利用できますし、設定オプションの組み合わせとなれば億を超えることになります。大多数のユーザーにとってはデフォルトが適しています。ただしLTSPをご検討される場合は、軽量なデスクトップ環境を選んでください。

6.4.1. 主サーバーのインストールの場合

  1. ルーターのDHCP機能を利用した、一般的な学校やご家庭でのインターネットアクセス:

    • 主サーバーのインストールは可能ですが、再起動した後はインターネットアクセスがありません(主ネットワークのIPアドレスが10.0.2.2/8になるためです)。

    • お手持ちのルーターをゲートウェイとして設定できない場合は別の方法がありますので、インターネットルーターの章をご覧ください。

    • すべての機材はネットワーク構成の章で説明しているように接続してください。

    • 主サーバーは一度正しい手順で設定して起動した後は、インターネットと接続されています。

  2. 典型的な学校や組織のネットワークで、上の例に似ているもののプロキシサーバーが必要な場合。

    • カーネルコマンドラインで'debian-edu-expert'を加えることになります。詳細は後述します。

    • プロキシサーバー関係の質問などが追加され、必須項目になります。

  3. DHCPサーバー機能を持たないルーターでIP 10.0.0.1/8に構成されたネットワークで、インターネット接続がある場合。

    • ネットワーク設定がDHCP機能の欠落によって失敗し次第、手動でのネットワーク設定を行うことになります。

      • ホストIPには10.0.2.2/8を設定します

      • ゲートウェイIPには10.0.0.1を設定します

      • 代案がない場合は、Google Public DNSである8.8.8.8をネームサーバーのIPとして入力します

    • 以上の設定で、主サーバーは初回起動後に正常に動作するはずです。

  4. オフライン(インターネット接続がない)場合:

    • ISOイメージにはBDを利用します。

    • (実物も仮想も含めて)あらゆるネットワークケーブルが接続されていないことを確認します。

    • ネットワーク設定時のDHCPで失敗の表示が出て、「続ける」を押した後、「今はネットワークを設定しない」を選びます。

    • インターネット接続のある環境でシステムを起動した後に、システムを更新してください。

6.4.2. デスクトップ環境の選択肢

  • KDEとGNOMEは言語サポートが充実していますが、古いコンピューターやLTSPクライアントには重い構成になります。

  • MATEは上の2つよりも軽量に動作しますが、言語対応が若干不足しています。

  • LXDEは一番軽量な構成で、35ヶ国語をサポートしています。

  • LXQtは軽量なデスクトップ環境で、言語サポートはLXDE並みで、より見た目と使い勝手が向上しています(KDE同様にQtをベースにしています)。

  • XfceはややLXDEより大きな構成ですが、106カ国語と言語対応は整っています。

Debian Eduでは国際化プロジェクトとしてXfceを標準デスクトップ環境にしています。他のものに変更する場合は、次の章をご覧になってください。

6.4.3. インストールにおけるモジュラー構成

  • システムをワークステーションありでインストールした場合、教育関連のプログラムが多くインストールされます。基本的な構成でのみインストールするには、desktop=xxxxをカーネルコマンドラインから外した状態でインストールしてください。詳細は後述します。この手法を利用することで個別対応したシステムの構築や、テストインストールのスピード向上が図れます。

  • 注意:もしデスクトップ環境を後からインストールしたい場合、Debian-Eduのメタパッケージ(education-desktop-mateなど)は使わないでください。教育向けプログラムが全てインストールされてしまいます。代わりにtask-mate-desktopなどをインストールしてください。初等から高等レベルごとの教育向けのメタパッケージはeducation-preschooleducation-primaryschooleducation-secondaryschooleducation-highschoolがあり、必要に応じてインストールしていただけます。

  • Debian Eduメタパッケージの詳細は、Debian Edu packages overviewをご覧になってください。

6.4.4. インストール方法と選択肢

64ビットハードウェアでのインストーラブートメニュー

64ビットインストーラのブートメニュー

Graphical installは GTK を利用したインストーラで、マウスを利用できます。

Install ではテキストモードを使います。

Advanced options > にはもっと詳細なオプションを選択できるサブメニューがあります。

Help でインストーラの使用に関するいくらかのヒントを提供します。以下のスクリーンショットを見てください。

64ビットインストーラの Advanced options 画面 1

Back.. を選択するとメインメニューに戻ります。

Graphical expert install では全ての項目を設定でき、マウスも使えます。

Graphical rescue mode により、このインストール用メディアは緊急時用のレスキューディスクとして使えます。

Graphical automated install には preseed ファイルが必要です。

Expert install ではテキストモードで全ての項目を設定できます。

Rescue mode ではテキストモードで、このインストール用メディアを緊急時用のレスキューディスクとして使えます。

Automated install のテキストモードには preseed ファイルが必要です。

ヘルプ画面

インストーラのヘルプ画面

このヘルプ画面は自己説明的になっていて、キーボードの<F数字>キーを押すと、説明されている項目についてもっと詳細なヘルプを得られるようになっています。

インストール時のブートパラメータの追加や変更

どちらの場合もブートメニューでタブキーを押すとブートオプションを編集できるようになっています。以下のスクリーンショットは Graphical install 用のコマンドラインの例です。

コマンドラインオプションの編集

  • ネットワーク上の既存の HTTP プロキシサービスを利用すると CD からの主サーバープロファイルのインストールを高速化できます。例えば、ブートパラメーターに mirror/http/proxy=http://10.0.2.2:3128/ を追加します。

  • 既にマシンに「主サーバー」プロファイルをインストール済みの場合は、以後のインストールは PXE を経由して行うべきです。この方法では主サーバーのプロキシを自動的に利用します。

  • 標準のXfce デスクトップではなく GNOME デスクトップをインストールするには、カーネルのブートパラメータ desktop=xfce の「xfce」を「gnome」に置き換えます。

  • LXDE デスクトップをインストールするには 、desktop=lxde を使います。

  • LXQt デスクトップをインストールするには 、desktop=lxqt を使います。

  • KDE Plasma デスクトップをインストールするには 、desktop=kde を使います。

  • MATE デスクトップをインストールするには 、desktop=mate を使います。

6.4.5. インストールの手順

LTSP サーバーの利用を検討する際は、システム要件と、ネットワークカード (NIC) が2つ以上あることを必ず確認してください。

  • 言語を選択します (インストール時とインストールしたシステム)。

  • 国や地域を選択します。通常はあなたがお住みの国や地域です。

  • キーボードの種類を選択します。「国や地域」と基本的には同じですが、もし英語表示でインストールする場合でも日本語キーボードを利用する場合には"Japanese"キーボードレイアウトを選択してください。

  • 以下のリストからプロファイルを選択します:

    • 「主サーバー(Main server)」プロファイル

      • このプロファイルは学校向けの全サービスを設定済みで、そのまま使える主サーバー (tjener) です。 学校のネットワークには、主サーバーを「1台だけ」インストールする必要があります。 このプロファイルにはGUIは収録されていません。GUIが必要であれば、これに加えて「ワークステーション」か 「LTSP サーバー」のプロファイルも選択してください。

    • 「ワークステーション(Workstation)」プロファイル

      • 一般的なコンピューターと同様に、それぞれのハードドライブからブートし、ソフトウェアやデバイスは全てローカルにあるものが利用されます。異なる点は、ユーザーログインの認証が主サーバーで行われる点と、ユーザーのファイルやデスクトッププロファイルが置かれている場所も主サーバーであるという点です。

    • 「ローミングワークステーション(Roaming workstation)」プロファイル

      • ワークステーションと同じですが、認証にキャッシュされた資格情報を利用します。つまり学校ネットワーク外でも利用できます。ユーザーのファイルやプロファイルはローカルディスクに保存されます。シングルユーザー向けのノートPCでは、以前のリリースで提案していた 「ワークステーション」 や 「スタンドアロン」 ではなく、このプロファイルを選択してください。

    • 「LTSPサーバー(LTSP Server)」プロファイル

      • シンクライアント (やディスクレスワークステーション)用の サーバーで、LTSP サーバーと呼ばれます。ハードドライブを持たないクライアントはブートとソフトウェアの実行をこのサーバーから行えます。このコンピュータには2つのネットワークインターフェイス、大量のメモリ、それに理想的には複数のプロセッサまたはマルチコアCPUが必要になります。これらの詳細については、ネットワーククライアントの章を見てください。このプロファイルを選択すると (選択していなくても) 「ワークステーション」プロファイルも有効になります。LTSP サーバーはワークステーションとしても使えるということです。

    • 「スタンドアロン(Standalone)」プロファイル

      • 主サーバーが無くても利用できる、普通のコンピュータです。つまり学内ネットワークにある必要がありません。ノートPCなどが該当します。

    • 「最小(Minimal)」プロファイル

      • このプロファイルではベースとなるパッケージをインストールし、そのマシンを Debian Edu ネットワークと連携するように設定しますが、サービスやアプリケーションはインストールされません。主サーバーから単一サービスを移動する場合やゲートウェイの基盤として有用です。

    主サーバー」と「ワークステーション」と「LTSP サーバー」のプロファイルは事前選択されています。複合主サーバーとしてインストールしたい場合、この3つのプロファイルは1つのマシンにインストールできます。つまり主サーバーが LTSP サーバーでもあり、ワークステーションとしても利用できるということです。これはほとんどの場合 PXE 経由で主サーバー以降のインストールをする前提のため、デフォルトとなっています。複合主サーバーや LTSP サーバーとしてインストールする場合、インストール後に有効活用するためには、そのマシンにはネットワークカードが2つないといけないことに注意してください。

  • 自動でパーティション設定するか、「yes」か「no」で答えます。 「yes」と答えた場合はハードドライブにあるデータはすべて壊れることに注意してください! 「no」と答え、自動で設定しない場合は少々作業が必要となります。その場合は、必要なパーティションが作成されていて、かつ十分な容量があることを確認してください。

  • popularity-contest の質問のときに「yes」 と答えて頂ければ、将来のリリースにも収録すべきパッケージがどれなのかを判断するための統計情報がhttps://popcon.debian.org/に送信されます。これは必須ではありません。私たちを支援できる簡単な方法です。 :)

  • もし「LTSP サーバー」のプロファイルも選択した場合、最後の処理画面でかなりの時間がかかることになりますので、ご留意ください:「インストールを終了しています - debian-edu-profile-udeb を実行しています...」

  • root パスワードの設定の後には、「管理作業以外の用途向け」に通常のユーザアカウントを作成するかが質問されます。 Debian Edu ではこのアカウントが非常に重要です。このアカウントで Skolelinux ネットワークの管理をすることになります。

    /!\ このユーザーのパスワードは長さが最低5文字ないといけません。 短いパスワードを設定してしまった場合は、ログインが不可能になります。

  • インストール過程の概説や注意点は以上です。

6.4.6. いくつかの注意事項

6.4.6.1. ノートPCでのインストールに関する注意

ほぼ確実に「Roaming workstation」プロファイル (上記参照) を利用するのが良いでしょう。データは全てローカルに保存される (そのためバックアップに関して別途考慮が必要) こととログイン資格情報がキャッシュされる (そのためパスワードを変更してから新しいパスワードでログインしていてノート PC がネットワークに接続していない場合に古いパスワードでのログインが要求される可能性がある) ことに留意してください。

6.4.6.2. USBフラッシュドライブ / Blu-ray ディスクイメージでのインストールに関する注意

USBフラッシュドライブ / Blu-ray ディスクイメージからのインストール後の/etc/apt/sources.list には、そのイメージからの(アップデートやインストールに関する)情報しか書かれていません。インターネット接続が使える場合には、以下の行をぜひ追加してください。そうすれば適時セキュリティ更新ができるようになります:

deb http://deb.debian.org/debian/ buster main 
deb http://security.debian.org/ buster/updates main 
6.4.6.3. CDでのインストールに関する注意

netinst でのインストール (私たちのCDが提供しているインストール方法です) では一部のパッケージをCDから、残りはインターネットから取得します。インターネットから取得するパッケージの量はプロファイルによっても異なりますが、(あらゆるデスクトップをインストールするような選択をしない限り) 1GB程度でしょう。主サーバー (純粋な主サーバーか他のプロファイルを組み合わせたサーバーかは問題になりません) のインストール後はプロキシを利用するので、同一のパッケージを何度もインターネットからダウンロードするはありません。

6.4.6.4. シンクライアントだけを扱う LTSP サーバのインストールに関する注意

カーネルブートパラメータ edu-skip-ltsp-make-client を提供するとシンクライアントの chroot からシンクライアント/ディスクレスワークステーション複合の chroot への LTSP chroot の変換を飛ばせます。

これは例えば純粋なシンクライアント chroot を用意したい場合や既にディスクレス chroot が別のサーバにあって rsync できる場合等、特定の状況で有用です。そういった状況の場合はこの段階を飛ばすことでかなりのインストール時間短縮になります。

インストール時間が長くなる以外に複合 chroot を常に作成することによる害はないため、デフォルトで変換するようになっています。

6.4.7. CD / Blu-ray ディスクの代わりにUSBフラッシュドライブを利用したインストール

CD/BD .iso イメージを USB フラッシュドライブ (USB メモリ) にそのままコピーしてブートできるようになりました。以下のようなコマンドを実行します。ファイル名やデバイス名は必要に応じて調整してください:

sudo dd if=debian-edu-amd64-XXX.iso of=/dev/sdX bs=1024

デバイス名のXに関しては、USBデバイスの挿入前後に次のコマンドを実行してご確認ください。

lsblk -p

かなりの時間を要することがあります。

選択したイメージにより、USB フラッシュドライブは CD や Blu-ray ディスクのように動作します。

6.4.8. ネットワーク (PXE) 越しのインストールとディスクレスクライアントのブート

このインストール方法では動作している主サーバーが必要です。クライアントがメインネットワーク経由でブートする際、インストーラーにより新しい PXE メニューとブートオプションの選択が表示されます。XXX.bin ファイルが欠けている (XXX.bin file is missing) というエラーメッセージで PXE インストールが失敗した場合は、ほぼ確実にクライアントのネットワークカードが非フリーのファームウェアを必要としています。この場合は Debian インストーラーの initrd を変更しないといけません。その場合はサーバーで /usr/share/debian-edu-config/tools/pxe-addfirmware を実行してください。

主サーバー」プロファイルだけの場合 、PXE メニューはこんな感じになります:

width=400

主サーバー」と「LTSP サーバー」プロファイルの場合、PXE メニューはこんな感じになります:

width=400

デフォルト以外のデスクトップ環境をインストールするにはタブキーを押してカーネルブートオプションを (前述のように) 編集します。

この設定では中心ネットワークでディスクレスワークステーションやシンクライアントのブートもできます。ワークステーションとは異なり、ディスクレスワークステーションは GOsa² を利用して LDAP に追加する必要はありませんが、例えばホスト名を強制したい場合は追加することもできます。

ネットワーククライアントについてのさらなる情報がネットワーククライアント HowTo の章にあります。

6.4.8.1. PXE インストールの調整

PXE インストールでは debian-installer の preseed ファイルを利用しています。このファイルを変更することでパッケージをもっとインストールさせるようにできます。

以下のような行を追加する必要があります: tjener:/etc/debian-edu/www/debian-edu-install.dat

d-i    pkgsel/include string 追加したいパッケージ(群)

PXE インストールでは /var/lib/tftpboot/debian-edu/install.cfg/etc/debian-edu/www/debian-edu-install.dat 中の preseed ファイルを利用します。インストール中に利用する preseed を調整することで、インターネットからインストールする際の質問を回避できます。/etc/debian-edu/pxeinstall.conf/etc/debian-edu/www/debian-edu-install.dat.local で追加設定して /usr/sbin/debian-edu-pxeinstall を実行し、生成されたファイルを更新する方法もあります。

さらなる情報はDebian インストーラのマニュアルにあります。

PXE を経由したインストールでプロキシを変更あるいは無効化するには tjener:/etc/debian-edu/www/debian-edu-install.dat 中の mirror/http/proxymirror/ftp/proxypreseed/early_command を含む行を変更する必要があります。インストール時にプロキシの利用を無効化するには最初の2行の冒頭に「#」を付加し、最後の行から「export http_proxy="http://ウェブキャッシュ:3128"; 」の部分を削除します。

preseed ファイルがダウンロードされる前に必要となるために preseed できない設定があります。その設定には /var/lib/tftproot/debian-edu/install.cfg から利用できる PXElinux ベースのブート引数を利用します。こういった設定の例として言語やキーボードレイアウト、デスクトップがあります。

6.4.9. 独自イメージ

CD、DVD、Blu-ray の独自ディスク作成は、モジュール設計その他の使いやすい機能を備えた Debian インストーラを利用しているためかなり簡単かもしれません。Preseed により、通常質問される項目の回答を事前に定義できるようになります。

そのため、必要なことは preseed ファイルを作成して回答を定義 (これは Debian インストーラマニュアルの付録で説明されています) し、CD/DVD を作り直すだけです。

6.5. スクリーンショットツアー

テキストモードとグラフィカルモードのインストールは機能的には同等です - 異なるのは見た目だけです。グラフィカルモードではマウスを使う機会があり、当然見た目もはるかに良くずっと現代的になります。ハードウェアに問題があってグラフィカルモードを使えないということでもなければこちらを使わない理由はありません。

以下は「主サーバー」と「ワークステーション」 と「 LTSP サーバー」のプロファイルを、64ビットのグラフィカルモードでインストールした場合と、主サーバーの最初のブート、ワークステーションネットワーク及び LTSP クライアントネットワークでの PXE ブートのスクリーンショットです:

01-Installer_64bit_boot_menu.png

02-select_a_language.png

03-select_your_location.png

04-Configure_the_keyboard.png

05-Detect_and_mount_CD-ROM.png

06-Load_installer_components_from_CD.png

07-Detect_network_hardware.png

08-Choose_Debian_Edu_profile.png

09-Really_use_the_automatic_partitioning_tool.png

10-Really_use_the_automatic_partitioning_tool-Yes.png

11-Participate_in_the_package_usage_survey.png

12-Set_up_users_and_passwords.png

12a-Set_up_users_and_passwords.png

12b-Set_up_users_and_passwords.png

12c-Set_up_users_and_passwords.png

12d-Setting-up-the-partitioner.png

13-Install the base system.png

14-Select_and_install_software.png

17-Select_and_install_software.png

18-Build LTSP chroot.png

19-Install_the_GRUB_boot_loader_on_a_hard_disk.png

20-Finish_the_Installation.png

21-Finish_the_Installation-Installation_complete.png

22-Tjener_GRUB_boot_menu.png

主サーバーの(Lightdm) ログイン画面

Xfceでのブラウザ

Xfceデスクトップ

28-Diskless-WS-GRUB_Boot_menu-PXE.png

ディスクレスワークステーションのログイン画面

7. さあ始めよう

7.1. 開始までの最小手順

主サーバーのインストール時に「最初のユーザーアカウント」が作成されます。以下の文ではこのアカウントを「最初のユーザー」と言及します。 このアカウントは特定の名前に制限はされませんが、特別なアカウントです。 「最初のユーザー」にはSamba アカウントは作成されず (GOsa² を経由して作成できます)、ホームディレクトリ権限は 700 にセットされます (そのため個人のウェブページにアクセスできるようにするには chmod o+x ~ が必要です)。 そして「最初のユーザー」は sudo を使って root になれます。

ユーザーを追加する前に、 Debian Edu に特有の情報について ファイルシステムのアクセス設定を読んでください。運用ポリシーに応じて設定は調整してください。

インストール後に最初のユーザとしてまずやらないといけないこと:

  1. 主サーバーにログインします。

  2. GOsa² でユーザーを追加します。

  3. GOsa² でワークステーションを追加します。シンクライアントやディスクレスワークステーションはこの手順をやらなくてもそのまま使えます。

ユーザーやワークステーションの追加については以下で詳細に説明しています。この章は必ず、全て読んでください。最小限の手順を正しく行う方法や、ほとんどの場合で必要となるその他の事項についても触れています。

このマニュアルには他にも多くの情報があります。前のSteretchなどのリリースについてよくご存知の方はBusterの新機能の章をご一読ください。前のリリースからアップグレードする方はアップグレードの章を、必ず読んでください。

/!\ もしも一般的なDNS通信がブロックされているネットワークをご利用の場合には、インターネット上のホスト参照に特定のDNSサーバーを利用せざるを得ないことがあります。その場合はそのDNSサーバーに対して、このサーバーが「転送サーバー (フォワーダー)」だということを通知する必要があります。/etc/bind/named.conf.options ファイルを編集して、利用するDNSサーバーのIPアドレスを指定してください。

HowTo の章ではさらなるコツやヒント、そしてよくある質問への回答も記載しています。

Debian Edu Xfce デスクトップ

7.1.1. 主サーバーで動作するサービス

主サーバーで動作しているサービスのいくつかは、ウェブ経由でも管理できます。以下で各サービスについて説明していきます。

7.2. GOsa² の紹介

GOsa² はウェブベースの管理ツールで、Debian Edu の基幹管理が可能です。GOsa² は次の重要な項目の管理 (追加、変更、削除) ができます:

  • ユーザーの管理

  • グループ管理

  • NIS ネットグループ管理

  • マシン管理

  • DNS 管理

  • DHCP 管理

GOsa² へのアクセスには Skolelinux の主サーバーと、ウェブブラウザがインストールされた (クライアント) システムが必要です。後者については複合サーバー (「主サーバー」と「 LTSP サーバー 」と「ワークステーション」のプロファイル) としてインストールされた主サーバー自体でも可能です。 前述のどれも利用できない場合は 主サーバーで GOsa² を利用するためのグラフィカル環境のインストールを見てください。

GOsa² へのアクセスにはウェブブラウザからURL https://www/gosa にアクセスし、最初のユーザとしてログインします。

  • 新しい Debian Edu Buster マシンでは、サイトの証明書はブラウザに設定されています。

  • そうでない場合はSSL証明書が不正だというエラーメッセージが表示されます。ネットワークにあなたしかいなくて信用できる状態なら、エラーは無視してブラウザにその証明書を設定してください。

GOsa² の一般的な情報については https://oss.gonicus.de/labs/gosa/wiki/documentation をご覧ください。

7.2.1. GOsa² のログインと概観

最初のユーザーとしてログインした後の GOsa² の概観ページ

GOsa² へのログイン後、GOsa² の概観ページが表示されます。

タスクはメニュー選択したり、あるいは概要ページのタスクアイコンをクリックして選択できます。基本的には画面左側のメニューをお勧めします。GOsa² の全ての管理ページで利用できます。

Debian Edu ではアカウントやグループ、システム情報は LDAP ディレクトリに保存されています。このデータは主サーバーだけでなく、ネットワーク上の (ディスクレス) ワークステーションや LTSP サーバー、Windows マシンでも利用されます。生徒や教員等についてのアカウントも、一度LDAPに設定するだけで利用できます。 LDAPに登録した後は、その情報は Skolelinux ネットワーク全体の全てのシステムから利用できるようになります。

GOsa² は、部門などの階層構造の情報管理を LDAPの利用で実現しています。各「部門」毎にユーザーアカウントやグループ、システム、ネットグループ等を追加できます。あなたの組織の構造に関しても、GOsa²/LDAP の部門別の構造を使って Debian Edu 主サーバーの LDAP データツリーに反映させることができます。

デフォルトでインストールした場合、Debian Edu 主サーバーには教員と生徒の2つと、LDAP ツリーのベースレベルとなる「部門」が設定されます。生徒のアカウントは「生徒」部門に、教員は「教員」部門に追加することになります。システム (サーバー、Skolelinux ワークステーション、Windows マシン、プリンタ等) は現在ベースレベルに追加することになります。 この構成については学校に合う方法をご検討ください 。(例えば、年次グループにユーザーを作成して各グループに共通のホームディレクトリを与える方法がこのマニュアルの HowTo/AdvancedAdministration の章)

処理したいタスク毎に (ユーザー管理、グループ管理、システム、管理等) 、GOsa² は選択されている部門 (やそのベースレベル)に応じた表示をします。

7.3. GOsa² によるユーザー管理

まず、左側のナビゲーションメニューにある「Users」をクリックします。画面の右側が「生徒」や「教員」の部門フォルダーの表と GOsa² の Administrator (最初に作成したユーザー) のアカウントの表示に変わります。この表の上に Base というフィールドが表示されます。マウスをその部分に移動させると、ドロップダウンメニューがツリー構造状に表示されます。そこから行いたい操作 (例えば新しいユーザーの追加) の対象となるフォルダーを選択してください。

7.3.1. ユーザーの追加

ツリーのナビゲーション項目の隣に「Actions」メニューが表示されます。マウスをこの項目の上に移動させると、画面にサブメニューが表示されます。「Create」を選んで、そして「User」を選択してください。ユーザー作成ウイザードに進みます。

  • ここで最も重要なのはテンプレート (newstudent や newteacher) とユーザのフルネーム (画像参照) です。

  • ウイザードに従って進めると GOsa² は実名を基にしてユーザー名を自動生成します。まだ存在しないユーザー名ですら自動的に生成するため、フルネームが同一のユーザーが複数いても問題にはなりません。ただし、(日本人名のような)非アスキー文字を含むフルネームでは GOsa² は無効なユーザー名を生成する可能性がありますので、ご注意ください。

  • 生成されたユーザー名では不都合な場合は、ドロップダウンメニューで別のユーザー名候補を選択できますが、ウイザードではユーザー名を自由に設定することはできません。 (提示されたユーザー名を変更するには、エディタで /etc/gosa/gosa.conf を開き、「location definition」の追加オプションとして allowUIDProposalModification="true" を追加します。)

  • ウイザードを完了させると、GOsa² は新しいユーザの情報を表示します。上部のタブを使って内容を確認してください。

ユーザ作成後 (ウイザードで入力を促さなかった項目についてはこの段階で変更する必要はありません)、右下の隅にある「Ok」ボタンをクリックします。

最終段階として GOsa² は新しいユーザのパスワードを聞いてきます。2回入力して右下の隅にある「Set password」ボタンをクリックします。 /!\ パスワードに許されない文字があります。

全てうまくいけば、ユーザ一覧表に新しいユーザが表示されているはずです。そのネットワーク内の任意の Skolelinux マシンにそのユーザ名でログインできるようになっているはずです。

7.3.2. ユーザの検索、変更、削除

検索枠

ユーザを変更、削除するには GOsa² を使ってシステム上のユーザ一覧を表示します。画面中央辺りに「Filter」という枠があります。これは GOsa² が提供している検索ツールです。ユーザアカウントがツリーのどこにあるのかわからない場合は GOsa²/LDAP ツリーの基底レベルに移動させてから「Search in subtrees」オプションを使って検索します。

「Filter」枠を操作したら、すぐに表の一覧ビュー中央の表示に反映されます。各行に1つのユーザーアカウントを表示し、各行の一番右側にはユーザーの編集、アカウントのロック、パスワード設定、ユーザー削除といった操作のアイコンが並びます。

ユーザに関する情報を直接変更できる新しいページが表示されます。ユーザのパスワードを変更し、ユーザの所属グループ一覧を変更します。

ユーザデータの編集

7.3.3. パスワード設定

生徒は自分のユーザ名で GOsa² にログインすることで自分のパスワードを変更できます。GOsa² に楽にアクセスできるようにするため、デスクトップのシステム (またはシステム設定) メニューに Gosa という項目が用意されています。ログインした生徒に対しては最小限のバージョンの GOsa² が提示され、生徒自身のアカウントデータとパスワード設定ダイアログへのアクセスだけができるようになっています。

GOsa² では自分のユーザ名でログインした教員には特別な権限があります。より権限のある GOsa² のビューが表示され、全生徒のアカウントのパスワードを変更できます。これは授業で非常に便利かもしれません。

管理作業でユーザの新しいパスワードを設定するには

  1. 上記で説明しているようにして変更するユーザを検索します

  2. ユーザ名が表示されている行の最後辺りにある鍵の絵をクリックします

  3. 次に表示されるページでそのユーザの新しいパスワードを設定できます

ユーザパスワードの設定

推測の容易なパスワードによりセキュリティへの影響が生じることに留意してください!

7.3.4. 高度なユーザ管理

GOsa² でCSVファイルを利用してユーザを大量に作成することもできます。CSVファイルは自分の使いやすいスプレッドシートソフトウェア (例えば localc) 等により作成できます。最低限必要な項目はユーザID、姓、名、パスワードです。同一のユーザIDが複数回出てこないことを確認してください。その際、既存の LDAP の uid (これはコマンドラインで getent passwd | grep tjener/home | cut -d":" -f1 を実行すれば取得できます) も併せて確認しないといけないことに注意してください。

CSVファイル等のデータ形式について指針があります (GOsa² はデータ形式についてかなり不寛容です):

  • 項目間の区切り文字には「,」を使ってください

  • 引用符を使わないようにしてください

  • CSVファイルにヘッダ行 (通常項目名等を記述している類の行) を含めてはいけません

  • 項目の順に指定はなく、GOsa² で大量インポートを行う際に定義できます

大量インポートの手順:

  1. 左のナビゲーション項目にある「LDAP Manager」リンクをクリックします

  2. 画面右側にある「Import」タブをクリックします

  3. インポートするユーザ一覧を収録しているCSVファイルをローカルディスクから選択します

  4. 利用可能なユーザテンプレートから大量インポート時に適用させるものを選択します (NewTeacher や NewStudent 等)

  5. 右下の隅にある「Import」ボタンをクリックします

最初にいくらかテストをしておくのは良い方法です。架空のユーザを使ったCSVファイルを使えば後から削除できます。

パスワード管理の項目でも同様です。CSVファイルを使った多量のパスワードのリセットや、特別なLDAPサブツリーに属するユーザーのパスワードの再設定が行えます。

パスワードの再設定

7.4. GOsa² によるグループ管理

グループ作成

グループ作成

グループ管理はユーザ管理とかなり似ています。

グループごとに名前と説明を入力できます。新しいグループを作成する際、LDAP ツリーの正しいレベルを選択していることを確認してください。

適切な Samba グループはデフォルトでは作成されません。グループ作成時に Samba グループのオプションにチェックを入れ忘れた場合は後からグループを編集できます。

新しく作成したグループにユーザを追加するには、ユーザ一覧に戻ります。ほぼ確実に「filter」枠を使ってユーザを探すのが良いでしょう。ここでも LDAP ツリーのレベルを確認してください。

グループ管理で入力したグループは通常の unix グループでもあります。そのため、ファイルの権限管理にも利用できます。

7.4.1. コマンドラインによるグループ管理

# 既存のグループについて UNIX と Windows のグループのマッピングを表示
net groupmap list

# 新しいまたは足りないグループを追加
net groupmap add unixgroup=NEW_GROUP type=domain ntgroup="NEW_GROUP"\
                 comment="DESCRIPTION OF NEW GROUP"

7.5. GOsa² によるマシン管理

マシン管理では基本的に、Debian Edu ネットワークに接続されている全ての機器を管理できます。GOsa² を利用して LDAP ディレクトリに追加したマシンには全てにホスト名、IPアドレス、MACアドレス、ドメイン名 (通常「intern」) が付加されます。Debian Edu 構成の全面的な説明についてはこのマニュアルの全体の構成の章を参照してください。

ディスクレスワークステーションやシンクライアントは中心ネットワークに接続すればそのままで利用できます。GOsa² を利用して LDAP に追加しないといけないのはディスクを備えたワークステーションだけですが、どれも可能です。

マシンを追加するには、GOsa² メインメニュー、システム、追加と進みます。事前設定済みのアドレス空間 10.0.0.0/8 にあるIPアドレス/ホスト名を利用できます。現在事前定義されている固定アドレスは 10.0.2.2 (tjener) と 10.0.0.1 (ゲートウェイ) の2つだけです。10.0.16.20 から 10.0.31.254 までのアドレス (ほぼ 10.0.16.0/20 あるいは4000ホスト) は DHCP 向けに予約済みで動的に割り当てられます。

GOsa² で MACアドレス 52:54:00:12:34:10 のホストに固定IPアドレスを割り当てるには、MACアドレス、ホスト名、IPアドレスを入力しないといけません。代わりにPropose ip ボタンをクリックすると 10.0.0.0/8 の範囲内の最初の固定空きアドレスを表示します。この方法で初めてマシンを追加した場合はほぼ確実に 10.0.0.2 のようなアドレスになるでしょう。まずネットワーク構成について考えておいてください: 例えば 10.0.0.x で x が10-50はサーバ用、100以上はワークステーション用など。追加したシステムの有効化を忘れないように。そうすると主サーバーを例外として、他の全システムで適切なアイコンが表示されます。

マシンがシンクライアント/ディスクレスワークステーションとしてブートされている場合や、ネットワークを利用するプロファイルを使ってインストールされた場合には、sitesummary2ldapdhcp スクリプトを利用することでマシンを GOsa² に自動的に追加できます。単純な構成のマシンの場合はそのまま使えます。MACアドレスが複数あるマシンでは、実際にそのネットワークで使っているアドレスを選択してください。sitesummary2ldapdhcp -h で使い方に関して解説しています。sitesummary2ldapdhcp の使用後に表示されるIPアドレスは、動的に割り当てる(DHCPの)範囲内のアドレスであることを確認してください。システムは後でネットワーク構成に合わせ、新しいシステムの名前を変更したり、DHCP やDNSを有効化したり、また必要に応じてネットグループ(以下のスクリーンショットをご参照ください)の追加などです。それらの操作後にはシステムを再起動してください。以下のスクリーンショットのような操作手順になります:

root@tjener:~# sitesummary2ldapdhcp -a -i ether-22:11:33:44:55:ff
info: Create GOsa machine for am-2211334455ff.intern [10.0.16.21] id ether-22:11:33:44:55:ff.

Enter password if you want to activate these changes, and ^c to abort.

Connecting to LDAP as cn=admin,ou=ldap-access,dc=skole,dc=skolelinux,dc=no
enter password: ********
root@tjener:~#

GOsa² のシステム一覧表示

ホスト詳細

ホストの変更

ネットグループの追加

DNSを更新する cron ジョブは毎時動作します。su -c ldap2bind を使うと手作業で更新させることもできます。

7.5.1. マシンの検索、削除

マシンの検索や削除はユーザの検索や削除とかなり似ています。その情報は省略します。

7.5.2. 既存マシンの変更 / ネットグループの管理

GOsa² を使って LDAP ツリーにマシンを追加した後、(ユーザの管理と同様に) 検索機能を使ってマシン名をクリックするとマシンの属性を変更できます。

このシステム項目の構成は既に見てきたユーザ項目の変更と似ていますが、この文脈では別の意味になります。

例えばネットグループへのマシン追加は、ファイルへのアクセス権限やそのマシンでのコマンドの実行権限、そのマシンにログインしたユーザーについて変更するわけではありません。ここではそのマシンから利用できる、主サーバーのサービスを制限します。

デフォルトでインストールした環境ではネットグループを提供します。

  • cups-queue-autoflush-hosts

  • cups-queue-autoreenable-hosts

  • fsautoresize-hosts

  • ltsp-server-hosts

  • netblock-hosts

  • printer-hosts

  • server-hosts

  • shutdown-at-night-hosts

  • shutdown-at-night-wakeup-hosts-blacklist

  • winstation-hosts

  • workstation-hosts

ネットグループ機能の現状の用途

  • NFS

    • 主サーバーからエキスポートされたホームディレクトリを、ワークステーションや LTSP サーバーがマウントします。セキュリティのため、エキスポートされたNFS共有をマウントできるのは NetGroups の workstation-hosts、 LTSP-server-hosts、 server-hosts のいずれかに属するホストだけです。重要な点として、 GOsa² を使って LDAP ツリーにこれらのマシンを適切に設定することと、LDAP から固定IPアドレスを使うように設定することがありますので、ご注意ください。

      /!\ GOsa² を使ってワークステーションや LTSP サーバを適切に設定してください。それを忘れるとユーザは自分のホームディレクトリにアクセスできなくなります。ディスクレスワークステーションやシンクライアントはNFSを使わないためこの設定を行う必要はありません。

  • fs-autoresize

    • このグループの Debian Edu マシンは LVM パーティションの容量が足りなくなると自動的にサイズを変更します。

  • shutdown at night

    • このグループの Debian Edu マシンは節電のため、夜間は自動的に電源を落とします。

  • CUPS (cups-queue-autoflush-hosts 及び cups-queue-autoreenable-hosts)

    • このグループの Debian Edu マシンは印刷キューを毎晩自動的に空にし、毎時無効化された印刷キューがあれば再有効化します。

  • netblock-hosts

    • このグループの Debian Edu マシンはローカルネットワーク上のマシンにのみ接続を許可されます。試験期間にウェブプロキシによる制限と組み合わせて利用すると有用かもしれません。

マシン設定についてもう一つ重要なのが (「Host information」領域にある) 「Samba host」フラグです。Skolelinux の Samba ドメインに既存の Windows システムを追加する予定がある場合、Windows ホストをドメインに加えられるようにするためには、Windows ホストを LDAP ツリーに追加してこのフラグをセットする必要があります。Skolelinux ネットワークへの Windows ホストの追加に関するさらなる情報については、このマニュアルの HowTo/NetworkClients の章を見てください。

8. プリンタ管理

プリンターを管理するには、ウェブブラウザーで https://www:631 にアクセスしてください。これは一般的な CUPSの管理インターフェイスで、プリンタの追加、削除、変更や、印刷キューのクリアができるようになっています。初期設定では root だけが操作可能ですが、変更できます。エディターで "/etc/cups/cups-files.conf" を開き、サイトのポリシーに合う有効なグループ名を SystemGroup lpadmin の行に追加します。これに指定する既存の GOsa² グループの例としては gosa-adminsprinter-admins (どちらもメンバーとして最初のユーザー)、 teachersjradmins (インストールしただけの状態ではメンバーがいないグループ) があります。

8.1. ワークステーションに接続されたプリンターの利用方法

p910ndワークステーションのプロファイルを含めた場合、システムに自動的にインストールされているパッケージです。

  • /etc/default/p910ndを次のように編集してください(USB接続プリンターの場合):

    • P910ND_OPTS="-f /dev/usb/lp0"

    • P910ND_START=1

  • 主サーバーのウェブインターフェイス https://www:631 からプリンターを設定します。 (メーカーブランドや型番をに関わらず)ネットワークプリンターのAppSocket/HP JetDirect を選択して、接続URIに socket://<ワークステーションのIPアドレス>:9100 を設定してください。

9. 時刻の同期

Debian Edu のデフォルト設定では全マシンの時計を同期させるようになっていますが必ずしも正確だとは限りません。時刻の同期にはNTPを利用します。時計はデフォルトで外部ソースと同期します。そのため、同期の際に外部インターネット接続処理を伴う場合はマシンがインターネットに接続したままになる可能性があります。

/!\ ダイヤルアップやISDNによる従量制の接続ではこのデフォルト設定から変更するのが良いでしょう。

ネットワーク外の時計との同期を無効化するには、主サーバーと全クライアントの /etc/ntp.conf ファイルと、 LTSP chroot 環境を変更する必要があります。server 項目の頭にコメント記号 ("#") を追加します。その後 root で /etc/init.d/ntp restart を実行し、NTP サーバーを再起動してください。あるマシンがネットワーク外の時計をソースとして使っているかどうか確認するには ntpq -c lpeer を実行します。

10. パーティション全体の拡張

自動化でのパーティション作業にもしかするとバグがあり、一部のパーティションがインストール後にはほとんど空きがなくなっているかもしれません。そういったパーティションを拡張するには、root で debian-edu-fsautoresize -n を実行します。さらなる情報については、管理一般 HowTo の章の「パーティションサイズの変更」を見てください。

11. 保守

11.1. ソフトウェアの更新

この節では apt-get upgrade の使い方を説明します。

apt-get の使い方は実に単純です。システムを更新するのに必要なのは root でコマンドラインからコマンドを2つ apt-get update (利用可能パッケージ一覧を更新) と apt-get upgrade (アップグレードが利用できるようになったパッケージをアップグレード) 実行するだけです。

ロケールに "C" を使ってアップグレードし、英語での出力も確保しておくことをご検討ください。検索エンジンなどで生じる文字化けなどの問題で役に立つことがあります。

LC_ALL=C apt-get update ; LC_ALL=C ltsp-chroot apt-get update
LC_ALL=C apt-get upgrade -y
LC_ALL=C ltsp-chroot -m apt-get upgrade -y
ltsp-update-kernels # 上のコマンドの結果で、新しいカーネルがインストールされた場合にはこれを実行してください。
ltsp-update-image

/!\ LTSP chroot に新しいカーネルがインストールされた場合は ltsp-update-kernels を実行してカーネルとカーネルモジュールの同期を保つことが重要です。カーネルはマシンが PXE ブートしたときに TFTP 経由で配布され、カーネルモジュールは LTSP chroot から取得されます。

/!\ ltsp-update-image を実行して NBD イメージを再生成します。

cron-aptapt-listchanges をインストールして自分が読んでいるアドレスにメールを送るように設定するのも良い方法です。

cron-apt は一日一度、アップグレードできるパッケージについてメールで通知します。アップグレードをインストールはしませんが (通常夜間に) ダウンロードするため、apt-get upgrade 実行時にダウンロードを待つ必要がなくなります。

自動で更新のインストールを行うことも簡単にできます。必要なのは unattended-upgrades パッケージをインストールして 、wiki.debian.org/UnattendedUpgrades の説明に従って設定するだけです。

apt-listchanges は新しい変更履歴を電子メールで送ることもできますし、代わりにaptapt-get を実行した時に端末画面に表示することもできます。

11.1.1. セキュリティ更新に関する通知を受け取り続ける

上記で説明しているように cron-apt を実行するのはインストール済みパッケージについて利用可能なセキュリティ更新を知るのによい方法です。セキュリティ更新について通知を受け取り続ける別の方法として Debian security-announce メーリングリストの購読があります。これにはどういったセキュリティについて更新するものなのかもわかる利点があります。(cron-apt と比較して) 欠点はインストールしていないパッケージの更新に関する情報も入ってくる点です。

11.2. バックアップ管理

バックアップを管理するには、ブラウザで https://www/slbackup-php にアクセスします。このサイトへのアクセスにはSSLを経由する必要があります。root パスワードを入力する必要があるためです。SSL無しでのアクセスはできません。

/!\ 注意: このサイトはSSHでのrootログインを一時的に許可しているバックアップサーバーでのみ利用できます。主サーバー 'tjener'が初期設定サーバーです。

デフォルトで主サーバー tjener は /skole/tjener/home0/etc//root/.svk、LDAP を LVM にある /skole/backup にバックアップします。(削除してしまった場合等の) 予備として複製を持っておきたいだけであれば、この設定で良いでしょう。

/!\ このバックアップ方法ではハードドライブの故障に対する防護にはならないことに留意してください。

データを外部サーバやテープ機器、別のハードドライブにバックアップしたい場合には既存の設定を多少変更する必要があります。

フォルダー全体を復旧させたい場合はコマンドラインを利用するのが最善の選択となります:

$ sudo rdiff-backup -r <日付>  \
   /skole/backup/tjener/skole/tjener/home0/user \
   /skole/tjener/home0/user_<日付>

これは <日付>/skole/tjener/home0/ユーザー名 の内容を /skole/tjener/home0/ユーザー名_<日付> フォルダーに残します。

復旧させたいのがファイル1つだけならウェブインターフェイスからファイル (とバージョン) を選択してそのファイルだけをダウンロードできるはずです。

古いバックアップを消してしまいたい場合はバックアップページのメニューから「Maintenance」を選択して残しておく最古のスナップショットを選択します:

slbackup-php の保守

11.3. サーバ監視

11.3.1. Munin

https://www/munin/ から Munin 傾向報告システムを利用できます。システム状態の測定結果を日、週、月、年単位でグラフにして提供し、障害やシステム問題の原因を探しているシステム管理者を支援します。

Munin により監視されるマシン一覧は sitesummary に報告しているホスト一覧から自動的に生成されます。munin-node パッケージがインストールされているホストは全て Munin による監視対象に登録されます。cron ジョブの実行順のため、導入されたマシンが Munin の監視対象に入るまでに通常1日かかります。短縮するためには、sitesummary のサーバー (通常は主サーバー) で sitesummary-update-munin を root で実行します。/etc/munin/munin.conf ファイルが更新されます。

収集される測定結果は munin-node-configure プログラムを利用している各マシンで自動的に生成します。このプログラムは /usr/share/munin/plugins/ から利用できるプラグインから /etc/munin/plugins/ に作成されたシンボリックリンクを探すようになっています。

Munin についての情報は http://muninmonitoring.org/ にあります。

11.3.2. Icinga

Icinga によるシステム及びサービス監視は https://www/icinga/ から利用できます。監視対象のマシンやサービスは sitesummary システムが収集した情報から自動的に生成されます。主サーバーや LTSP サーバーのプロファイルのマシンは完全な監視情報を受け取りますが、ワークステーションやシンクライアントのマシンが受け取るのは簡素な監視情報となります。ワークステーションでも完全な監視情報を受け取るようにするには nagios-nrpe-server パッケージをインストールしてください。

ユーザ名は icingaadmin でデフォルトのパスワードは skolelinux となっています。セキュリティ上の理由から、root と同一のパスワードを再利用するのは避けてください。パスワードは root で以下のコマンドを実行することで変更できます:

htpasswd /etc/icinga/htpasswd.users icingaadmin

デフォルトでは Icinga はメールを送りません。これは /etc/icinga/sitesummary-template-contacts.cfg ファイルの notify-by-nothinghost-notify-by-emailnotify-by-email 置き換えることで変更できます。

利用される Icinga 設定ファイルは /etc/icinga/sitesummary.cfg です。sitesummary の cron ジョブは監視するホスト及びサービスの一覧を収録する /var/lib/sitesummary/nagios-generated.cfg を生成します。

ファイル /var/lib/sitesummary/icinga-generated.cfg.post に Icinga によるチェック対象を追加すると生成されるファイルに収録されています。

Icinga についての情報は http://www.icinga.com/icinga-doc パッケージにあります。

11.3.2.1. Icinga の一般的な警告とその対処方法

Icinga の最も一般的な警告とその対処手順を示します。

11.3.2.1.1. DISK CRITICAL - free space: /usr 309 MB (5% inode=47%):

当該パーティション (例では /usr/) がほぼいっぱいになっています。一般的にこの処理方法は2つあります: (1) ファイルをいくらか削除するか (2) パーティションサイズを大きくするかです。パーティションが /var/ の場合は apt-get clean を実行して APT のキャッシュを完全に削除するとファイルをいくらか削除できるかもしれません。LVM ボリューム群に利用できる空き容量がある場合は debian-edu-fsautoresize プログラムを実行してパーティション拡張を試みてもいいかもしれません。当該ホストを fsautoresize-hosts ネットグループに追加するとこのプログラムを毎時自動的に実行させられます。

11.3.2.1.2. APT CRITICAL: 13 packages available for upgrade (13 critical updates).

アップグレードできる新しいパッケージが利用可能になっています。通常重要なのはセキュリティの修正です。アップグレードするにはターミナルまたは ssh 経由でログインし、root で「apt-get upgrade && apt-get dist-upgrade」を実行します。LTSP サーバの場合は ltsp-chroot apt-get update && ltsp-chroot apt-get upgrade を実行して LTSP chroot を更新することも忘れないようにしてください。

パッケージのアップグレードを手作業で行いたくなく、Debian による新しいバージョンの作業を信頼する場合、unattended-upgrades パッケージをインストールして自動的に毎晩全て新しいパッケージにアップグレードするように設定できます。これは LTSP chroot のアップグレードは行いません。

LTSP chroot のアップグレードには ltsp-chroot apt-get update && ltsp-chroot apt-get upgrade を実行します。64ビットのサーバでは ltsp-chroot への引数として -a i386 を追加する必要があります。ホストシステムを更新する際に chroot も更新するのは良い方法です。

11.3.2.1.3. WARNING - Reboot required : running kernel = 2.6.32-37.81.0, installed kernel = 2.6.32-38.83.0

実行中のカーネルが最新のインストール済みカーネルより古くなっています。最新のインストール済みカーネルを有効化するには再起動が必要です。これは通常かなり緊急を要します。Debian Edu で新しいカーネルが出てくるのは通常セキュリティ問題を修正するものであるためです。

11.3.2.1.4. WARNING: CUPS queue size - 61

CUPS の印刷キューに保留となっているジョブが多数あります。これは恐らく利用できないプリンタが原因となっています。cups-queue-autoreenable-hosts ネットグループのメンバーとなっているホストでは印刷キューを毎時無効化する機能が有効になっているため、そういったホストでは手作業による介入は必要ないはずです。cups-queue-autoflush-hosts ネットグループのメンバーとなっているホストでは印刷キューを毎晩空にします。キューに多くのジョブがあるホストが存在する場合は、こういったネットグループにそのホストを追加することを検討してください。

11.3.3. Sitesummary

各コンピュータでの情報収集と中央サーバへの送信に sitesummary を利用しています。収集した情報は /var/lib/sitesummary/entries/ から利用できるようになっています。/usr/lib/sitesummary/ にあるスクリプトを利用して報告を生成できます。

https://www/sitesummary/ ではsitesummaryによるシンプルなレポートが利用できます。

sitesummary 関連の文書が http://wiki.debian.org/DebianEdu/HowTo/SiteSummary にいくらかあります

11.4. Debian Edu の独自化に関するさらなる情報

システム管理者にとって有用となる Debian Edu のカスタム化に関しては次の章をご覧になってください: 管理一般 Howto の章高度な管理 Howto の章

12. アップグレード

/!\ このアップグレードガイドを読む前に、運用サーバを稼働状態で更新するということは自己責任であることに注意してください。Debian Edu/Skolelinux は法律で認められている範囲内で完全に無保証です。

アップグレードは、必ずこの章とこのマニュアルの Buster の新機能の章を「全て」読んでから挑んでください。

12.1. アップグレードに関する一般的な注意

Debian をあるディストリビューションから次のディストリビューションにアップグレードするのは通常簡単なことです。Debian Edu 設定ファイルを望ましくない方法で変更しているためにこれは残念ながら当てはまりません (さらなる情報については Debian バグ 311188 参照)。アップグレードは可能ではありますが手作業による介入がいくらか必要となるかもしれません。

一般にサーバーのアップグレードはワークステーションよりも困難で、主サーバーは最もアップグレードが困難です。ディスクレスマシンの場合、特に変更していなければ chroot 環境は削除して再生成できるため容易です。変更していればその chroot 環境は基本的にワークステーションの chroot 環境であり、アップグレードはかなり容易です。

アップグレード後に確実に全て以前と同じように動作するようにしたいのならテスト用システムか運用環境のマシンと同じように設定したシステムでアップグレードをテストすべきです。そうすることでリスク無くアップグレードをテストし、全て動作すべきように動作するか確認できます。

Debian 安定版リリースについてさらなる情報がインストールマニュアルにあります。

また、旧安定版での運用を何週間か延長してしばらく待つのも賢明かもしれません。その間に他の人がアップグレードをテストして何か問題があれば言及できるということになります。Debian Edu の旧安定版リリースは次の安定版リリース後もしばらくはサポートが続けられますが Debian が旧安定版のサポートを終了すると Debian Edu でも必然的に終了することになります。

12.2. Debian Edu Stretch からアップグレードする場合

/!\ 必ず事前準備をしてください。テスト環境でStretchからのアップグレードをまず試してください。さらに、元に戻せるように事前のバックアップも完了してから実行してください。

以下の方法はデフォルトでインストールした Debian Edu 主サーバー (カーネルコマンドラインでのデスクトップ指定はdesktop=xfceで、プロファイルは主サーバー、ワークステーション、LTSP サーバーになっています)を前提にしていることに注意してください。 (一般的な素のDebian Stretch から Buster へのアップグレードについては、https://www.debian.org/releases/buster/releasenotesをご一読ください。)

X を使わないようにし、仮想コンソールを使って root でログインしてください。

apt でエラーが生じた場合は、まず apt -f install を実行してみて、apt -y full-upgrade をもう一度実行してみてください。

12.2.1. 主サーバーをアップグレードします

  • まず、システムが最新版に更新されていることを確認します:

apt update
apt full-upgrade
  • パッケージキャッシュの掃除:

apt clean
  • ディスク容量が十分にあるのか、必ず確認してください。/usr/varにはそれぞれ5GB以上の空き容量が必要になることがあります。パーティションのサイズ変更の章も参考にしてください。

  • Buster へのアップグレードの準備と実行方法:

sed -i 's/stretch/buster/g' /etc/apt/sources.list
export LC_ALL=C        # これは英語で表示をするためのオプションです。
apt update
apt purge atftpd       # tftpdのインストールのために必要なコマンドです。
apt install libcurl4   # libcurl3からの更新のため必要なコマンドです。
apt install apache2    # 後で面倒にならないようにするために必要なコマンドです。
apt full-upgrade
  • apt-list-changes: 読むべき NEWS が大量にあることを覚悟してください。ページャーのスクロールを進めるには <Enter> を、終了させるには <q> を押します。rootアカウントにはすべての情報が送信されるので、後で読むこともできます。その場合はmailxmuttなどのメール閲覧ソフトを利用してください。

  • debconf の情報を全て注意深く読み、以下で特に言及していない限り「現在インストールされているローカルバージョンを維持」を選択するようにしてください。ほとんどの場合「Enter」を押せばいいはずです。

    • restart services: "yes"を選択したください。

    • ntp: N を選択してください。

    • smb

    • dovecot

    • grub

  • 設定の適用と調整:

cf-agent -I -D installation
  • 新しい Debian Edu Buster アートワークの取得:

apt install debian-edu-artwork-buster
  • PHP 7.3 の有効化:

apt purge php7.0*
a2enmod php7.3
a2enconf php7.3-cgi
service apache2 restart
  • GOsa²アクセスの調整(暗号化方法が変更されています):

    • /etc/gosa/gosa.conf.orig をバックアップ

    • /etc/gosa/gosa.conf の長いハッシュ化されたパスワードを、 /etc/gosa/gosa.conf.orig の短いランダムなパスワードに置き換えます。 (adminPasswordsnapshotAdminPasswordのために必要です。)

    • /etc/gosa/gosa.secrets を削除

    • gosa-encrypt-passwordsを実行

    • service apache2 reload を実行

  • 再起動後さらにいくらか掃除します:

apt purge linux-image-4.9.0-*
apt purge linux-headers-4.9.0-*
apt --purge autoremove
  • アップグレードしたシステムが機能するか確認します:

再起動して最初のユーザとしてログインし、

  • GOsa² GUI が機能しているか、

  • LTSP クライアントやワークステーションに接続できるか

  • システムのネットグループのメンバーを追加/削除できるか、

  • 内部メールを送受信できるか、

  • プリンターを管理できるか、

  • その他サイト特有の事項について機能するかテストしてください。

12.2.2. ワークステーションのアップグレード

基本的には主サーバーの場合と同様ですが、不要な操作は省いて基本事項のみを実行します。

12.2.3. LTSP chroot 環境のアップグレード

ディスクの空き容量が十分にあることを確認してください。LTSP はNBD(Network Block Device)を使います。NBDイメージファイルのサイズは標準で4GiB程度になります。イメージ更新時には、更に一時ファイル用に4GiBが追加で必要となります。

Stretchでは標準的なLTSPのアーキテクチャーが i386 だったことにもご注意ください。amd64 の64ビット chroot 環境の生成方法は以下に記します。

ltsp-chroot -m -a i386 apt update
ltsp-chroot -m -a i386 apt -y full-upgrade
sed -i 's/stretch/buster/g' /opt/ltsp/i386/etc/apt/sources.list
ltsp-chroot -m -a i386 apt update
ltsp-chroot -m -a i386 apt -y full-upgrade
ltsp-chroot -m -a i386 apt -f install
ltsp-chroot -m -a i386 apt -y full-upgrade
  • 後始末:

ltsp-chroot -m -a i386 apt --purge autoremove
  • サーバ側の LTSP サポート更新:

ltsp-update-kernels
ltsp-update-sshkeys
ltsp-update-image

ディスク容量を節約したい場合、代わりに ltsp-update-image -n を使う方法があります。man ltsp-update-image を見てください。

12.2.4. LTSP chroot 環境の再生成

LTSP サーバーでも LTSP chroot 環境を再生成できます。新しい chroot 環境もシンクライアントとディスクレスワークステーションの両方をサポートします。ただしBusterでは、 LTSP chroot 環境のアーキテクチャーがLTSPサーバーで利用されているものを標準にすることになっていますので、注意してください。

/opt/ltsp/i386 (マシンによっては /opt/ltsp/amd64) を削除します。十分なディスク容量がある場合はバックアップを検討してください。

詳細やオプションについてはltsp-build-client --helpコマンドやltsp-build-client --extra-helpコマンドをご覧になってください。"/etc/ltsp/ltsp-build-client.conf" ファイルには便利なオプションが記載されていますが、コメントアウトされています。

ltsp-update-image をrootアカウントで実行しすると、 NBD イメージが再生成されます。

12.2.5. 64ビットPCクライアント用のLTSP chroot環境の追加方法

最低20GiBのディスク空き容量が /opt に必要になります。

  • "ltsp-build-client --arch amd64" を実行して、chroot環境とNBDイメージを作成します。

  • "ldapvi -ZD '(cn=admin)'"を実行し、i386amd64 に書き換えてください(専用ネットワークに関するLDAP関連のDHCP設定です)。

  • "service isc-dhcp-server restart" を実行してください。

  • /etc/debian-edu/pxeinstall.conf ファイルで "ltsparch=amd64" を設定してください。

  • 'debian-edu-pxeinstall' を実行し、PXEメニューを再生成してください。

  • 'service nbd-service restart' を実行したら、新しいNBDファイルが有効になります。

12.3. Debian Edu / Skolelinux の(Stretch より古い)旧バージョン からのアップグレード

Stretchよりも古いリリースからアップグレードする場合でも、まずStretch ベースの Debian Edu リリースにアップグレードする必要があります。前述したBusterへのアップグレードはその後に行ってください。 JessieからStretchへのアップグレード方法については Debian Edu Stretch マニュアルに記載してあります。同様に Jessie 版のマニュアルでは Wheezy からのアップグレード方法を説明しています。

13. HowTo

14. 管理一般 HowTo

さあ始めよう保守の章で、Debian Edu で最初にすべきことや基本的な保守作業の方法について説明しています。この章の HowTo ではより「高度な」ヒントや技をいくらか提示します。

14.1. 設定履歴: バージョン管理システム git を使って /etc/ を追跡

Debian Edu Squeeze で導入された etckeeper (それ以前のバージョンでは etcinsvk を使っていましたが Debian から削除されました) を使えば、バージョン管理システムとして git を使って、/etc/ 中の全ファイル履歴が管理できます。

これにより、ファイルの削除や変更、削除がいつ行われたのか、そしてファイルがテキストファイルの場合はその変更点を確認できるようになります。git リポジトリは /etc/.git/ に置かれます。

毎時、変更があれば自動的に記録され、設定の履歴を取り出して確認できます。

履歴を調べるにはコマンド etckeeper vcs log を使います。ある時点とある時点の間の差分を確認するには etckeeper vcs diff のようなコマンドを使います。

さらなる情報については man etckeeper の出力を見てください。

有用なコマンド一覧:

etckeeper vcs log
etckeeper vcs status
etckeeper vcs diff
etckeeper vcs add .
etckeeper vcs commit -a
man etckeeper

14.1.1. 使用例

新しくインストールされたシステムではこれを実行して、システムがインストールされてから行われた全変更を見られるか試してみましょう:

etckeeper vcs log

どのファイルが追跡されていないのかと、どれが最新でないのかを確認します:

etckeeper vcs status

最大1時間待ちたくないため手作業でファイルをコミットするには:

etckeeper vcs commit -a /etc/resolv.conf

14.2. パーティションのサイズ変更

Debian Edu では /boot/ パーティション以外のパーティションは全て論理 LVM ボリュームです。Linux カーネルのバージョン 2.6.10 以降でパーティションをマウントした状態で拡張できるようになっています。パーティションの縮小についてはパーティションをマウントしていない状態で行う必要があります。

fsck の実行や必要になったときにバックアップからの復旧にかかる時間の観点から、巨大すぎるパーティション (例えば 20GiB 超) の作成を避けるのは良い方法です。可能であれば、巨大すぎるパーティションよりも小さなパーティションを複数作成する方が良いということになります。

パーティション全体の拡張を容易にするために補助スクリプト debian-edu-fsautoresize が提供されています。これを実行すると、 /usr/share/debian-edu-config/fsautoresizetab/site/etc/fsautoresizetab/etc/fsautoresizetab から設定を読み込みます。ファイルから提供された規則をもとに、空き領域が少なすぎるパーティションの拡張を提案します。引数無しで実行すると何もせず、ファイルシステムを拡張するのに必要なコマンドを表示します。提示されたコマンドを実際に実行してファイルシステムを拡張するには引数 -n が必要です。

このスクリプトは fsautoresize-hosts ネットグループ一覧にある全クライアントで毎時自動的に実行されます。

Squid プロキシにより利用されているパーティションのサイズを変更した場合は etc/squid/squid.conf のキャッシュサイズも同様に更新する必要があります。補助スクリプト /usr/share/debian-edu-config/tools/squid-update-cachedir が提供され、現在の /var/spool/squid/ のパーティションサイズを自動的に確認し、Squid がその 80% をキャッシュのサイズとして利用するように設定します。

14.2.1. 論理ボリューム管理

論理ボリューム管理 (LVM) により、パーティションサイズをマウント、使用状態で変更できるようになります。LVM についてもっと学ぶには LVM HowTo を見てください。

論理ボリュームを手作業により拡張するには、単に lvextend コマンドで増やしたい大きさを指示します。例えば home0 を 30GiB に拡張するにはコマンド:

lvextend -L30G /dev/vg_system/skole+tjener+home0
resize2fs /dev/vg_system/skole+tjener+home0

を実行します。home0 を 30GiB 追加する場合は「+」を使えます (-L+30G)

14.3. GOsa² を利用するための主サーバーへのグラフィカル環境のインストール

(誤って) 「主サーバー」プロファイルだけでインストールしてしまい、ウェブブラウザを利用できるクライアントがない場合は次の方法が簡単でしょう。 主サーバのインストール中に作成した「最初のユーザー」 で、(グラフィカルではない) シェルから以下のコマンドを順に実行して、主サーバーに最小構成のデスクトップをインストールします:

  $ sudo apt update
  $ sudo apt install education-desktop-xfce lightdm
  ### インストールが完了したら 'sudo service lightdm start' を実行
  ### 「最初のユーザー」でログイン

14.4. ldapvi の利用

ldapvi はコマンドライン上で普通のテキストエディタを利用して LDAP データベースを編集するツールです。

以下を実行する必要があります:

ldapvi --ldap-conf -ZD '(cn=admin)'

注意: ldapvi はデフォルトに設定されているエディタを利用します。シェルプロンプトで export EDITOR=vim を実行するとエディタに vi クローンを使う環境に設定できます。

ldapvi を使って LDAP の項目を追加するには新しい LDAP 項目の前に連番と add という文字列を使います。

/!\ 警告: ldapvi は非常に強力なツールです。LDAP データベースを台無しにしないように注意してください。JXplorer についても同様です。

14.5. Kerberos対応NFS

Kerberosを使ってNFSでホームディレクトリを安全にマウントすることができます。セキュリティレベルはkrb5krb5i、そしてkrb5pがサポートされています。krb5はKerberos認証のことで、 "i" は整合性、 "p" は暗号化などのプライバシーを意味します。セキュリティレベルに伴い、サーバーとワークステーションの両方でコンピューターへの負荷は増加します。krb5iがその面も含めるといいかもしれません。

GOsa²を使って追加したシステムでは, Kerberosホストのkeytabファイルは自動生成されます。

GOsa²で設定された既存のシステムにkeytabを生成するには、主サーバーにrootとしてログインして、次のコマンドを実行してください:

/usr/share/debian-edu-config/tools/gosa-modify-host <ホスト名> <IPアドレス>

注意: ホストのkeytab生成が可能なシステムタイプはworkstationservers、そしてterminalの形式のみで、netdevicesは含みません。またLTSPクライアントはsshfsでホームディレクトリをマウントするので、ディスクレスワークステーションには操作は不要です。

14.5.1. 実際の手順

主サーバー

  • rootとしてログイン

  • ldapvi -ZD '(cn=admin)'を実行して、 sec=sys を探して sec=krb5iに変更

  • /etc/exportsを編集します。既存の/srv/*関連をコメント解除して有効化したり、コメントアウトしたり、あるいは内容を修正します。以下のようになるよう確認してください:

/srv/nfs4        gss/krb5i(rw,sync,fsid=0,crossmnt,no_subtree_check)
/srv/nfs4/home0  gss/krb5i(rw,sync,no_subtree_check)
  • exportfs -r を実行

  • gss/krb5iのどちらも有効なエントリーの管理にはexportfsを実行します。

「ワークステーション(Workstation)」プロファイル

  • rootとしてログインします。

  • /usr/share/debian-edu-config/tools/copy-host-keytab を実行

14.6. Standardskriver

このツールは使用場所やコンピューター、あるいはグループメンバーに基づいて規定のプリンターを設定します。詳細については/usr/share/doc/standardskriver/README.mdをご覧ください。

設定ファイル /etc/standardskriver.cfg を管理者が準備する必要があります。いくつかの例が /usr/share/doc/standardskriver/examples/standardskriver.cfg にありますので、参考にしてください。

14.7. LDAP GUI JXplorer

LDAP データベースについてGUIで作業する方が良ければ jxplorer パッケージについて調べてみてください。これはデフォルトでインストールされています。次のようにして書き込みできるように接続します:

host: ldap.intern
port:636
Security level: ssl + user + password
User dn: cn=admin,ou=ldap-access,dc=skole,dc=skolelinux,dc=no

14.8. コマンドラインツール ldap-createuser-krb

ldap-createuser-krb は小さなコマンドラインツールで、LDAP ユーザを作成してそのパスワードを Kerberos で設定する処理を行います。これが有用なのは主にテストですが。

14.9. stable-updates の利用

2011年の Squeeze リリース以降、それまで Debian では volatile.debian.org で保守されていたパッケージを stable-updates スイートに収録するようになりました。

stable-updates を直接利用することもできますが、利用しないといけないというわけではありません: stable-updates は定期的に安定版のポイントリリースの際に取り込まれます。これは大体2か月ごとに行われます。

14.10. backports を利用した、より新しいソフトウェアのインストール

Debian Edu の安定性が好ましいために Debian Edu を選択した。よくできています。しかし問題が一つだけあります: ソフトウェアが求めるものよりも少々古くなっていることがあります。これは backports の出番です。

backports で扱うのは Debian のテスト版 (ほとんどの場合) や Debian の不安定版 (例えばセキュリティ更新等、一部の状況でのみ) のパッケージを再コンパイルしたものであるため、(それが可能な限り) 新しいライブラリを必要とせず Debian Edu 等の安定版 Debian ディストリビューションで動作します。利用可能なバックポートを全て使うのではなく、要求に一致する個々のバックポートだけを取り上げて利用することを勧めます。

backports の利用は簡単です:

echo "deb http://deb.debian.org/debian/ buster-backports main" >> /etc/apt/sources.list
apt-get update

この後はバックポートされたパッケージを簡単にインストールできます。以下のコマンドではバックポートされたバージョンの tuxtype をインストールします:

apt-get install -t buster-backports tuxtype

Backports のパッケージは他のパッケージと全く同じように (利用可能になれば) 自動的に更新されます。通常のアーカイブと同様、backports にはセクションが main、 contrib、 non-free の3つあります。

14.11. CDや類似イメージからのアップグレード

インターネット接続がなく、物理メディアのみであるバージョンから別のバージョン (例えば Buster 10.1+edu0 から 10.3+edu1) にアップグレードしたい場合は、以下の手順で行ってください:

CD / DVD / Blu-ray ディスク / USBフラッシュドライブなどを差し込んでマウントし、apt-cdrom コマンドを実行します:

apt-cdrom add

apt-cdrom(8) man ページから引用します:

  • apt-cdrom は利用可能な取得元として、APT のリストに新しい CD-ROM を追加するのに使用します。apt-cdrom は、ディスクの構造を測定します。また、焼き損じを可能な限り補正し、インデックスファイルの確認を行います。

  • APT システムに手作業で CD を追加するのは難しいため、apt-cdrom が必要になります。その上、複数の CD のディスクを 1 枚づつ、焼き損じを補正できるか評価しなければなりません。

それからコマンドを2つ実行し、システムをアップグレードします:

apt-get update
apt-get upgrade

14.12. 自動での残存プロセスの掃除

killer は現在マシンにログインしていないユーザに属するプロセスを取り除く perl スクリプトです。cron ジョブにより毎時実行されます。

14.13. セキュリティ更新の自動インストール

unattended-upgrades はセキュリティその他の更新を自動的にインストールする Debian パッケージです。このパッケージをインストールした場合、セキュリティ更新をするように設定されます。自動更新時のログは /var/log/unattended-upgrades/ で参照できます。もちろん /var/log/dpkg.log/var/log/apt/ もあります。

14.14. 夜間自動マシンシャットダウン

クライアントマシンは、自動的に夜に電源オフにして朝に電源オンにすることで、消費電力と電気料金を節約することも可能です。このパッケージは16:00以後、毎時マシンの電源オフを試みますが、ユーザーがいると思われる場合にはそのままにします。このパッケージは07:00頃にBIOS機能でマシンを電源オンにし、一方主サーバーは06:30から Wake-on-LAN パケットを送って他のマシンの電源オンにします。各マシンの crontab で時刻は変更できます。

この設定にあたって留意しておくべき事項:

  • 誰かが使用中のクライアントはシャットダウンすべきではありません。これは who の出力で確認できます。また、特別な状況では LTSP シンクライアントと連携する LDM (LTSP Display Manager) の ssh 接続コマンドを確認します。

  • 電気のヒューズを飛ばすような状況を避けるためにどのクライアントも同時に起動しないようにするのは良い方法です。

  • クライアントを起動させる方法は2種類あります。1つはBIOSの機能を利用し、ハードウェアクロックが正常に動作していることと、マザーボードとそのバージョンのBIOSが nvram-wakeup によりサポートされていることが要求されます。もう一方ではクライアントが wake-on-lan に対応していることと、起動させる必要のある全クライアントについてサーバが知っていることが要求されます。

14.14.1. shutdown-at-night の設定方法

夜間電源を落としておきたいクライアントで /etc/shutdown-at-night/shutdown-at-night を作成するか、ホスト名 (クライアントでの「uname -n」の出力) をネットグループ「shutdown-at-night-hosts」に追加します。GOsa² ウェブツールを利用して LDAP のネットグループにホストを追加できます。クライアント側のBIOSで wake-on-lan の設定を行う必要があるかもしれません。また、クライアントの電源が落とされている場合でも wake-on-lan サーバのとクライアントの間で利用されているスイッチやルータが WOL パケットをクライアントに渡すということも重要です。スイッチによっては、スイッチ上の ARP テーブルにないクライアントへのパケットを渡せない場合があり、そうなるとそこで WOL パケットがブロックされてしまいます。

サーバーで Wake-on-LAN を有効化するには、 /etc/shutdown-at-night/clients にクライアントを追加します。クライアントごとに1行ずつ、IPアドレス、空白、MACアドレス (イーサネットアドレス) の順で記載します。クライアント一覧をその場で生成する /etc/shutdown-at-night/clients-generator スクリプトを作成する方法もあります。

sitesummary と併せて使う場合の /etc/shutdown-at-night/clients-generator の例です:

  #!/bin/sh
  PATH=/usr/sbin:$PATH
  export PATH
  sitesummary-nodes -w

クライアントでネットグループを使って shutdown-at-night を有効化している場合の代替として、ng-utils パッケージのネットグループツールを利用するこのスクリプトがあります:

  #!/bin/sh
  PATH=/usr/sbin:$PATH
  export PATH
  netgroup -h shutdown-at-night-hosts

14.15. ファイアウォールの先に置かれている Debian-Edu サーバへのアクセス

インターネットからファイアウォールの先のマシンにアクセスさせる場合、パッケージ autossh のインストールを検討してください。これを利用し、自分のアクセスできるインターネット上のマシンへのSSHトンネルを用意できます。そのマシンからSSHトンネルを経由してファイアウォールの先のサーバにアクセスできます。

14.16. サービスマシンの追加による主サーバーの負荷分散

デフォルトのインストールでは、サービスはすべて「主サーバー (tjener) 」で実行されます。別のマシンへの一部サービスの移行を単純にするため、「最小」のインストール用プロファイルが利用できるようになっています。このプロファイルでインストールすると、Debian Edu ネットワークの一部ではあるものの、サービスは何も実行しないマシンになります。

一部のサービスを行うために専用マシンを用意するのに必要となる手順があります。

  • debian-edu-expert ブートオプションを使って「最小」プロファイルをインストールします

  • サービスを行うパッケージをインストールします

  • サービスを設定します

  • 主サーバーで行っている当該サービスを停止します

  • 主サーバでー (LDAP/GOsa² 経由で) DNSを更新します

14.17. wiki.debian.org の HowTo

FIXME: The HowTos from http://wiki.debian.org/DebianEdu/HowTo/ are either user- or developer-specific. Let's move the user-specific HowTos over here (and delete them over there)! (But first ask the authors (see the history of those pages to find them) if they are fine with moving the howto and putting it under the GPL.)

15. 高度な管理 HowTo

この章では高度な管理タスクについて説明します。

15.1. GOsa² によるユーザの独自設定

15.1.1. 年次グループ内のユーザ作成

この例では各グループに共通のホームディレクトリ (home0/2014, home0/2015, 等) を持つ年次グループ内にユーザを作成したい、また作成するユーザはCSVによりインポートしたいものとします。

(主サーバーの root で)

  • 必要な年次グループのディレクトリを作成します

mkdir /skole/tjener/home0/2014

(Gosa の最初のユーザーとして)

  • 部門 (Department)

メインメニュー: 「Directory structure」に移動し、「Students」部門をクリックします。「Base」欄には「/Students」が表示されているはずです。「Actions」ドロップボックスから「Create」「Department」を選択します。名前 (2014) と説明 (2014年卒業の生徒) の値を埋め、「Base」欄はそのまま (「/Students」のはずです) にします。「Ok」をクリックして保存します。これで新しい部門 (2014) が「/Students」の下に表示されるようになったはずです。それをクリックします。

  • グループ

メインメニュー「Actions/Create/Group」から「Groups」を選択します。グループ名を入力して (「Base」はそのまま、「/Students/2014」になっているはずです) 「Samba group」の左側にあるチェックボックスをクリックします。「Ok」をクリックして保存します。

  • テンプレート

「users」をメインメニューで選択し、Base欄を「Students」に変更します。新しい「NewStudent」エントリーが表示されるので、クリックしてください。これは「students」テンプレートで、実際のユーザーではありません。(CSVファイルでのインポートができるにように)、こういったテンプレートを作る必要があります。「Generic」「POSIX」{Samba」タブに表示される項目は、新しいテンプレートを作るときのためにスクリーンショットを撮っておくべきです。

次にBase項目を「/Students/2014」にします。「Create/Template」を選んで、「Generic」タブの項目からはじめ、「POSIX」そして「Samba」の順に入力していきます(「2014」グループを「Group Membersip」でも作ります )。最後にPOSIXアカウントとSambaアカウントの作成をします。

  • ユーザのインポート

CSVをインポートする際に新しいテンプレートを選択します。少数のユーザを使ってテストしておくことを勧めます。

15.2. その他のユーザ独自設定

15.2.1. 全ユーザのホームディレクトリ内へのディレクトリ作成

このスクリプトでは管理者が各ユーザのホームディレクトリ内にディレクトリを作成してアクセス権限と所有権をセットできます。

group=teachers と permissions=2770 を指定する以下の例では、ユーザはファイルを「assignment」ディレクトリに保存することでその課題を提出でき、教員側はそのディレクトリに書き込みアクセス権限が与えられているためコメントを加えることができます。

 #!/bin/bash
 home_path="/skole/tjener/home0"
 shared_folder="assignments"
 permissions="2770"
 created_dir=0
 for home in $(ls $home_path); do
    if [ ! -d "$home_path/$home/$shared_folder" ]; then
        mkdir $home_path/$home/$shared_folder
        chmod $permissions $home_path/$home/$shared_folder
        #set the right owner and group
        #"username" = "group name" = "folder name"
        user=$home
        group=teachers
        chown $user:$group $home_path/$home/$shared_folder
        ((created_dir+=1))
    else
        echo -e "the folder $home_path/$home/$shared_folder already exists.\n"
    fi
 done
 echo "$created_dir folders have been created"

15.2.2. USBメモリやCD、DVDへの簡単アクセス

ユーザが (ディスクレス) ワークステーションにUSBメモリやCD、DVDを差し込むと、他の通常のインストールと同じようにウィンドウが出てきてどうするか質問します。

ユーザがシンクライアントにUSBメモリやCD、DVDを差し込むと、通知ウィンドウは数秒間表示されるだけです。メディアは自動的にマウントされ、アクセスして /media/$user を見られるようになります。これは経験の浅い多くのユーザにとってはかなり困難です。

デスクトップ環境として KDE「Plasma」(または KDE「Plasma」と併せてインストールしていれば LDXE) を利用している場合、デフォルトのファイルマネージャー Dolphin を表示させるようにできます。そのように設定するにはターミナルサーバで単に /usr/share/debian-edu-config/ltspfs-mounter-kde enable を実行します (GNOME を利用している場合はデバイスのアイコンがデスクトップに置かれ、簡単にアクセスできるようになっています)。

さらに、以下のスクリプトを使って全ユーザのホームディレクトリにシンボリックリンク「media」を作成し、USBメモリやCD、DVD等シンクライアントに差し込んだメディアに簡単にアクセスできるようにできます。接続したメディアのファイルをユーザが直接編集したいような場合に便利かもしれません。

 #!/bin/bash
 home_path="/skole/tjener/home0"
 shared_folder="media"
 permissions="775"
 created_dir=0;
 for home in $(ls $home_path); do
    if [ ! -d "$home_path/$home/$shared_folder" ]; then
        ln -s /media/$home $home_path/$home/$shared_folder
        ((created_dir+=1))
    else
        echo -e "the folder $home_path/$home/$shared_folder already exists.\n"
    fi
 done
 echo "$created_dir folders has been created"
15.2.2.1. LTSP サーバの脱着可能メディアについての警告

/!\ 警告: LTSP サーバにUSBメモリその他の脱着可能メディアを差し込むとリモートの LTSP クライアントでメッセージが出てくることになります。

リモートユーザがそのポップアップを確認した、あるいはコンソールから pmount を使っている場合、そのユーザはその脱着可能デバイスをマウントし、ファイルにアクセスできます。

15.3. ストレージ専用サーバの利用

以下の手順を追ってユーザのホームディレクトリや他のデータを置ける、専用のストレージサーバを用意します。

  • 新しい種類のサーバーを追加には、このマニュアルのさあ始めようの章で説明しているようにGOsa² を使います。

    • この例では「nas-server.intern」をサーバ名としています。「nas-server.intern」の設定が出来たら、新しいストレージサーバを指すNFSエクスポートが適切なサブネットやマシンにエクスポートされているか確認します:

          root@tjener:~# showmount -e nas-server
          Export list for nas-server:
          /storage         10.0.0.0/8
          root@tjener:~#

      この例ではバックボーンネットワークの全てが /storage エクスポートへのアクセスを許されています。(これは tjener:/etc/exports ファイルで行うのと同様にネットグループメンバー権やIPアドレスで制限することでNFSへのアクセスを限定できます。)

  • 「nas-server.intern」についての自動マウント情報をLDAPに追加し、全クライアントからリクエストにより新しいエクスポートを自動的にマウントできるようにします。

    • これは GOsa² では自動マウント用モジュールが欠けているためできません。代わりに ldapvi を利用し、エディタを使って必要な LDAP 項目を追加します。

      ldapvi --ldap-conf -ZD '(cn=admin)' -b ou=automount,dc=skole,dc=skolelinux,dc=no

      エディタが起動したら、ファイルの末尾に以下の LDAP 項目を追加します。 (最後の LDAP 項目の「/&」は全ての「nas-server.intern」エクスポートに合うワイルドカードで、これにより LDAP 中の個々のマウントポイントを列挙する必要がなくなります。)

          add cn=nas-server,ou=auto.skole,ou=automount,dc=skole,dc=skolelinux,dc=no
          objectClass: automount
          cn: nas-server
          automountInformation: -fstype=autofs --timeout=60 ldap:ou=auto.nas-server,ou=automount,dc=skole,dc=skolelinux,dc=no
      
          add ou=auto.nas-server,ou=automount,dc=skole,dc=skolelinux,dc=no
          objectClass: top
          objectClass: automountMap
          ou: auto.nas-server
      
          add cn=/,ou=auto.nas-server,ou=automount,dc=skole,dc=skolelinux,dc=no
          objectClass: automount
          cn: /
          automountInformation: -fstype=nfs,tcp,rsize=32768,wsize=32768,rw,intr,hard,nodev,nosuid,noatime nas-server.intern:/&
  • tjener.intern はマウントのループを避けるため自動マウントを利用しないので、tjener.intern:/etc/fstab に関連する項目を追加します:

    • mkdir を使ってマウントするディレクトリを作成し、「/etc/fstab」を適切に編集して mount -a を実行して新しいリソースをマウントします。

  • ディスクレスワークステーションを使っている場合はアクセスを有効化します。NFS と automount に代えて sshfs を使うようになったためこれは特別な状況です:

    • 同様に LTSP ディスクレスクライアントの root にマウントポイントのディレクトリ (デフォルトでは /opt/ltsp/i386/) も作成します。

      /opt/ltsp/i386/etc/lts.conf に、例えば "LOCAL_APPS_EXTRAMOUNTS=/storage"といった行を追加します。

      そしてそれぞれのユーザーのホームディレクトリに、'ln -s /storage Storage' などでシンボリックリンクを作成すると、ユーザーにとって便利でしょう。

これでユーザは任意のワークステーションや LTSP シンクライアント、LTSP サーバから任意のアプリケーションで「/tjener/nas-server/storage/」ディレクトリ、LTSP ディスクレスクライアントの場合は「~/Storage」に行くだけで「nas-server.intern」にあるファイルに直接アクセスできるはずです。

15.4. SSHログインアクセスの制限

SSHのログインを制限する方法は複数ありますが、一部を提示します。

15.4.1. LTSP クライアント無しでの準備

LTSP クライアントを使っていない場合の簡単な方法は新しいグループ (例えば sshusers) を作成してそのマシンの /etc/ssh/sshd_config ファイルに1行追記します。sshusers グループのメンバーだけが任意のマシンからのSSH接続を許可されます。

GOsa で管理する方法はかなり簡単です:

  • 基底レベル (既に gosa-admins 等、他のシステム管理関連のグループがあるはずです) にグループ sshusers を作成します。

  • 新しいグループ sshusers にユーザを追加します。

  • /etc/ssh/sshd_config に AllowGroups sshusers を追加します。

  • service ssh restart を実行します。

15.4.2. LTSP クライアントの準備

デフォルトで用意した LTSP クライアントは LTSP サーバへの接続にSSHを使います。そのためPAMを利用した別の方法が必要となります。

  • LTSP サーバの /etc/pam.d/sshd ファイルで pam_access.so を有効化します。

  • (例では) ユーザ alice、jane、bob、john はどこからでも、他のユーザはすべて内部ネットワークからの接続だけを許すように /etc/security/access.conf を設定します:

+ : alice jane bob john : ALL
+ : ALL : 10.0.0.0/8 192.168.0.0/24 192.168.1.0/24
- : ALL : ALL
#

特定の LTSP サーバしか使わない場合は 10.0.0.0/8 ネットワークを外して内部 ssh ログインアクセスを無効化することもできます。注意: 誰かが特定の LTSP クライアントネットワークにコンピュータを接続すると LTSP サーバへのSSHアクセスを獲得できるということになります。

15.4.3. 更に複雑な場合のセットアップでの注意点

もしLTSPクライアントが(複合サーバーやLTSPクラスターの場合に)10.0.0.0/8 のネットワークに属する場合、厄介になります。内部でのSSHログインを無効化する方法としては、DHCP(LDAP内)でベンダークラス識別子をチェックするようにすることとPAMの適切な設定を組み合わせることが挙がります。

16. デスクトップ HowTo

16.1. 多国語対応デスクトップ環境のセットアップ

多国語対応するには、次の手順を行ってください:

  • dpkg-reconfigure locales をrootで実行し、必要な言語を選びます (UTF-8のものにしてください).

  • 以下のコマンドをルートで実行して必要なパッケージをインストールします:

apt update
/usr/share/debian-edu-config/tools/install-task-pkgs
/usr/share/debian-edu-config/tools/improve-desktop-l10n

ユーザーはLightDMディスプレイマネージャーでログインする前に利用する言語を選択できるようになっています。Xfce、LXDE、LXQtも同様です。GNOMEとKDEに関しては、それぞれ「地域と言語」の設定と言語設定のツールがあるので、それらを利用してください。MATEでは「Arctica greeter 」がLightDMの言語設定を阻害してしまうので、apt purge arctica-greeter で標準のLightDMに設定してください。

LTSPディスクレスクライアントを使う場合は、上述の手順に加えてLTSP chroot 環境も設定する必要があります。LDMは全てのデスクトップ環境をサポートしています。まず「Preferences」を使って言語を選び、ログインしてください。

16.2. DVDの再生

ほとんどの商用DVDの再生に libdvdcss が必要です。法的な理由からこれは Debian (Edu) には収録されていません。これの利用を法的に許されている場合は libdvd-pkg Debian パッケージを利用できます。/etc/apt/sources.listcontrib が有効になっていることを確認してください。

apt update
apt install libdvd-pkg

debconf の質問に答え、dpkg-reconfigure libdvd-pkg を実行します。

16.3. 手書きフォント

パッケージ fonts-linex (デフォルトでインストールされます) は子供向けの楽しい手書きフォント「Abecedario」をインストールします。このフォントには点線のものや基準線が付加されたものなど複数の形式があります。

17. ネットワーククライアント HowTo

17.1. シンクライアント及びディスクレスワークステーションについて

(!) Debian Edu Busterからの標準: LTSPクライアントとLTSPサーバーは、同一のアーキテクチャーであることになりました(最近の64ビットPC "amd64" か、古い32ビット時代のPC "i386"のどちらか一方のみです)。

/!\ この章でのコマンドすべてで、アーキテクチャーを("amd64"か"i386"のいずれかに)正しく設定することに注意してください。

シンクライアントとディスクレスワークステーションの両方を表す総称が LTSP クライアントです。LTSP は Linux ターミナルサーバプロジェクトを短縮した名前です。

シンクライアント

シンクライアントを利用すれば、普通のPCをLTSP サーバ上であらゆるソフトウェアが動作する(X-)端末にできます。この場合マシンは各々のハードドライブを利用せず、PXE経由で起動します。

ディスクレスワークステーション

ディスクレスワークステーションはソフトウェアを全てローカルで実行します。クライアントマシンはローカルハードドライブを利用せず、LTSP サーバから直接ブートします。ソフトウェアは LTSP サーバ (LTSP chroot 内) で保守管理され、ディスクレスワークステーションで実行されます。ホームディレクトリやシステム設定もサーバに保管されます。ディスクレスワークステーションは少々古くなった (しかし高性能な) ハードウェアをシンクライアント並に低い保守コストで再利用する素晴らしい方法です。

LTSP ではディスクレスワークステーションのRAM容量のデフォルトの最小限度を320MBと決めています。RAM容量がこれに満たない場合、そのマシンはシンクライアントとしてブートします。関連する LTSP パラメータは FAT_RAM_THRESHOLD でそのデフォルト値は 300 です。そのため (例えば) RAMが1GB以上ある場合にのみそのクライアントをディスクレスワークステーションとしてブートさせるには FAT_RAM_THRESHOLD=1000 を lts.conf に追加 (または LDAP でそのように設定) します。ワークステーションとは異なり、ディスクレスワークステーションは LTSP サーバへのログインや接続に LDM を利用するため、GOsa² でマシンを追加する必要はありません。

LTSP クライアントのファームウェア

クライアントのネットワークカードがフリーでないファームウェアを必要とする場合は LTSP クライアントのブートは失敗します。マシンのネットワークブートに関わる問題の解決にPXEインストールを利用できます。XXX.bin ファイルが欠けていると Debian インストーラが訴えていれば、LTSP クライアントが利用する initrd にフリーでないファームウェアを追加しないといけないということになります。

この場合は LTSP サーバで以下のコマンドを実行します。

# まずファームウェアパッケージについての情報を集めます。
apt-get update && apt-cache search ^firmware-

# ネットワークインターフェイス用にどのパッケージをインストールする必要があるのか判断します。
# 大抵は firmware-linux-nonfree になります。
# amd64 アーキテクチャの LTSP chroot で有効にする必要があります。
ltsp-chroot -a amd64 apt-get update
ltsp-chroot -d -a amd64 apt-get -y -q install <パッケージ名>

# 新しい initrd をサーバーの tftpboot ディレクトリにコピーします。
ltsp-update-kernels
ltsp-update-image

手軽な別の方法 -- 利用可能なファームウェアを全てインストールして tftpboot ディレクトリを更新します:

/usr/share/debian-edu-config/tools/ltsp-addfirmware

17.1.1. LTSP クライアントの種類の選択

各 LTSP サーバーにはイーサネットインターフェイスが2つあります。1つは中心側の 10.0.0.0/8 サブネット (主サーバーとつながっているネットワーク) で、もう1つは別のローカルの 192.168.0.0/24 サブネット (各 LTSP サーバーごとに分離されているサブネット) を構成します。

中心側のサブネットでは完全なPXEメニューを提供します。各 LTSP サーバごとに分離されているサブネットではディスクレスワークステーションと LTSP クライアントだけが選択できるようになっています。

中心側サブネット 10.0.0.0/8 でデフォルトのPXEメニューを使うと、マシンはディスクレスワークステーションまたはシンクライアントとして起動できます。分離されているサブネット 192.168.0.0/24 にあるクライアントマシンはRAM容量が十分にあればデフォルトでディスクレスワークステーションとして起動します。ある LTSP のクライアント側サブネットにあるクライアントマシンを全てシンクライアントとして起動させるには以下を実行します。

(1) 「/opt/ltsp/amd64/etc/ltsp/update-kernels.conf」を次のように編集します。
CMDLINE_LINUX_DEFAULT="init=/sbin/init-ltsp quiet"
の行を
CMDLINE_LINUX_DEFAULT="init=/sbin/init-ltsp LTSP_FATCLIENT=False quiet"
に置き換えます。
(2)「ltsp-chroot -a amd64 /usr/share/ltsp/update-kernels」を実行します
(3)「ltsp-update-kernels」を実行します
(4)「ltsp-update-image」を実行します

17.2. PXEメニューの設定

PXEの設定は debian-edu-pxeinstall スクリプトで生成されます。設定の一部は /etc/debian-edu/pxeinstall.conf を編集すれば別の内容に変更できます。

17.2.1. PXEインストールの設定

PXEインストールの選択肢はデフォルトで、マシンをPXEブートできる誰でも使えるようになっています。PXEインストールの選択肢をパスワード保護するには、以下のような内容のファイル /var/lib/tftpboot/menupassword.cfg を作成します:

MENU PASSWD $4$NDk0OTUzNTQ1NTQ5$7d6KvAlVCJKRKcijtVSPfveuWPM$

パスワードのハッシュは当該パスワードのMD5ハッシュに置き換えてください。

PXEインストールでは言語やキーボードレイアウト、ミラーの設定を主サーバーインストール時の設定から引き継ぎ、他 (プロファイル、popcon への参加、パーティション、root パスワード) はインストール時に質問します。インストール時の質問を避けるには、ファイル /etc/debian-edu/www/debian-edu-install.dat を編集して、debconf 値の自動設定を提供します。利用可能な一部の debconf 値の例は、/etc/debian-edu/www/debian-edu-install.dat のコメントに書かれています。変更は debian-edu-pxeinstall を使ってPXEインストール環境を再作成した時点で失われます。debian-edu-pxeinstall での再作成時に debconf 値を /etc/debian-edu/www/debian-edu-install.dat に付加するには、追加の debconf 値を指定したファイル /etc/debian-edu/www/debian-edu-install.dat.local を追加します。

PXEインストールの変更についてさらなる情報がインストールの章にあります。

17.2.2. PXEインストール用独自リポジトリの追加

独自リポジトリを追加するには以下のような行を /etc/debian-edu/www/debian-edu-install.dat.local に追加します:

# skole プロジェクトのローカルリポジトリを追加
d-i     apt-setup/local1/repository string      http://example.org/debian stable main contrib non-free
d-i     apt-setup/local1/comment string         Example Software Repository
d-i     apt-setup/local1/source boolean         true
d-i     apt-setup/local1/key    string          http://example.org/key.asc

それから /usr/sbin/debian-edu-pxeinstall を一度実行します。

17.2.3. (主サーバーと LTSP サーバーの) 複合サーバーのPXEメニュー変更

PXEメニューにより、LTSP クライアントのネットワークブートやインストーラその他の代替手段をブートできます。クライアントに合うディレクトリに他のファイルがなければファイル /var/lib/tftpboot/pxelinux.cfg/default がデフォルトで利用され、何も手を加えない状態で /var/lib/tftpboot/debian-edu/default-menu.cfg へのリンクがセットされています。

全クライアントで完全なPXEメニューを提示せずディスクレスワークステーションとしてブートさせるにはシンボリックリンクを変更します:

ln -s /var/lib/tftpboot/debian-edu/default-diskless.cfg /var/lib/tftpboot/pxelinux.cfg/default

全クライアントでシンクライアントとしてブートさせるにはシンボリックリンクをこのように変更します:

ln -s /var/lib/tftpboot/debian-edu/default-thin.cfg /var/lib/tftpboot/pxelinux.cfg/default

http://syslinux.zytor.com/wiki/index.php/PXELINUX にある PXELINUX 文書も参照してください。

17.2.4. 主サーバーと LTSP サーバーの分離

性能とセキュリティを考慮して、LTSP サーバーとしては働かない、独立した主サーバーを用意します。

ltspserver00 で中心ネットワーク (10.0.0.0/8) のディスクレスワークステーションを担当させ、主サーバーを複合サーバーにしない場合は以下の手順を追います:

  • ltspserver00 の /var/lib/tftpboot から ltsp ディレクトリを主サーバーの同一ディレクトリにコピーします。

  • /var/lib/tftpboot/debian-edu/default-diskless.cfg を主サーバーの同一ディレクトリにコピーします。

  • ltspserver00 のIPアドレスを使うように /var/lib/tftpboot/debian-edu/default-diskless.cfg を編集します。以下の例では ltspserver00 の中心側ネットワークのIPアドレスに 10.0.2.10 を使っています:

 DEFAULT ltsp/amd64/vmlinuz initrd=ltsp/amd64/initrd.img nfsroot=10.0.2.10:/opt/ltsp/amd64 init=/sbin/init-ltsp boot=nfs ro quiet ipappend 2
  • 主サーバーの /var/lib/tftpboot/pxelinux.cfg のシンボリックリンクが /var/lib/tftpboot/debian-edu/default-diskless.cfg を指すようにします。

ldapvi を使って「next server tjener」を検索し、tjener を ltspserver00 に置き換える方法もあります。

17.2.5. 異なる LTSP クライアントネットワークの利用

LTSP サーバのプロファイルを使ってインストールしたマシンではデフォルトの LTSP クライアントネットワークは 192.168.0.0/24 となっています。LTSP クライアントを多数抱えている、あるいは異なる LTSP サーバで i386 と amd64 の chroot 環境を両方とも提供する場合、もう1つの設定済みネットワーク 192.168.1.0/24 を同様に使うこともできます。ファイル /etc/network/interfaces を編集して eth1 設定を適切に調整します。DNSやDHCPの設定を調べるには ldapvi その他任意の LDAP エディタを利用できます。

17.2.6. 32ビットクライアント向けのLTSP chroot 環境の追加方法

LTPSサーバーと chroot 環境が64ビットPCの場合でも、古い32ビット機材を利用する方法はあります。/opt に最低で20GBの追加空き容量が必要になります。

  • ltsp-update-image --arch i386 を実行して NBD イメージを再生成します。

  • ldapvi -ZD '(cn=admin)' を使って amd64i386 に書き換えます(dhcp statements in LDAP for one dedicated network).

  • service isc-dhcp-server restart を実行します。

  • service nbd-service restart を実行して新しいNBDファイルを生成します。

17.3. ネットワーク設定の変更

debian-edu-config パッケージには 10.0.0.0/8 から別のネットワークへの変更を支援するツールが付属しています。/usr/share/debian-edu-config/tools/subnet-change をご覧になってください。これは主サーバーインストール直後に使うもので、サブネット変更目的に更新する必要がある LDAP やその他のファイルを調整します。

/!\ 既に Debian Edu により他のどこかで利用されているサブネットへの変更はうまくいかないことに注意してください。192.168.0.0/24 と 192.168.1.0/24 は既に LTSP クライアントネットワーク用に用意されています。この範囲のネットワークに変更した場合は、設定ファイルを手作業で編集して重なった項目を削除する必要があります。

DNSのドメイン名は、簡単には変更できません。ドメイン名の変更には LDAP 構造と主サーバーのファイルシステムにある複数のファイルを変更する必要があります。主サーバーのホスト名とDNS名 (tjener.intern) を簡単に変更する方法もありません。それには LDAP と主サーバーのファイルに加えて、クライアントファイルシステムにも変更が必要となります。どちらの場合も、Kerberos の設定も変更する必要があります。

17.4. LTSP の詳細

17.4.1. LDAP (及び lts.conf) での LTSP クライアントの設定

特定のLTSPクライアントの特定の機能を設定するには、 LDAP に設定を追加するかファイル /opt/ltsp/amd64/etc/lts.conf を編集します。lts.conf を変更するたびに ltsp-update-image を実行しないといけないことに注意してください。lts.conf を /var/lib/tftpboot/ltsp/amd64/ ディレクトリにコピーしていれば、イメージの更新は必要ありません。

/!\ 設定を失う (あるいはやり直す) ことなく LTSP サーバの追加や置き換えが可能なため、LDAP によるクライアント設定を勧めます (つまり lts.conf を直接編集しないということになりますが、LTSP 設定用ウェブフォームは現在 GOsa² では利用できないため、普通の LDAP ブラウザや ldapvi を使って行う必要があります)。

LDAP のデフォルト値は cn=ltspConfigDefault,ou=ltsp,dc=skole,dc=skolelinux,dc=noltspConfig 属性を使って定義されています。LDAP にホスト特有の項目を追加することもできます。

利用可能な設定オプションは man lts.conf を実行してご確認ください (LTSP の詳細情報については /usr/share/doc/ltsp/LTSPManual.html をご覧になってください)。

デフォルト値は [default] ブロックで定義されています。ある1つのクライアントを設定するには [192.168.0.10] のように条件にMACアドレスかIPアドレスを指定します。

例: シンクライアント ltsp010 の画面解像度を 1280x1024 に設定する場合:

[192.168.0.10]
X_MODE_0 = 1280x1024
X_HORZSYNC = "60-70"
X_VERTREFRESH = "59-62"

のような内容をデフォルト設定のどこかに記述します。

ある LTSP クライアントで特定のXサーバの利用を強制するには XSERVER 変数をセットします。例えば:

[192.168.0.11]
XSERVER = nvidia

シンクライアントで画面が真っ黒になってしまう場合、同時発色数を変えると改善するかもしれません。設定例:

[192.168.0.12]
X_COLOR_DEPTH=16

変更の内容や対象によってはクライアントの再起動が必要かもしれません。

lts.conf でIPアドレスを使って設定するには、DHCP サーバにクライアントのMACアドレスを追加する必要があります。そうしない場合は lts.conf ファイルでクライアントのMACアドレスを直接指示してください。

17.4.2. 全てのLTSPクライアントのデスクトップ環境を LXDE を強制する方法

LTSP サーバに LXDE がインストールされていることを確認してください。それから「lts.conf」の [default] に以下の行を追加します:

LDM_SESSION=LXDE
LDM_FORCE_SESSION=true

17.4.3. Desktop autoloader

このツールで、デスクトップ環境(とお好みのプログラム)を事前にロードできます。ディスクレスクライアントでのみ有用です。設定方法は学校毎に異なることになりますし、技術的なハードルもあります。

  • 詳細については、次のコマンドでご確認ください: ltsp-chroot cat /usr/share/doc/desktop-autoloader/README.Debian

最低限2つのファイルを編集する必要がありますが、利用できる<エディター>の選択肢は「vi」「nano」「mcedit」になります。

  • ltsp-chroot <エディター> /etc/cron.d/desktop-autoloader を実行

  • ltsp-chroot <エディター> /etc/default/desktop-autoloader を実行

設定が終わったら、 NBDイメージをltsp-update-image 実行して更新し、テストしてください。

17.4.4. LTSP サーバ群の負荷分散

17.4.4.1. 第一段階

負荷分散のために、クライアントが複数の LTSP サーバの中の一つに接続するよう設定することもできます。 LDM の接続先サーバ一覧を出力するスクリプト /opt/ltsp/amd64/usr/share/ltsp/get_hosts を利用して、更に各 LTSP chroot 環境に各LTSPサーバーのSSHホスト鍵を導入する必要があります。

まず、負荷分散用サーバにする LTSP サーバを1台選ばないといけません。クライアントは全てこのサーバから PXE ブートし、Skolelinux イメージを読み込みます。イメージを読み込むと LDM が「get_hosts」スクリプトを使って接続先サーバを選択します。その方法については後から決められます。

負荷分散用サーバーは DHCP 経由で「next-server」としてクライアントに通知しないといけません。DHCP の設定は LDAP に置かれているため、変更も LDAP で行わないといけません。ldapvi --ldap-conf -ZD '(cn=admin)' を使って LDAP の適切な項目を編集します (プロンプトで主サーバーの root パスワードを入力します。VISUAL がセットされていない場合のデフォルトのエディタは nano です)。dhcpStatements: next-server tjener のような行を検索します。負荷分散用に選択したサーバーのIPアドレスかホスト名を next-server にセットします。ホスト名を使う場合はDNS機能も必要です。DHCP サービスの再起動も忘れずに行ってください。

この段階で 192.168.0.0 のネットワークから 10.0.0.0 のネットワークにクライアントを移動しないといけません。LTSP サーバの2つ目のネットワークカードが接続しているネットワークでに代えてバックボーンのネットワークに接続します。これは負荷分散のためには LDM が選択したサーバにクライアントが直接アクセスする必要があるためです。クライアントを 192.168.0.0 のネットワークに置いたままだと、そのクライアントの通信は選択した LDM サーバに届く前にそのサーバを経由することになります。

17.4.4.2. 第二段階

LDM が接続するサーバの一覧を出力する「get_hosts」スクリプトを作らないといけません。パラメータ LDM_SERVER はこのスクリプトより優先されるため、「get_hosts」スクリプトを使う場合はこのパラメータが定義されていてはいけません。「get_hosts」スクリプトは各サーバのIPアドレスやホスト名を順不同で標準出力に書き出します。

「/opt/ltsp/amd64/etc/lts.conf」を編集して次のような項目を追加:

MY_SERVER_LIST = "xxxx xxxx xxxx"

「xxxx」はサーバーのIPアドレスやホスト名の一覧を「スペース」で区切ったものに置き換えてください。その後、負荷分散用サーバーの /opt/ltsp/amd64/usr/lib/ltsp/get_hosts スクリプトとして、以下のものを配置します。

 #!/bin/bash
 # Randomise the server list contained in MY_SERVER_LIST parameter
 TMP_LIST=""
 SHUFFLED_LIST=""
 for i in $MY_SERVER_LIST; do
     rank=$RANDOM
     let "rank %= 100"
     TMP_LIST="$TMP_LIST\n${rank}_$i"
 done
 TMP_LIST=$(echo -e $TMP_LIST | sort)
 for i in $TMP_LIST; do
     SHUFFLED_LIST="$SHUFFLED_LIST $(echo $i | cut -d_ -f2)"
 done
 echo $SHUFFLED_LIST
17.4.4.3. 第三段階

「get_hosts」スクリプトが出来上がり、今度は LTSP chroot 環境のSSHホスト鍵を作成します。負荷分散用に利用する全 LTSP サーバーの /opt/ltsp/amd64/etc/ssh/ssh_known_hosts の内容を収録するファイルをまず作成します。そのファイルを負荷分散用の全サーバーの /etc/ltsp/ssh_known_hosts.extra として保存します。この最後の段階は非常に重要です。ltsp-update-sshkeys がサーバーのブート時に毎回実行される際、/etc/ltsp/ssh_known_hosts.extra が存在すれば取り込まれるためです。

/!\ 新しいホストファイルを /opt/ltsp/amd64/etc/ssh/ssh_known_hosts に保存した場合は、サーバーが再起動した時点で消去されてしいます。

この方法には明らかな弱点がいくつかあります。クライアントは全てイメージを同一のサーバから取得するため、多数のクライアントが同時に起動するとそのサーバは高負荷になります。また、クライアントにとってはそのサーバを常に利用できるということが要求されます。このサーバが利用できない場合、起動や LDM サーバの取得ができなくなります。そのため、この方法は1つのサーバに非常に大きく依存するもので、あまり良い方法ではありません。

クライアントはこれで負荷分散するはずです!

17.4.5. LTSP クライアントのオーディオ

LTSPシンクライアントはネットワークオーディオを利用してサーバーからクライアントにオーディオを配信します。

LTSP ディスクレスワークステーションは音声をローカルで扱います。

17.4.6. LTSP クライアントに接続されたプリンターの利用

  • LTSP クライアントマシンにプリンターを接続します (USBとパラレルポートをサポートしています)。

  • そのマシンでプリンターを使うように lts.conf を設定します。デフォルトファイルは /opt/ltsp/amd64/etc/lts.confにあります。詳細は LTSP マニュアル /usr/share/doc/ltsp/LTSPManual.html#printer 参照してください。

  • 主サーバーのウェブインターフェイス https://www:631 からプリンターを設定します。ネットワークプリンターの (ブランドや型を問わず) AppSocket/HP JetDirect を選択して接続URIに socket://<LTSP クライアントのIPアドレス>:9100 をセットします。

17.4.7. NBDの代わりにNFSを使う方法

スピード向上目的やテスト環境用に、LTSP chroot NFS も利用できます。

# NBDからNFSへの変更方法
sed -i 's/default ltsp-NBD/default ltsp-NFS' /opt/ltsp/$(dpkg --print-architecture)/boot/pxelinux.cfg/ltsp
sed -i 's/ontimeout ltsp-NBD/ontimeout ltsp-NFS/' /opt/ltsp/$(dpkg --print-architecture)/boot/pxelinux.cfg/ltsp
ltsp-update-kernels
# NFSからNBDへの変更方法:
ltsp-update-image 
sed -i 's/default ltsp-NFS/default ltsp-NBD' /opt/ltsp/$(dpkg --print-architecture)/boot/pxelinux.cfg/ltsp
sed -i 's/ontimeout ltsp-NFS/ontimeout ltsp-NBD/' /opt/ltsp/$(dpkg --print-architecture)/boot/pxelinux.cfg/ltsp
ltsp-update-kernels

17.4.8. LTSP 環境のアップグレード

新しいパッケージで LTSP 環境を頻繁にアップグレードし、セキュリティ修正や改善を確実に利用できるようにするのは有益です。アップグレードは各 LTSP サーバで以下のコマンド root で実行します:

ltsp-chroot -a amd64  # これは "chroot /opt/ltsp/amd64" などを実行します。各種デーモンの起動も防ぎます。
apt update
apt upgrade
apt full-upgrade
exit
ltsp-update-image
17.4.8.1. LTSP 環境への追加ソフトウェアのインストール

LTSP クライアント用のソフトウェアを追加でインストールするには LTSP サーバの chroot 内でインストールを行う必要があります。

ltsp-chroot -a amd64
## 必要に応じて sources.list を編集します:
#editor /etc/apt/sources.list
apt update
apt install $new_package
exit
ltsp-update-image

17.4.9. ログイン遅延とセキュリティ

Skolelinux ではクライアントネットワークにセキュリティ機能を複数追加し、認めていないスーパーユーザーアクセスやパスワードの盗聴、その他ローカルネットワークで利用される工作を回避するようにしています。こういったセキュリティ対策の1つにSSHを使用した安全なログインがあり、LDM のデフォルトで利用するようになっています。そのためにプロセッサが 160MHz、RAM容量が32MBに満たないような、15年以上前のクライアントマシンでは処理が遅くなるでしょう。おすすめはしませんが、当該サーバーの /opt/ltsp/amd64/etc/lts.conf ファイルに設定を追加することでSSHを使わないようにもできます:

LDM_DIRECTX=True

/!\ 警告: 上記では最初のログインは保護されますが、その後は全て暗号化されない状態でXの通信が行われます。パスワードも (最初だけ例外ですが) 他の全てと同様に平文のままネットワークを流れます。

注意: こういった15年落ちのシンクライアントでは pixmap キャッシュの問題のため LibreOffice や Firefox の新しいバージョンの実行は困難かもしれません。利用するシンクライアントをRAM容量が最低でも128MB搭載されているものにするかハードウェアのアップグレードを検討するといいかもしれません。そうするとディスクレスワークステーションとしても利用できるという利点があります。

17.5. ネットワークへの Windows マシンの接続 / Windows との統合

17.5.1. ドメインへの参加

Windows クライアント向けには Windows ドメイン「SKOLELINUX」に参加できるようになっています。主サーバーにはSamba サービスがインストールされているので、Windows クライアントはプロファイルやユーザーデータを保管できます。ログイン時のユーザー認証も行います。

/!\ Windows クライアントによるドメインへの参加には Debian Edu Buster Samba Howto で説明している手順で操作する必要があります。

Windows はドメインユーザーのプロファイルを Windows へのログインやログアウトの度に同期します。プロファイルに保管されているデータの量によっては時間を要します。時間短縮したい場合は、ブラウザのローカルキャッシュなどを無効化 (主サーバーにインストールした Squid プロキシキャッシュが代わりに使えます) して、ファイルを 「マイ ドキュメント」や「ドキュメント」ではなく H: ボリュームに保存します。

17.6. リモートデスクトップ

「LTSPサーバー」プロファイルや複合サーバープロファイルは、xrdpx2goserver パッケージもインストールします。

17.6.1. Xrdp

Xrdpパッケージは RDP (Remote Desktop Protocol) を利用して、リモートクライアントにグラフィカルなログイン画面を提供します。Microsoft Windows のユーザーは追加ソフトウェアをインストールすることなく xrdp の動作している LTSP サーバーに接続できます。 Windows マシンから Remote Desktop Connection を起動して接続するだけです。

さらに、xrdp は VNC サーバやその他の RDP サーバに接続できます。

素の Xrdp には音声サポートがありません。必要なモジュールをコンパイルする場合は、次のスクリプトを使ってください。

 #!/bin/bash
 # xrdp PulseAudio モジュールのコンパイル用スクリプトです。
 # root か sudo グループのユーザーで実行する必要があります。
 # /etc/apt/sources.list にdeb-src設定も必要です。
 set -e
  if [[ $UID -ne 0 ]] ; then  
     if ! groups | egrep -q sudo ; then
         echo "ERROR: You need to be root or a sudo group member."
         exit 1
     fi
 fi
 if ! egrep -q  ^deb-src /etc/apt/sources.list ; then
     echo "ERROR: Make sure /etc/apt/sources.list contains a deb-src line."
     exit 1
 fi
 TMP=$(mktemp -d)
 PULSE_UPSTREAM_VERSION="$(dpkg-query -W -f='${source:Upstream-Version}' pulseaudio)"
 XRDP_UPSTREAM_VERSION="$(dpkg-query -W -f='${source:Upstream-Version}' xrdp)"
 sudo apt -q update
 # ソースとビルド依存パッケージの入手:
 sudo apt -q install dpkg-dev
 cd $TMP
 apt -q source pulseaudio xrdp
 sudo apt -q build-dep pulseaudio xrdp
 # pulseaudio で 'configure' を実行する:
 cd pulseaudio-$PULSE_UPSTREAM_VERSION/
 ./configure
 # pulseaudio モジュールの Makefile の調整(絶対パスが必要です)と、
 # pulseaudio モジュールのビルド。
 cd $TMP/xrdp-$XRDP_UPSTREAM_VERSION/sesman/chansrv/pulse/
 sed -i 's/^PULSE/#PULSE/' Makefile
 sed -i "/#PULSE_DIR/a \
 PULSE_DIR = $TMP/pulseaudio-$PULSE_UPSTREAM_VERSION" Makefile
 make
 # モジュールを Pulseaudio モジュールディレクトリにコピーしてアクセス権を調整。
 sudo cp *.so /usr/lib/pulse-$PULSE_UPSTREAM_VERSION/modules/
 sudo chmod 644 /usr/lib/pulse-$PULSE_UPSTREAM_VERSION/modules/module-xrdp*
 # xrdpを再起動すれば、音声が有効化されます。
 sudo service xrdp restart

17.6.2. X2Go

X2GoはLTSPサーバーへのGUIデスクトップアクセスソフトです。回線容量の高低のいずれの場合にも対応しています。接続元としてはLinuxが動作しているPC、Windows、macOSが使えます。ただしクライアント側でソフトの追加が必要になりますので、X2Go wiki をご覧になってください。

注意点として、X2Goを利用する場合には、LTSPサーバーからkillerパッケージを削除すべきです。Debianバグ報告サイトで890517 をご覧になってください。

17.6.3. 利用できるリモートデスクトップクライアント

  • freerdp-x11 はデフォルトでインストールされ、RDP と VNC の機能を持っています。

    • RDP - Windows ターミナルサーバにアクセスする最も簡単な方法です。代替クライアントのパッケージには rdesktop があります。

    • VNC (Virtual Network Computer、仮想ネットワークコンピュータ) クライアントはリモートから Skolelinux にアクセスする手段を提供します。代替クライアントのパッケージには xvncviewer があります。

  • x2goclient はX2Goシステム用のGUIクライアントです(デフォルトではインストールされません)。 既存のセッションへの接続と新しいセッションの接続に使えます。

  • Citrix ICA クライアント HowTo にSkolelinux から Windows ターミナルサーバーにアクセスするための記載があります。

18. Debian Edu の Samba

/!\ この章を進める前に、Samba wikiで対応しているWindowsのバージョン、必要なレジストリ操作、その他の設定について、必ずご確認ください。

https://wiki.samba.org/index.php/Joining_a_Windows_Client_or_Server_to_a_Domain

https://wiki.samba.org/index.php/Required_Settings_for_Samba_NT4_Domains

Samba は NT4 形式のドメインコントローラーとして完全に使えるように開発されています。マシンをドメインに参加させた後は、そのマシンは GOsa² で完全に管理できるようになります。

18.1. さあ始めよう

この文書では読者への前提条件がいくつかあります。 まずDebian Edu の主サーバーやDebian Edu ワークステーションのインストール経験があること。 Debian Edu ワークステーションにログインして利用できるユーザーを既に作成した経験があること。 そして、手元に Windows XP/Vista/7 ワークステーションがあり、Windows マシンから Debian Edu の主サーバーへのアクセスをテストできることです。

Debian Edu 主サーバーのインストール後、Samba ホスト \\TJENER が Windows ネットワークコンピュータとして表示されるはずです。Debian Edu の Windows ドメインは SKOLELINUX です。Windows マシン (または smbclient を使っている Linux システム) で Windows/Samba ネットワーク環境の状態を確認してください。

  1. スタート -> ファイル名を指定して実行

  2. \\TJENER と入力して[Enter]を押します

  3. そうすると Windows Explorer のウィンドウが出てきて \\TJENER のネットログオン共有と、印刷用に設定済みのプリンターがあれば Unix/Linux (CUPS キュー) 以下に表示されるはずです。

18.1.1. ファイルへの Samba 経由のアクセス

GOsa² 経由で設定した生徒や教員のユーザーアカウントは、 \\TJENER\HOMES か \\TJENER\<ユーザ名> での認証でき、自分のホームディレクトリにアクセスできます。(Windowsネットワークの意味での)SKOLELINUX ドメインに参加していない Windows マシンからでも可能です。

  1. スタート -> ファイル名を指定して実行

  2. \\TJENER\HOMES または \\TJENER\<ユーザ名> と入力して[Enter]を押します

  3. 出てきた認証ダイアログのウィンドウでログイン資格情報 (ユーザ名、パスワード) を入力します

  4. そうすると Windows Explorer のウィンドウが出てきて Debian Edu のホームディレクトリにあるファイルやディレクトリが表示されるはずです。

デフォルトでは「ホーム」と「ネットログオン」共有だけがエクスポートされます。生徒と教員の詳細な例が Debian Edu の主サーバーの /etc/samba/smb-debian-edu.conf にあります。

18.2. ドメインメンバー権

主サーバーの Samba をドメインコントローラーとして利用するには、ネットワークの Windows ワークステーションを Debian Edu の主サーバーが提供する SKOLELINUX ドメインに参加させる必要があります。

まず SKOLELINUX\Administrator アカウントの有効化を最初に行います。このアカウントは日々の使用を対象とするものではありません。主な目的は SKOLELINUX ドメインに Windows マシンを追加することです。このアカウントを有効化するには主サーバーに「最初のユーザ」 (主サーバーのインストール時に作成したもの) でログインして、このコマンドを実行します:

  • $ sudo smbpasswd -e Administrator

SKOLELINUX\Administrator のパスワードは、主サーバーのインストール時にすでに設定されています。SKOLELINUX\Administrator の認証にはそのシステムの root アカウントを使ってください。

管理作業を終えたら必ず SKOLELINUX\Administrator アカウントを再び無効化してください:

  • $ sudo smbpasswd -d Administrator

18.2.1. Windows のホスト名

Windows マシンの名前が SKOLELINUX ドメインで使いたい名前になっていることを確認してください。違っている場合はまず変更して (再起動もして) ください。Windows マシンの NetBIOS ホスト名はその後 GOsa² で利用され、(このマシンのドメインメンバー権を壊さず) それを変更することはできません。

18.3. ドメインへの最初のログオン

Debian Edu ships では最初のログオン時に Windows ユーザプロファイルを先んじて設定するログオンスクリプトをいくらか用意しています。SKOLELINUX ドメインに参加した Windows ワークステーションに初めてログオンしてときには以下のタスクが実行されます:

  1. そのユーザの Firefox プロファイルを別の場所にコピーして Windows の Mozilla Firefox に登録します

  2. Firefox のウェブプロキシとスタートページを設定します

  3. IE のウェブプロキシとスタートページを設定します

  4. MyHome アイコンをデスクトップに追加。ダブルクリックするとエクスプローラーで H: ドライブを開きます

他のタスクはログインごとに実行されます。詳細な情報については Debian Edu の主サーバーの /etc/samba/netlogon を参照してください。

19. クラスルーム HowTo

この節で説明している Debian パッケージは全て (root で) apt install <パッケージ> を実行することでインストールできます。

19.1. プログラミングを教える

stable/education-development は無数のプログラミングソフトをインストールするためのメタパッケージです。ディスク空き容量として2GBは必要になることを前提としてください。詳細については (あるいは一部のパッケージのみをインストールしたい場合などは), Debian Edu Development packages をご覧ください。

19.2. 生徒の監視

/!\ 警告: 自分の管轄する領域でコンピュータユーザの活動を監視、制限することに関する法の見解を必ず確認してください。

生徒の監視に EpoptesVeyon を使っている学校もあります。詳細は Epoptes HomepageVeyon Homepage をご覧になってください。

Epoptes の機能を完全に使うには、次の手順が必要になります。

# 複合サーバー上 (と追加した各LTSPサーバー上で)実行:
apt update
apt install epoptes
ltsp-chroot -m --arch amd64 apt update
ltsp-chroot -m --arch amd64 apt install epoptes-client
ltsp-chroot -m --arch amd64 apt install ssvnc
ltsp-chroot -m --arch amd64 sed -i 's/test -f/#test -f/' /etc/init.d/epoptes-client 
ltsp-chroot -m --arch amd64 sed -i 's/grep -qs/#grep -qs/' /etc/init.d/epoptes-client 
# ディスク容量が問題になる場合は 'ltsp-update-image -n' を実行してください.
ltsp-update-image

19.3. 生徒のネットワークアクセスの制限

学校によっては SquidguardDansguardian を使ってインターネットへのアクセスを制限しています。

20. ユーザ向け HowTo

20.1. パスワード変更

全ユーザがパスワードの変更に GOsa² を使うべきです。そのためには単にブラウザを使って https://www/gosa/ にアクセスします。

GOsa² を使ってパスワードを変更することで Kerberos (krbPrincipalKey)、LDAP (userPassword)、Samba (sambaNTPassword 及び sambaLMPassword) のパスワードの一貫性を確保できます。

PAM 側 GDM ログインプロンプトでのパスワード変更もできますが、その場合 Kerberos パスワードだけが更新され、Samba と GOsa² (LDAP) のパスワードは以前のままです。そのため、ログインプロンプトでパスワードを変更した場合は GOsa² での変更も実際に行うようにしてください。

20.2. Java

20.2.1. 単体 Java アプリケーションの実行

単体 Java アプリケーションは OpenJDK Java ランタイムによりそのままでサポートしています。

20.3. メールの利用

ユーザーは学校内ネットワーク内では全員が電子メールの送受信ができます。セキュリティのためTLSで接続されますし、そのためのデジタル証明証も提供されます。学内ネットワークの外へも電子メールを許可する場合は、管理者はexim4 メールサーバーを適切な設定をする必要があります。その際はdpkg-reconfigure exim4-config の実行からまず行ってください。

Thunderbird を使いたいユーザは以下のように設定する必要があります。ユーザ名が jdoe のユーザの内部メールアドレスは jdoe@postoffice.intern となります。

20.3.1. Thunderbird

  • Thunderbird を起動します

  • 「これをスキップし、既存のメールを使用する」をクリックします

  • メールアドレスを入力します

  • Kerberos のシングルサインオンを利用するためパスワードは入力しないようにしてください

  • 「続ける」をクリックします

  • IMAP でも SMTP でも設定では「STARTTLS」と「Kerberos/GSSAPI」を選択します。自動的に検出されない場合は調整してください。

  • 「完了」をクリックします

20.3.2. ディスクレスワークステーションでメールを読むための Kerberos 資格情報の取得

ディスクレスワークステーションでの作業ではデフォルトで Kerberos TGT (発見許可証) がありません。取得するにはシステムトレイの資格情報ボタンをクリックします。自分のパスワードを入力すると受け付けられます。

20.4. 音量調整

シンクライアントでは pavucontrolalsamixer (kmix は使えません) を使って音量を変更できます。

他のマシン (ワークステーション、LTSP サーバ、ディスクレスワークステーション) では kmixalsamixer を利用できます。

21. 貢献

21.1. 地域での貢献

現在、地域のチームはノルウェー、ドイツ、スペインのエクストレマドゥーラ地方、台湾、フランスにあります。「単独の」貢献者やユーザはギリシャ、オランダ、日本その他にいます。

サポートの章に地域対応に関する説明があります。 貢献の章サポートの章はコインの両面のような関係になっています。

21.2. 国際的な貢献

私たちの国際的なチームで、色々なチームが様々なプロジェクトを担っています.

Debian Edu開発者のメーリングリストが主なコミュニケーション手段で、他にも毎月 irc.debian.org の #debian-edu チャンネルでIRCでの会議もしています。稀ですが、時には実際に会って対話することもあります。新たに貢献しようと思ってくださる方は、まず http://wiki.debian.org/DebianEdu/ArchivePolicy をご覧になってください。

Debian Eduの開発状況などを知るには、debian-edu-commisメーリングリストに参加していただくのがよいでしょう。

21.3. 文書の著者及び翻訳者

この文書には支援が必要です! 最も重要なのはまだ完成していないということです: 読んでみると文中に FIXME がいくつもあることがわかるでしょう。説明する必要があるのは何なのか (少しでも) わかってしまったなら、知識の共有を検討してください。

この文書の元になっているのは wiki なので、ウェブブラウザで簡単に編集できます。http://wiki.debian.org/DebianEdu/Documentation/Buster/ で簡単に貢献できます。ただし、ページを編集するにはユーザーアカウントが必要です。まず wiki ユーザーを作成してください。

ユーザを支援するための、とても良い別の貢献方法はソフトウェア及び文書の翻訳です。この文書の翻訳方法についての情報はこの本の 翻訳の章にあります。この本の翻訳の取り組みへの支援を検討してください!

22. サポート

22.1. ボランティアベースのサポート

22.1.1. 英語

22.1.2. ノルウェー語

22.1.3. ドイツ語

22.1.4. フランス語

22.2. 商業的なプロのサポート

商業的なプロフェッショナルによるサポートをしている会社などのリストはhttp://wiki.debian.org/DebianEdu/Help/ProfessionalHelpにあります。

23. Debian Edu Buster の新機能

23.1. Debian Edu 10+edu0 コード名 Buster の新機能

23.1.1. インストールの変更

  • 今回のリリースはhttps://cdimage.debian.orgでインストールイメージが提供される初めてのものです。つまりDebian公式のイメージです。

  • Debian Busterの新しいのインストーラーについてはDebian Buster インストールマニュアルをご覧になってください。

  • 新しいアートワークはfuturePrototype themeになりました。Debian 10 Busterのデフォルトのものです。

  • 新しいデフォルトのデスクトップ環境はXfceになりました(KDEからの変更です)。

  • CFEngineによる設定管理も新しくなりました。メンテナンスが終了した cfengine2 からcfengine3 に変更されています。これは重要な変更点になります。詳細について CFEngine公式文書をご一読ください。

  • LTSP chroot環境のアーキテクチャーはサーバー側のアーキテクチャーが標準になりました。

23.1.2. ソフトウェアの更新

  • Debian 10 Busterで一新されたものは、例えば以下のものです:

    • Linux カーネル 4.19

    • デスクトップ環境 KDE Plasma Workspace 5.14、GNOME 3.22、Xfce 4.12、LXDE 0.53、MATE 1.20

    • Firefox 60.5 ESR 、 Chromium 72.0

    • LibreOffice 6.1

    • 教育用ツール集 GCompris 0.95

    • 音楽作成ツール Rosegarden 18.12

    • GOsa 2.74

    • LTSP 5.18

    • Debian Buster では 57,000 以上ものパッケージが利用できます。

23.1.3. 文書や翻訳の更新

  • インストーラで使われるテンプレートの翻訳の更新については、76ヶ国語もあり、31ヵ国語は完全に翻訳されています。プロフィール選択ページについては29カ国語が利用でき、19カ国語が完全な翻訳になっています。

  • Debian Edu Buster のマニュアルはフランス語、ドイツ語、イタリア語、デンマーク語、オランダ語、ノルウェー語 (ブークモール) 、そして日本語に翻訳されています。

    • 部分的な翻訳版は、ポーランド語、スペイン語、中国語(簡体字)、中国語(繁体字)で提供されています。

23.1.4. 前のリリースからの他の変更点

  • BD ISOイメージではオフラインでのインストールが再度可能になりました。

  • 新しい学校教育レベルのメタパッケージとして education-preschooleducation-primaryschooleducation-secondaryschool、そしてeducation-highschoolが利用できるようになりました。ただしデフォルトではインストールされません。

  • 幼児教育や小学校レベルのパッケージの一部は、デフォルトでインストールされないことになりました。 gcompris-qtchildsplaytuxpainttuxmath)などです。

  • 学校ごとに合わせたインストールが可能になりました。必要な教育向けパッケージのみをインストールすることができるようになっています。詳細は個別インストール の章をご覧になってください。

  • 学校ごとに合わせた多国語サポートがされるようになりました。詳細については多言語デスクトップ環境の章をご覧になってください。

  • 新たなデスクトップ環境の選択肢としてLXQt 0.14が導入されました。

  • GOsa²の新しいプラグインとして パスワード管理が追加されました。

  • 利用できないオプションをGOsa²ウェブインターフェイスから外しました。

  • shut-down-at-night-hosts netgroup が追加され、属しているシステムが起動されてしまうのを防ぐことができます。

  • 新たにStandardskriverが追加されました (printerのデフォルトです)。詳細はStandardskriver の章をご覧ください。

  • 新たに desktop-autoloader が追加され、LTSPディスクレスクライアントのパフォーマンス改善が図れます。詳細は Desktop autoloader の章をご覧ください。

  • ネットワーク内のTLS/SSLが改善されています。ルートCA証明証がサーバー証明証の署名に使われることになり、ユーザーホームディレクトリはアカウント生成時に設定されます。Firefox ESR、Chronium、それとKonquerorはHTTPSを使うことになり、安全でない通信を許容する必要がなくなりました。

  • Kerberos対応SSHになりました。ネットワーク内部ではもうパスワードを入力する必要がありません。root はkinitを実行して有効化する必要はあります。

  • Kerberos対応NFSになりました。ホームディレクトリアクセスはより安全になります。Kerberos対応NFSの章で説明しています。

  • 学校ごとの変更を容易にするため、サンプル付きの設定ファイル/etc/debian-edu/pxeinstall.conf が追加されました。

  • 学校ごとの変更を容易にするための /etc/ltsp/ltsp-build-client.conf 設定ファイルがサンプル例付きで追加されました。

  • 新しく /usr/share/debian-edu-config/tools/edu-ldap-from-scratch が追加されました。主サーバーのインストール直後に LDAP データベースを再生成できます。 学校ごとの変更もより容易にできます。

  • Debian本体で X2Go server が利用可能になり、「 LTSP-Server」プロファイルの全てのシステムで関連するパッケージがインストールされることになりました。

  • Firefox ESRでのJavaアプレットの動作に関しては、アップストリームでもはやサポートされないことになりました。

  • Firefox ESRでの non-free な Adobe Flash のサポートは打ち切られています。

  • Stretch以前と同様に、Debian 10は unattended-upgrades パッケージをデフォルトではインストールしません。セキュリティ更新については ソフトウェアの更新 の章をご確認ください。

23.1.5. 既知の問題

24. 著作権と著者

この文書は以下の方々により執筆され、著作権の対象となっています。Holger Levsen (2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019)、 Petter Reinholdtsen (2001, 2002, 2003, 2004, 2007, 2008, 2009, 2010, 2012, 2014)、Daniel Heß (2007)、Patrick Winnertz (2007)、Knut Yrvin (2007)、Ralf Gesellensetter (2007)、Ronny Aasen (2007)、Morten Werner Forsbring (2007)、Bjarne Nielsen (2007, 2008)、Nigel Barker (2007)、José L. Redrejo Rodríguez (2007)、John Bildoy (2007)、Joakim Seeberg (2008)、Jürgen Leibner (2009, 2010, 2011, 2012, 2014)、Oded Naveh (2009)、Philipp Hübner (2009, 2010)、Andreas Mundt (2010)、Olivier Vitrat (2010, 2012)、Vagrant Cascadian (2010)、Mike Gabriel (2011)、Justin B Rye (2012)、David Prévot (2012)、Wolfgang Schweer (2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019)、Bernhard Hammes (2012)、Joe Hansen (2015)。GPL2とそれ以降のバージョンでライセンスされています。

追加する内容は自分で書いたものだけにしてください。同一条件の下でリリースする必要があります! それから自分の名前を追加し、「v2 以降の任意のバージョンのGPL」ライセンスの下でリリースしてください。

25. 翻訳の著作権と著者

スペイン語の翻訳はJosé L. Redrejo Rodríguez (2007)、Rafael Rivas (2009, 2010, 2011, 2012, 2015)、(2010, 2012, 2013)に著作権があり、GPL v2とそれ以降のバージョンでライセンスされいます。

ノルウェー語 (Bokmål) の翻訳は、Petter Reinholdtsen (2007, 2012, 2014, 2015, 2016, 2017, 2018, 2019)、Håvard Korsvoll (2007-2009)、Tore Skogly (2008)、Ole-Anders Andreassen (2010)、Jan Roar Rød (2010)、Ole-Erik Yrvin (2014, 2016, 2017)、Ingrid Yrvin (2014, 2015, 2016, 2017)、Hans Arthur Kielland Aanesen (2014)、Knut Yrvin (2014)、FourFire Le'bard (2014)、Stefan Mitchell-Lauridsen (2014)、Ragnar Wisløff (2014)、Allan Nordhøy (2018, 2019)に著作権があり、GPLv2以降のライセンスで提供されています。

ドイツ語翻訳版は、Holger Levsen (2007)、Patrick Winnertz (2007)、Ralf Gesellensetter (2007, 2009)、Roland F. Teichert (2007, 2008, 2009)、Jürgen Leibner (2007, 2009, 2011, 2014)、Ludger Sicking (2008, 2010)、Kai Hatje (2008)、Kurt Gramlich (2009)、Franziska Teichert (2009)、Philipp Hübner (2009)、Andreas Mundt (2009, 2010)、Wolfgang Schweer (2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019)に著作権があり、GPL v2以降のライセンスで提供されています。

イタリア語の翻訳版はClaudio Carboncini (2007, 2008, 2009, 2010, 2011, 2012, 2013, 2014, 2015, 2016, 2017, 2018, 2019)とBeatrice Torracca (2013, 2014)に著作権があり、GPL v2以降のライセンスで提供されています。

フランス語の翻訳版はChristophe Masson (2008)、Olivier Vitrat (2010)、Cédric Boutillier (2012, 2013, 2014, 2015)、Jean-Paul Guilloneau (2012)、David Prévot (2012)、Thomas Vincent (2012)、Jean-Pierre Giraud (2019)、French l10n team (2009, 2010, 2012, 2019)に著作権があり、GPL v2以降のライセンスで提供されています。

The Danish translation is copyrighted by Joe Hansen (2012, 2013, 2014, 2015, 2016, 2019) and is released under the GPL v2 or any later version.

The Dutch translation is copyrighted by Frans Spiesschaert (2014, 2015, 2016, 2017, 2018, 2019) and is released under the GPL v2 or any later version.

The Japanese translation is copyrighted by victory (2016, 2017) and hoxp18 (2019) and is released under the GPL v2 or any later version.

The Polish translation is copyrighted by Stanisław Krukowski (2016, 2017) and Wiktor Wandachowicz (2019) and is released under the GPL v2 or any later version.

The Simplified Chinese translation is copyrighted by Ma Yong (2016, 2017, 2018, 2019), Boyuan Yang (2017), Roy Zhang (2017) and is released under the GPL v2 or any later version.

The Traditional Chinese translation is copyrighted by Louies (2019) and is released under the GPL v2 or any later version.

26. この文書の翻訳

Versions of this document translated into German, Italian, French, Danish, Dutch, Norwegian Bokmål and Japanese are available. Incomplete translations exist for Spanish, Polish and Simplified Chinese. There is an online overview of shipped translations.

26.1. この文書の翻訳方法

26.1.1. POファイルを使った翻訳

As in many free software projects, translations of this document are kept in PO files. More information about the process can be found in /usr/share/doc/debian-edu-doc/README.debian-edu-buster-manual-translations. The Git repository (see below) contains this file too. Take a look there and at the language specific conventions if you want to help translating this document.

To commit your translations you need to be a member of the Salsa project debian-edu.

を追加し、ssh 経由で debian-edu-doc ソースを取得します: git clone git@salsa.debian.org:debian-edu/debian-edu-doc.git

翻訳したいだけなら Git から取得 (匿名で取得できます) する必要があるのは一部のファイルだけです。その場合、debian-edu-doc パッケージに対してバグ報告し、PO ファイルをそのバグ報告に添付してください。バグ報告方法についての指示がいくらかあります

以下のコマンドで debian-edu-doc のソースを匿名で取得できます (これには git パッケージをインストールしている必要があります):

  • git clone https://salsa.debian.org/debian-edu/debian-edu-doc.git

それからファイル documentation/debian-edu-buster/debian-edu-buster-manual.$CC.po ($CC は翻訳する言語のコードに置き換え) を編集します。翻訳に利用できるツールは多数あります。私たちは lokalize の使用を勧めます。

それから翻訳したファイルを Git に直接 (権限があれば) 送るか、バグ報告にファイルを添付します。

リポジトリのローカルコピーの更新には debian-edu-doc ディレクトリで次のコマンドを実行します:

  • git pull

を実行します。翻訳する言語がない場合に新しいPOファイルを作成する方法や翻訳を更新する方法等の情報は /usr/share/doc/debian-edu-doc/README.debian-edu-buster-manual-translations を読んでください。

ご注意:この文書自体はまだ開発途上です。FIXMEの項目は翻訳しないでください。

Salsa (Gitリポジトリが置かれているホスト) やGitについての基本的な情報は https://wiki.debian.org/Salsa にあります。

Gitを使ったことがない方は Pro Git をご覧ください。recording changes to the repositoryの章があります。GUIでGitを利用する場合はgitk パッケージを参照してください。

26.1.2. ウェブブラウザを使ったオンラインでの翻訳

言語チームによっては Weblate 経由で翻訳している場合があります。さらなる情報については https://hosted.weblate.org/projects/debian-edu-documentation/debian-edu-buster/ を見てください。

何か問題があれば報告してください。

27. 付録A - GNU General Public License

翻訳者の方へ: GPLライセンス条文の翻訳の必要はありません。正式な翻訳文が https://www.gnu.org/licenses/old-licenses/gpl-2.0-translations.html で提供されています。 

27.1. Debian Edu 10+edu0 コード名 Buster のマニュアル

Copyright (C) 2007-2018 Holger Levsen < holger@layer-acht.org > 著作権の章 に完全な著作権保有者のリストがあります。

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

27.2. GNU GENERAL PUBLIC LICENSE

Version 2, June 1991

Copyright (C) 1989, 1991 Free Software Foundation, Inc. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed.

27.3. TERMS AND CONDITIONS FOR COPYING, DISTRIBUTION AND MODIFICATION

0. This License applies to any program or other work which contains a notice placed by the copyright holder saying it may be distributed under the terms of this General Public License. The "Program", below, refers to any such program or work, and a "work based on the Program" means either the Program or any derivative work under copyright law: that is to say, a work containing the Program or a portion of it, either verbatim or with modifications and/or translated into another language. (Hereinafter, translation is included without limitation in the term "modification".) Each licensee is addressed as "you".

Activities other than copying, distribution and modification are not covered by this License; they are outside its scope. The act of running the Program is not restricted, and the output from the Program is covered only if its contents constitute a work based on the Program (independent of having been made by running the Program). Whether that is true depends on what the Program does.

1. You may copy and distribute verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice and disclaimer of warranty; keep intact all the notices that refer to this License and to the absence of any warranty; and give any other recipients of the Program a copy of this License along with the Program.

You may charge a fee for the physical act of transferring a copy, and you may at your option offer warranty protection in exchange for a fee.

2. You may modify your copy or copies of the Program or any portion of it, thus forming a work based on the Program, and copy and distribute such modifications or work under the terms of Section 1 above, provided that you also meet all of these conditions:

  • a) You must cause the modified files to carry prominent notices stating that you changed the files and the date of any change.

    b) You must cause any work that you distribute or publish, that in whole or in part contains or is derived from the Program or any part thereof, to be licensed as a whole at no charge to all third parties under the terms of this License.

    c) If the modified program normally reads commands interactively when run, you must cause it, when started running for such interactive use in the most ordinary way, to print or display an announcement including an appropriate copyright notice and a notice that there is no warranty (or else, saying that you provide a warranty) and that users may redistribute the program under these conditions, and telling the user how to view a copy of this License. (Exception: if the Program itself is interactive but does not normally print such an announcement, your work based on the Program is not required to print an announcement.)

These requirements apply to the modified work as a whole. If identifiable sections of that work are not derived from the Program, and can be reasonably considered independent and separate works in themselves, then this License, and its terms, do not apply to those sections when you distribute them as separate works. But when you distribute the same sections as part of a whole which is a work based on the Program, the distribution of the whole must be on the terms of this License, whose permissions for other licensees extend to the entire whole, and thus to each and every part regardless of who wrote it.

Thus, it is not the intent of this section to claim rights or contest your rights to work written entirely by you; rather, the intent is to exercise the right to control the distribution of derivative or collective works based on the Program.

In addition, mere aggregation of another work not based on the Program with the Program (or with a work based on the Program) on a volume of a storage or distribution medium does not bring the other work under the scope of this License.

3. You may copy and distribute the Program (or a work based on it, under Section 2) in object code or executable form under the terms of Sections 1 and 2 above provided that you also do one of the following:

  • a) Accompany it with the complete corresponding machine-readable source code, which must be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or,

    b) Accompany it with a written offer, valid for at least three years, to give any third party, for a charge no more than your cost of physically performing source distribution, a complete machine-readable copy of the corresponding source code, to be distributed under the terms of Sections 1 and 2 above on a medium customarily used for software interchange; or,

    c) Accompany it with the information you received as to the offer to distribute corresponding source code. (This alternative is allowed only for noncommercial distribution and only if you received the program in object code or executable form with such an offer, in accord with Subsection b above.)

The source code for a work means the preferred form of the work for making modifications to it. For an executable work, complete source code means all the source code for all modules it contains, plus any associated interface definition files, plus the scripts used to control compilation and installation of the executable. However, as a special exception, the source code distributed need not include anything that is normally distributed (in either source or binary form) with the major components (compiler, kernel, and so on) of the operating system on which the executable runs, unless that component itself accompanies the executable.

If distribution of executable or object code is made by offering access to copy from a designated place, then offering equivalent access to copy the source code from the same place counts as distribution of the source code, even though third parties are not compelled to copy the source along with the object code.

4. You may not copy, modify, sublicense, or distribute the Program except as expressly provided under this License. Any attempt otherwise to copy, modify, sublicense or distribute the Program is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance.

5. You are not required to accept this License, since you have not signed it. However, nothing else grants you permission to modify or distribute the Program or its derivative works. These actions are prohibited by law if you do not accept this License. Therefore, by modifying or distributing the Program (or any work based on the Program), you indicate your acceptance of this License to do so, and all its terms and conditions for copying, distributing or modifying the Program or works based on it.

6. Each time you redistribute the Program (or any work based on the Program), the recipient automatically receives a license from the original licensor to copy, distribute or modify the Program subject to these terms and conditions. You may not impose any further restrictions on the recipients' exercise of the rights granted herein. You are not responsible for enforcing compliance by third parties to this License.

7. If, as a consequence of a court judgment or allegation of patent infringement or for any other reason (not limited to patent issues), conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot distribute so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not distribute the Program at all. For example, if a patent license would not permit royalty-free redistribution of the Program by all those who receive copies directly or indirectly through you, then the only way you could satisfy both it and this License would be to refrain entirely from distribution of the Program.

If any portion of this section is held invalid or unenforceable under any particular circumstance, the balance of the section is intended to apply and the section as a whole is intended to apply in other circumstances.

It is not the purpose of this section to induce you to infringe any patents or other property right claims or to contest validity of any such claims; this section has the sole purpose of protecting the integrity of the free software distribution system, which is implemented by public license practices. Many people have made generous contributions to the wide range of software distributed through that system in reliance on consistent application of that system; it is up to the author/donor to decide if he or she is willing to distribute software through any other system and a licensee cannot impose that choice.

This section is intended to make thoroughly clear what is believed to be a consequence of the rest of this License.

8. If the distribution and/or use of the Program is restricted in certain countries either by patents or by copyrighted interfaces, the original copyright holder who places the Program under this License may add an explicit geographical distribution limitation excluding those countries, so that distribution is permitted only in or among countries not thus excluded. In such case, this License incorporates the limitation as if written in the body of this License.

9. The Free Software Foundation may publish revised and/or new versions of the General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns.

Each version is given a distinguishing version number. If the Program specifies a version number of this License which applies to it and "any later version", you have the option of following the terms and conditions either of that version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of this License, you may choose any version ever published by the Free Software Foundation.

10. If you wish to incorporate parts of the Program into other free programs whose distribution conditions are different, write to the author to ask for permission. For software which is copyrighted by the Free Software Foundation, write to the Free Software Foundation; we sometimes make exceptions for this. Our decision will be guided by the two goals of preserving the free status of all derivatives of our free software and of promoting the sharing and reuse of software generally.

NO WARRANTY

11. BECAUSE THE PROGRAM IS LICENSED FREE OF CHARGE, THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.

12. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR REDISTRIBUTE THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.

END OF TERMS AND CONDITIONS

28. 付録B - Buster の Debian Edu Live CD/DVD (まだありません)

/!\ Buster の Debian Edu Live CD/DVD は、現時点ではまだありません。

28.1. 「スタンドアロン」 イメージに収録されている機能

  • XFCE デスクトップ

  • 「スタンドアロン」プロファイルの全パッケージ

  • laptop タスクの全パッケージ

28.2. Workstation イメージに収録されている機能

  • XFCE デスクトップ

  • Workstation プロファイルの全パッケージ

  • laptop タスクの全パッケージ

28.3. 翻訳や地域サポートの有効化

特定の翻訳を有効化するにはブートオプションとして locale=ll_CC.UTF-8 を使ってブートします。「ll_CC.UTF-8」には希望するロケールの名前とエンコーディングを指定します。決まったキーボードレイアウトを有効化するには keyb=KB オプションを使います。「KB」には希望するキーボードレイアウトを指定します。広く利用されているロケールコード一覧:

言語 (地域)

ロケール

キーボードレイアウト

ノルウェー語 (ブークモール)

nb_NO.UTF-8

no

ノルウェー語 (ニーノシュク)

nn_NO.UTF-8

no

ドイツ語

de_DE.UTF-8

de

フランス語 (フランス)

fr_FR.UTF-8

fr

ギリシャ語 (ギリシャ)

el_GR.UTF-8

el

日本語

ja_JP.UTF-8

jp

北サーミ語 (ノルウェー)

se_NO

no(smi)

/usr/share/i18n/SUPPORTED に利用可能なロケールコードの完全な一覧がありますが live イメージでサポートするのは UTF-8 ロケールだけです。全ロケールに翻訳があるわけでもありません。キーボードレイアウトの名前は /usr/share/keymaps/i386/ にあります。

28.4. 知っておくべき事柄

  • 最初のユーザのパスワードは「user」で、root のパスワードはセットされていません。

28.5. イメージの既知の問題

  • /!\ イメージはまだありません :(

28.6. ダウンロード

イメージは今はまだありませんが、将来的には FTPHTTPあるいはrsyncならftp.skolelinux.orgcd-buster-live/ で利用できるようになる予定です。

29. 付録 C- 過去のリリースの機能について

29.1. 2017年6月17日にリリースされた Debian Edu 9+edu0 Stretch の新機能

29.1.1. インストールの変更

  • Debian Stretch 用の新しいバージョンの debian-installer。詳細についてはインストールマニュアルを見てください。

  • 「Thin-Client-Server (シンクライアントサーバ)」プロファイルは「LTSP-Server」プロファイルに改名されました。

  • New artwork based on the "soft Waves" theme, the default artwork for Debian 9 Stretch.

29.1.2. ソフトウェアの更新

  • Debian 9 Stretch で更新されたもの:

    • Linux カーネル 4.9

    • デスクトップ環境 KDE Plasma Workspace 5.8、GNOME 3.22、Xfce 4.12、LXDE 0.99.2、MATE 1.16

      • デフォルトで KDE Plasma Workspace がインストールされます。他のデスクトップ環境選択についてはこのマニュアルを見てください。

    • Firefox 45.9 ESR 及び Chromium 59

      • Iceweasel の名前はまたまた Firefox に変わりました! :-)

    • Icedove の名前はまたまた Thunderbird に変わり、デフォルトでインストールされるようになっています。

    • LibreOffice 5.2.6

    • 教育用ツール集 GCompris 15.10

    • 音楽作成 Rosegarden 16.06

    • GOsa 2.7.4

    • LTSP 5.5.9

    • Debian Stretch には 50000 以上のパッケージを収録し、インストールして利用できます。

29.1.3. 文書や翻訳の更新

  • インストーラで使われるテンプレートの翻訳。現在29言語が用意されています。

  • Debian Edu Stretch のマニュアルはドイツ語、フランス語、イタリア語、 デンマーク語、オランダ語、ノルウェー語 (ブークモール)、日本語に完全に翻訳されています。

    • Partly translated versions exist for Spanish, Polish and Simplified Chinese.

29.1.4. 前のリリースからの他の変更点

  • 監視ツールは Nagios から Icinga に替わりました。

  • スクリーンショットツールが ksnapshot から kde-spectacle に替わりました。

  • フリーの Flash プレーヤー gnash が帰ってきました。

  • Plymouth is installed and activated by default, except for the 'Main Server' and 'Minimal' profiles; pressing ESC allows to view boot and shutdown messages.

  • Jessie からアップグレードする際、LDAP データベースを調整しないといけません。GOsa² や LDAP エディタを使い、sudoHost の「tjener」を「tjener.intern」に置き換えます。

  • 古い32ビットPC(Debianアーキテクチャー名としてはi386)のサポート対象から、i586プロセッサーは外れました。現在の最低基準はi686以降となりますが、AMD Geodeなど一部のi586プロセッサーのサポートは残っています。

  • Debian 9 enables unattended upgrades (for security updates) by default for new installations. This might cause a delay of about 15 minutes if a system with a low uptime value is powered off.

  • LTSP now uses NBD instead of NFS for the root filesystem. After each single change to an LTSP chroot, the related NBD image must be regenerated (ltsp-update-image) for the changes to take effect.

  • LTSP サーバと LTSP シンクライアントへの同一ユーザによる同時ログインは許可されなくなっています。

29.2. 2016年7月2日にリリースされた Debian Edu 8+edu0 コード名 Jessie の新機能

29.2.1. インストールの変更

29.2.2. ソフトウェアの更新

  • Debian 8 Jessie で新しくなっているもの全て。例えば:

    • Linux カーネル 3.16.x

    • デスクトップ環境 KDE Plasma Workspace 4.11.13、GNOME 3.14、Xfce 4.10、LXDE 0.5.6

      • デスクトップ環境の新たな選択肢: MATE 1.8

      • デフォルトで KDE Plasma Workspace がインストールされます。他のデスクトップ環境選択についてはこのマニュアルを見てください。

    • ウェブブラウザ Iceweasel 31 ESR 及び Chromium 41

    • LibreOffice 4.3.3

    • 教育用ツール集 GCompris 14.12

    • 音楽作成 Rosegarden 14.02

    • GOsa 2.7.4

    • LTSP 5.5.4

    • 起動後の管理は systemd になりました。詳細についてはsystemd wiki pagesystemd manualをご覧になってください。

    • Debian Jessie には約 42000 のパッケージを収録し、インストールして利用できます。

29.2.3. 文書や翻訳の更新

  • インストーラで使われるテンプレートの翻訳。現在29言語が用意されています。

  • オランダ語とノルウェー語 (ブークモール) への翻訳が完了。

  • Debian Edu Jessie のマニュアルはドイツ語、フランス語、イタリア語、 デンマーク語、オランダ語、ノルウェー語 (ブークモール) に完全に翻訳されています。スペイン語には部分的に翻訳されているバージョンが存在します。

29.2.4. 前のリリースからの他の変更点

  • squid: Shutdown and reboot of the main server takes longer than before due to a new default setting shutdown_lifetime 30 seconds. As an example the delay could be set to 10 seconds by appending the line shutdown_lifetime 10 seconds to /etc/squid3/squid.conf.

  • ssh: The root user is no longer allowed to login via SSH with password. The old default PermitRootLogin yes has been replaced with PermitRootLogin without-password, so ssh-keys will still work.

  • slbackup-php: To be able to use the slbackup-php site (which uses root logins via ssh), PermitRootLogin yes has to be set temporarily in /etc/ssh/sshd_config.

  • sugar: Sugar デスクトップは Debian Jessie から削除されたため、Debian Edu jessie でも利用できません。

29.3. 2013年9月28日にリリースされた Debian Edu 7.1+edu0 コード名 Wheezy の新機能

29.3.1. ユーザから見える変更点

  • インストール中、ログイン画面、デスクトップの壁紙として見えるアートワークと新しい Debian Edu / Skolelinux ロゴが更新されました。

29.3.2. インストールの変更

  • Debian Wheezy 用の新しいバージョンの debian-installer。詳細についてはインストールマニュアルを見てください。

  • DVDイメージは無くなりました。代わりにUSBフラッシュドライブ / Blu-ray ディスク用のイメージを用意しています。DVDイメージと同じように使えますが巨大すぎて DVD には収まらなくなりました。

29.3.3. ソフトウェアの更新

  • Debian Wheezy 7.1 で新しくなっているもの全て。例えば:

    • Linux カーネル 3.2.x

    • デスクトップ環境: KDE Plasma 4.8.4、GNOME 3.4、Xfce 4.8.6、LXDE 0.5.5 (KDE Plasma がデフォルトでインストールされます。GNOME や Xfce、LXDE を選択する方法についてはマニュアルをご参照ください。)

    • ウェブブラウザ Iceweasel 17 ESR

    • LibreOffice 3.5.4

    • LTSP 5.4.2

    • GOsa 2.7.4

    • CUPS 印刷システム 1.5.3

    • 教育用ツール集 GCompris 12.01

    • 音楽作成 Rosegarden 12.04

    • 画像編集用エディタ Gimp 2.8.2

    • 仮想宇宙 Celestia 1.6.1

    • 仮想プラネタリウム Stellarium 0.11.3

    • Scratch 視覚的プログラミング環境 1.4.0.6

    • Debian Wheezy 用の新しいバージョンの debian-installer。詳細についてはインストールマニュアルを見てください。

    • Debian Wheezy には約 37000 のパッケージを収録し、インストールして利用できます。

29.3.4. 文書や翻訳の更新

  • インストーラで使われるテンプレートの翻訳。現在29言語が用意されています。

  • Debian Edu Wheezy のマニュアルはドイツ語、フランス語、イタリア語、 デンマーク語に完全に翻訳されています。ノルウェー語 (Bokmål) とスペイン語には部分的に翻訳されているバージョンが存在します。

29.3.5. LDAP 関連の変更点

  • Slight changes to some objects and acls to have more types to choose from when adding systems in GOsa. Now systems can be of type server, workstation, printer, terminal or netdevice.

29.3.6. 他の変更点

  • 新しい Xfce デスクトップタスク。

  • LTSP ディスクレスワークステーションが追加設定無しで動作します。

  • LTSP サーバのクライアント用ネットワーク (デフォルトは 192.168.0.0/24) では、十分な性能のないマシンはデフォルトでディスクレスワークステーションとして動作します。

  • GOsa gui: Now some options that seemed to be available, but are non functional, are greyed out (or are not clickable). Some tabs are completely hidden to the end user, others even to the GOsa admin.

29.3.7. 既知の問題

  • Using KDE "Plasma" on standalone and roaming workstations, at least Konqueror, Chromium and Step sometimes fail to work out-of-the box when the machines are used outside the backbone network, proxy use is required to use the other network but no wpad.dat information is found. Workaround: Use Iceweasel or configure the proxy manually.

29.4. 更に古いリリースについての情報

The following Debian Edu releases were made further in the past:

  • 2013年3月3日にリリースされた Debian Edu 6.0.7+r1 コード名 Squeeze。

  • 2012年3月11日にリリースされた Debian Edu 6.0.4+r0 コード名 Squeeze。

  • 2010年10月5日にリリースされた Debian Edu 5.0.6+edu1 コード名 Lenny 。

  • 2010年2月8日にリリースされた Debian Edu 5.0.4+edu0 コード名 Lenny 。

  • 2007年12月5日にリリースされた Debian Edu 3.0r1 Terra。

  • 2007年4月8日にリリースされた Debian 4.0 Etch を元に、2007年7月22日にリリースされた Debian Edu 「3.0r0 Terra」。

  • 2005年6月6日にリリースされた Debian 3.1 Sargeを ベースに、2006年3月14日にリリースされた Debian Edu 2.0。

  • 2002年7月19日にリリースされた Debian 3.0 Woody ベースに、2004年6月20日にリリースされた Debian Edu 1.0 Venus。

A complete and detailed overview about older releases is contained in Appendix C of the Jessie manual; or see the related release manuals on the release manuals page.

29.4.1. もっと古いリリースについてのさらなる情報

さらに古いリリースについての情報は http://developer.skolelinux.no/info/cdbygging/news.html にあります。