Установка локального FTP-сервера с K8S / Minikube и доступ к нему с помощью Filezilla - PullRequest
0 голосов
/ 11 марта 2020

Я пытаюсь установить FTP-сервер с Kubernetes на основе этого репо .

Я также использую Traefik в качестве Ingress.

Все, кажется, хорошо, и я могу ли я подключить FTP-сервер с cluster-ip, но я не могу заставить его работать с локальным доменом, таким как ftp.local

Вот мои файлы K8S:

apiVersion: apps/v1
kind: Deployment
metadata:
  annotations:
    reloader.stakater.com/auto: "true"
  labels:
    app: ftp-local
  name: ftp-local
  namespace: influx
spec:
  selector:
    matchLabels:
      app: ftp-local
  strategy:
    type: Recreate
  replicas: 1
  template:
    metadata:
      labels:
        app: ftp-local
    spec:
      containers:
      - name: ftp-local
        image: fauria/vsftpd
        resources:
          limits:
            memory: "128Mi"
            cpu: "500m"
        ports:
        - containerPort: 21
          protocol: TCP
          name: "ftp-server"
        volumeMounts:
        - mountPath: "/home/vsftpd"
          name: task-pv-storage
        env:
        - name: FTP_USER
          value: "sunchain"
        - name: FTP_PASS
          value: "sunchain"
        #- name: PASV_ADDRESS
        #  value: "127.0.0.1"
        #- name: PASV_MIN_PORT
        #  value: "21100"
        #- name: PASV_MAX_PORT
        #  value: "21110"
      volumes:
      - name: task-pv-storage
        persistentVolumeClaim:
          claimName: task-pv-claim
---

kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: task-pv-claim
  namespace: influx
spec:
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 3Gi
---
kind: PersistentVolume
apiVersion: v1
metadata:
  name: task-pv-volume
  namespace: influx
  labels:
    type: local
spec:
  capacity:
    storage: 10Gi
  accessModes:
    - ReadWriteOnce
  hostPath:
    path: "/tmp/data"
---
apiVersion: v1
kind: Service
metadata:
  name: ftp-local
  namespace: influx
  labels:
    app: ftp-local
spec:
  ports:
  - name: "21"
    port: 21
    targetPort: 21
  selector:
    app: ftp-local
  type: NodePort
---
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
  name: ftp-ingress
  namespace: influx
  annotations:
    kubernetes.io/ingress.class: traefik
spec:
  rules:
  - host: ftp.local
    http:
      paths:
      - backend:
         serviceName: ftp-local
         servicePort: 21

У меня также есть строка в / etc / hosts такая:

127.0.0.1      ftp.local

Что мне не хватает?

1 Ответ

0 голосов
/ 24 марта 2020

Сначала ссылка на репо, которую вы использовали, была создана / обновлена ​​ 2-3 года a go.

Многие новейшие функции Kubernetes требуют SSL для связи. По этой причине SFTP легче применять в Кубернетесе. Другое дело, вы используете Minikube с --driver=none, которые имеют некоторые ограничения. Вся необходимая информация о none драйвере описана здесь .

Уже был похожий вопрос относительно FTP Filezilla в этой теме .

Как обходной путь Вы можете использовать hostPort или hostNetwork.

Многие аспекты конфигурации зависят от того, хотите ли вы использовать Acitve или Passive FTP .

Для работы FTP требуется два TCP-соединения. Второе соединение устанавливается с использованием случайного порта. Я не выгляжу совместимым с Services концепцией. SFTP требуется только одно соединение.

В качестве другого решения вы можете рассмотреть использование SFTP. В Интернете можно найти много статей с информацией о том, что лучше использовать SFTP, а не FTP. Например Tibco docs или эта статья

Вы можете проверить информацию о SFTP-сервере с помощью OpenS SH и попробовать этот github Пример SFTP .

Здесь вы можете найти информацию, используя SFTP в FileZilla.

...