「インストール - Samba」の版間の差分
5行目: | 5行目: | ||
<br><br> | <br><br> | ||
== | == Sambaのインストール == | ||
==== パッケージ管理システムからインストール ==== | |||
最新パッケージリストを取得する。<br> | |||
# CentOS | # CentOS | ||
sudo yum update | sudo yum update | ||
16行目: | 17行目: | ||
sudo apt-get update | sudo apt-get update | ||
<br> | <br> | ||
Sambaをインストールする。<br> | |||
# CentOS | # CentOS | ||
sudo yum install samba samba-client | sudo yum install samba samba-client | ||
25行目: | 26行目: | ||
# Raspberry Pi | # Raspberry Pi | ||
sudo apt-get install samba | sudo apt-get install samba | ||
<br> | |||
==== ソースコードからインストール ==== | |||
Sambaのビルドに必要なライブラリをインストールする。<br> | |||
# SUSE | |||
sudo zypper install tar gcc gdb rpcgen gnutls-devel gpgme-devel zlib-devel dbus-1-devel \ | |||
readline-devel libjansson-devel keyutils-devel krb5-server krb5-devel libacl-devel \ | |||
libaio-devel libarchive-devel libattr-devel libblkid-devel libtasn1-devel systemd-devel \ | |||
libxml2-devel libxslt-devel docbook5-xsl-stylesheets lmdb lmdb-devel openldap2-devel pam-devel \ | |||
perl perl-ExtUtils-MakeMaker perl-Parse-Yapp popt-devel cups-devel \ | |||
python3-devel python3-cryptography python3-dnspython python3-gpg python3-Markdown \ | |||
python3-talloc-devel libtalloc-devel libcmocka-devel libtdb-devel tracker-devel libnscd-devel \ | |||
glusterfs-devel libtirpc-devel libntirpc-devel libavahi-devel | |||
<br> | |||
[https://download.samba.org/pub/samba/ Sambaの公式Webサイト]にアクセスして、ソースコードをダウンロードする。<br> | |||
ダウンロードしたファイルを解凍する。<br> | |||
tar xf samba-<バージョン>.tar.gz | |||
cd samba-<バージョン> | |||
<br> | |||
Sambaをビルドおよびインストールする。<br> | |||
<u>ビルドディレクトリを作成する場合、Sambaのビルドに失敗することに注意する。</u><br> | |||
./configure --prefix=<Sambaのインストールディレクトリ> --enable-cups --with-systemd --systemd-install-services | |||
make -j $(nproc) | |||
make install | |||
<br> | |||
Sambaの設定ファイルを作成する。<br> | |||
vi /<Sambaのインストールディレクトリ>/etc/smb.conf | |||
<br> | |||
# /<Sambaのインストールディレクトリ>/etc/smb.confファイル | |||
<br> | |||
SambaのSystemdサービスファイルを、/etc/systemd/systemディレクトリにコピーする。<br> | |||
sudo cp /<Sambaのインストールディレクトリ>/lib/systemd/system/* /etc/systemd/system | |||
<br> | |||
SambaのSystemdサービスファイルを読み込む。<br> | |||
sudo systemctl daemon-reload | |||
<br><br> | <br><br> | ||
2022年11月3日 (木) 15:27時点における版
概要
ここでは、Sambaを使用してファイルサーバを構築する。
ネットワークに接続していないと、Sambaをインストールしても外部からアクセスができないので、既存のネットワークに接続すること。
必ず、Linuxを固定IPアドレスに設定すること。(ここでは192.168.1.5とする)
Sambaのインストール
パッケージ管理システムからインストール
最新パッケージリストを取得する。
# CentOS sudo yum update # SUSE sudo zypper update # Raspberry Pi sudo apt-get update
Sambaをインストールする。
# CentOS sudo yum install samba samba-client # SUSE sudo zypper install samba samba-client # Raspberry Pi sudo apt-get install samba
ソースコードからインストール
Sambaのビルドに必要なライブラリをインストールする。
# SUSE sudo zypper install tar gcc gdb rpcgen gnutls-devel gpgme-devel zlib-devel dbus-1-devel \ readline-devel libjansson-devel keyutils-devel krb5-server krb5-devel libacl-devel \ libaio-devel libarchive-devel libattr-devel libblkid-devel libtasn1-devel systemd-devel \ libxml2-devel libxslt-devel docbook5-xsl-stylesheets lmdb lmdb-devel openldap2-devel pam-devel \ perl perl-ExtUtils-MakeMaker perl-Parse-Yapp popt-devel cups-devel \ python3-devel python3-cryptography python3-dnspython python3-gpg python3-Markdown \ python3-talloc-devel libtalloc-devel libcmocka-devel libtdb-devel tracker-devel libnscd-devel \ glusterfs-devel libtirpc-devel libntirpc-devel libavahi-devel
Sambaの公式Webサイトにアクセスして、ソースコードをダウンロードする。
ダウンロードしたファイルを解凍する。
tar xf samba-<バージョン>.tar.gz cd samba-<バージョン>
Sambaをビルドおよびインストールする。
ビルドディレクトリを作成する場合、Sambaのビルドに失敗することに注意する。
./configure --prefix=<Sambaのインストールディレクトリ> --enable-cups --with-systemd --systemd-install-services make -j $(nproc) make install
Sambaの設定ファイルを作成する。
vi /<Sambaのインストールディレクトリ>/etc/smb.conf
# /<Sambaのインストールディレクトリ>/etc/smb.confファイル
SambaのSystemdサービスファイルを、/etc/systemd/systemディレクトリにコピーする。
sudo cp /<Sambaのインストールディレクトリ>/lib/systemd/system/* /etc/systemd/system
SambaのSystemdサービスファイルを読み込む。
sudo systemctl daemon-reload
Sambaの設定
ホームディレクトリにSambaで使用する共有ディレクトリを作成する。
mkdir ~/Common
Samba の設定ファイルであるsmb.confを編集する。
sudo vi /etc/samba/smb.conf
smb.confの末尾に以下の記述を追加して保存する。
# [global]セクションの直下に、以下の2行を追記する unix charset = UTF-8 dos charset = CP932 # [global]セクションのworkgroupキー # ドメインを設定している場合は変更する workgroup = WORKGROUP # [global]セクションのhosts allowキーおよび各共有設定のセクションに追記 # アクセス制限を行う場合は、アクセスを許可するIPアドレスを指定する hosts allow = 192.168.2. 192.168.1.20/24 # 126行目あたり : 認証なしでアクセスする場合は追記する security = <ユーザ名> passdb backend = tdbsam map to guest = Bad User # 末尾に以下を追記する [Common] comment = Shared Directory on Samba path = /home/<ユーザ名>/Common read only = no browsable = yes public = no guest ok = no available = yes valid users = <Sambaに登録したユーザ名1> <Sambaに登録したユーザ名2> <Sambaに登録したユーザ名3> ... #force user = <サーバのユーザ名>
設定項目の意味を、以下に示す。
- available, valid users
- 以下の2つをセットで設定する時、hogeユーザ以外はログインできない。
- available = yes
- valid users = hoge
- force user
- どのユーザでログインしても、内部的にhogeでログインして接続する。この時、そのユーザ名とパスワードが求められる。
- force user = hoge
- public, guest ok
- パスワードなしでアクセスするためguestを許可する。publicキーとguest okキーは同じ意味のキーである。
- public = yes
- guest ok = yes
- map to guest
- Sambaにアクセスする時、有効なユーザとして認証されなかった場合の動作を指定するパラメータである。
- 設定値を以下に示す。
- Never
- 不正なパスワードによるユーザのログイン要求を拒否して、ゲスト認証は許可しない。
- Bad User
- 存在するユーザに対する不正なパスワードによるログイン要求は拒否する。
- 存在しないユーザを指定された場合は、ゲスト認証であるとみなして、guest accountパラメータに定義されたユーザでログインする。
- Bad Password
- 存在しないユーザを指定された場合に加えて、存在するユーザに対する不正なパスワードによるログイン要求も、ゲスト認証であるとみなして、
- guest accountパラメータに定義されたユーザでログインする。
- Bad Uid
- Sambaがドメインモードのセキュリティで構成されている環境において、認証が成功したにも関わらずUNIX側のユーザアカウントが存在しない場合に、
- guest accountパラメータに定義されたユーザでログインする。
- ただし、Sambaでwinbinddが機能している場合、WindowsのユーザがUnixのユーザとして動作できるようになるため、
- 認証に成功したにも関わらずUNIX側のユーザアカウントが存在しない、ということは発生しない。
- そのため、winbinddが機能するSamba 3以降ではBad Uidはほとんど利用されていない。
- なお、Samab 2.x系では、Bad Uidがデフォルトとして設定されている。
Sambaを再起動する。
sudo systemctl restart smbd sudo systemctl restart nmbd
ファイアーウォールを有効にしている場合は、Sambaサービスの許可が必要である。
sudo firewall-cmd --permanent --add-service=samba または sudp firewall-cmd --permanent --add-port=445/tcp sudo firewall-cmd --reload
SELinuxを有効にしている場合は、SELinuxコンテキストの変更が必要である。
sudo setsebool -P samba_enable_home_dirs on sudo restorecon -R /home/<ユーザ名>/Common
動作の確認
エクスプローラまたは[ファイル名を指定して実行]にて、
下記のように、IPアドレスまたはホスト名を入力して、共有ディレクトリが表示できるか確認する。
\\192.168.1.5 または \\RASPBERRYPI
Sambaへのユーザ登録
Sambaは独自でユーザの管理をするので、Sambaへのユーザ登録をすることができる。
Sambaと通常サーバは、別々にユーザを管理するが、同一のユーザ名とパスワードで問題ない。
クライアントからSambaにアクセスしたときに、認証画面において、ユーザ名とパスワードを入力することになる。
Sambaのユーザ名とパスワードを登録する方法を、以下に示す。
ただし、登録できるユーザは、既にサーバに存在するユーザのみである。
また、Sambaのユーザ登録のコマンドは、Samba2.xではsmbpasswd
コマンド、Samba3.xではpdbedit
コマンドとなる。
# Sambaのユーザ名の一覧を表示 sudo pdbedit -L # 詳細なユーザ名の一覧を表示 sudo pdbedit -L -v # ユーザを登録する (パスワードを2回入力して設定する) sudo pdbedit -a <ユーザ名> # Sambaのユーザを削除する sudo pdbedit -x <ユーザ名>
Sambaユーザのパスワードを変更する場合、smbpasswd
コマンドを使用する。
sudo smbpasswd <ユーザ名>
次に、/etc/samba/smb.confファイルを以下のように編集する。
sudo vi /etc/samba/smb.conf
# /etc/samba/smb.confファイル public = no # force user = pi # コメントする valid users = <登録するユーザ名>
最後に、Sambaを再起動する。
sudo systemctl restart smbd sudo systemctl restart nmbd
Sambaユーザのパスワードがサーバとは別管理になる理由は、
Linuxのパスワード管理の暗号化方式と、Sambaのパスワード管理の暗号化方式が異なるためである。
Sambaは、Windowsのパスワード管理の暗号化に合わせているため、同一のユーザ名とパスワードであっても、Sambaに登録をする。
暗号化方式を統一することもできるが、セキュリティ面から標準の設定の方がよい。