2022年4月5日火曜日

k3sでlocal永続ボリュームを使用するSambaをデプロイする

Sambaでファイル共有を行うことができます。k3sでlocal永続ボリュームを使用するSambaをデプロイするには、以下の手順を実行します。

実行手順

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`は今ログオンしているk3sがインストールされているホスト名になります。適宜変更してください。
sudo k3s 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

sudo k3s 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

sudo k3s 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  # 外部からアクセスできるk3sをインストールしたホストのIPを設定します。
  ports:
  - name: netbios-ssn
    protocol: TCP
    port: 139
    targetPort: 139
  - name: microsoft-ds
    protocol: TCP
    port: 445
    targetPort: 445
EOF

sudo k3s kubectl apply -f ./samba-service.yml

6. アクセス確認
Windowsのエクスプローラーに以下の場所を入力します。
\\<k3sのホスト名またはIP>\share
ユーザ名にsampleuser、パスワードにsamplepasswordを入力します

0 件のコメント:

コメントを投稿