実行手順
1. Sambaデータ格納用ディレクトリを作成以下のコマンドでSambaデータ格納用ディレクトリを作成します。
sudo mkdir -p /var/samba
sudo chown 1001:1001 /var/samba
2. local永続ボリュームの作成
以下のコマンドでlocal永続ボリュームを作成します。
cat << EOF > local-samba-pv.yml
apiVersion: v1
kind: PersistentVolume
metadata:
name: local-samba-pv
spec:
capacity:
storage: 5Gi
accessModes:
- ReadWriteOnce
storageClassName: local-storage
local:
path: /var/samba
nodeAffinity:
required:
nodeSelectorTerms:
- matchExpressions:
- key: kubernetes.io/hostname
operator: In
values:
- `hostname`
EOF
※`hostname`は今ログオンしているMicrok8sがインストールされているホスト名になります。適宜変更してください。microk8s kubectl apply -f ./local-samba-pv.yml
3. 永続ボリューム要求の作成
以下のコマンドで永続ボリューム要求を作成します。
cat << EOF > local-samba-pvc.yml
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: local-samba-pvc
spec:
accessModes:
- ReadWriteOnce
storageClassName: local-storage
resources:
requests:
storage: 5Gi
volumeName: local-samba-pv
EOF
microk8s kubectl apply -f ./local-samba-pvc.yml
4. Deploymentの作成
以下のコマンドでSambaのイメージと作成したlocal永続ボリュームを使用するDeploymentを作成します。
ユーザ名とパスワードはargsのsampleuser;samplepasswordの部分を変更してください。
cat << EOF > samba-deployment.yml
apiVersion: apps/v1
kind: Deployment
metadata:
name: samba-deployment
labels:
app: mysamba
spec:
replicas: 1
selector:
matchLabels:
app: mysamba
strategy:
type: Recreate
template:
metadata:
labels:
app: mysamba
spec:
containers:
- name: mysamba
image: dperson/samba
env:
- name: TZ
value: "Asia/Tokyo"
- name: USERID
value: "1001"
- name: GROUPID
value: "1001"
args: ["-u", "sampleuser;samplepassword",
"-s", "share;/mnt;yes;no;no;sampleuser", "-w", "WORKGROUP", "-r", "-p"]
#-s "<name;/path>[;browse;readonly;guest;users;admins;writelist;comment]"
ports:
- containerPort: 139
- containerPort: 445
volumeMounts:
- name: samba-mount
mountPath: /mnt
volumes:
- name: samba-mount
persistentVolumeClaim:
claimName: local-samba-pvc
EOF
microk8s kubectl apply -f ./samba-deployment.yml
5. サービスの作成
以下のコマンドでサービスを作成します。
cat << EOF > samba-service.yml
apiVersion: v1
kind: Service
metadata:
name: samba-service
spec:
selector:
app: mysamba
type: LoadBalancer
externalIPs:
- xxx.xxx.xxx.xxx # 外部からアクセスできるMicrok8sをインストールしたホストのIPを設定します。
ports:
- name: netbios-ssn
protocol: TCP
port: 139
targetPort: 139
- name: microsoft-ds
protocol: TCP
port: 445
targetPort: 445
EOF
microk8s kubectl apply -f ./samba-service.yml
6. アクセス確認
Windowsのエクスプローラーに以下の場所を入力します。
\\<Microk8sのホスト名またはIP>\share
ユーザ名にsampleuser、パスワードにsamplepasswordを入力します
0 件のコメント:
コメントを投稿