У меня проблема с ftps-filezilla и Kubernetes в течение нескольких недель.
CONTEXT :
У меня есть школьный проект с Kubernetes и ftps. Мне нужно создать FTP-сервер в Kubernetes в порту 21, и он должен работать на Alpine linux. Поэтому я создаю образ моего ftps-alpine сервера, используя контейнер docker. Я проверяю его, если он работает правильно сам по себе: Используя docker run --name test-alpine -itp 21:21 test_alpine
У меня есть такой вывод в filezilla:
Status: Connecting to 192.168.99.100:21…
Status: Connection established, waiting for welcome message…
Status: Initializing TLS…
Status: Verifying certificate…
Status: TLS connection established.
Status: Logged in
Status: Retrieving directory listing…
Status: Calculating timezone offset of server…
Status: Timezone offset of server is 0 seconds.
Status: Directory listing of “/” successful
Он работает успешно, filezilla видит файл, который находится в моем каталоге ftps, для которого я хорош сейчас (работа в активном режиме).
ПРОБЛЕМА :
Так что я хотел, чтобы использовать мое изображение в моем кластере kubernetes (я использую Minikube). Когда я подключаю свой docker образ к входному сервисному развертыванию в kubernetes, я получаю следующее:
Status: Connecting to 192.168.99.100:30894…
Status: Connection established, waiting for welcome message…
Status: Initializing TLS…
Status: Verifying certificate…
Status: TLS connection established.
Status: Logged in
Status: Retrieving directory listing…
Command: PWD
Response: 257 “/” is the current directory
Command: TYPE I
Response: 200 Switching to Binary mode.
Command: PORT 192,168,99,1,227,247
Response: 500 Illegal PORT command.
Command: PASV
Response: 227 Entering Passive Mode (172,17,0,5,117,69).
Command: LIST
Error: The data connection could not be established: EHOSTUNREACH - No route to host
Error: Connection timed out after 20 seconds of inactivity
Error: Failed to retrieve directory listing
SETUP :
ingress.yaml :
kind: Ingress
metadata:
annotations:
nginx.ingress.kubernetes.io/rewrite-target: /$1
namespace: default
name: ingress-controller
spec:
backend:
serviceName: my-nginx
servicePort: 80
backend:
serviceName: ftps-alpine
servicePort: 21
ftps-alpine.yml :
apiVersion: v1
kind: Service
metadata:
name: ftps-alpine
labels:
run: ftps-alpine
spec:
type: NodePort
ports:
port: 21
targetPort: 21
protocol: TCP
name: ftp21
port: 20
targetPort: 20
protocol: TCP
name: ftp20
selector:
run: ftps-alpine
apiVersion: apps/v1
kind: Deployment
metadata:
name: ftps-alpine
spec:
selector:
matchLabels:
run: ftps-alpine
replicas: 1
template:
metadata:
labels:
run: ftps-alpine
spec:
- name: ftps-alpine
image: test_alpine
imagePullPolicy: Never
ports:
- containerPort: 21
- containerPort: 20
ЧТО Я ПОПРОБОВАЛ :
- Когда я вижу сообщение об ошибке: Ошибка: Не удалось установить соединение для передачи данных: EHOSTUNREACH - Нет маршрута для размещения Google, и я вижу это сообщение: FTP в пассивном режиме: EHOSTUNREACH - Нет маршрута к хосту . И я уже запускаю свой ftps-сервер в активном режиме.
- Измените файл vsftpd.conf и мой сервис:
vsftpd.conf :
seccomp_sandbox=NO
pasv_promiscuous=NO
listen=NO
listen_ipv6=YES
anonymous_enable=NO
local_enable=YES
write_enable=YES
local_umask=022
dirmessage_enable=YES
use_localtime=YES
xferlog_enable=YES
connect_from_port_20=YES
chroot_local_user=YES
#secure_chroot_dir=/vsftpd/empty
pam_service_name=vsftpd
pasv_enable=YES
pasv_min_port=30020
pasv_max_port=30021
user_sub_token=$USER
local_root=/home/$USER/ftp
userlist_enable=YES
userlist_file=/etc/vsftpd.userlist
userlist_deny=NO
rsa_cert_file=/etc/ssl/private/vsftpd.pem
rsa_private_key_file=/etc/ssl/private/vsftpd.pem
ssl_enable=YES
allow_anon_ssl=NO
force_local_data_ssl=YES
force_local_logins_ssl=YES
ssl_tlsv1=YES
ssl_sslv2=NO
ssl_sslv3=NO
allow_writeable_chroot=YES
#listen_port=21
Я изменил свой нодпорт моих kubernetes на 30020 и 30021 и я добавляю их в порты контейнеров. Я меняю порт pasv min и порт max. Я добавляю pasv_adress моего миникуба ip. Ничего не работает.
Вопрос :
Как я могу получить успешно первое сообщение, кроме моего кластера kubernetes?
Если у вас есть какие-либо вопросы, чтобы уточнить , без проблем.
ОБНОВЛЕНИЕ :
Благодаря coderanger, у меня есть аванс, и есть эта проблема:
Status: Connecting to 192.168.99.100:30894...
Status: Connection established, waiting for welcome message...
Status: Initializing TLS...
Status: Verifying certificate...
Status: TLS connection established.
Status: Logged in
Status: Retrieving directory listing...
Command: PWD
Response: 257 "/" is the current directory
Command: TYPE I
Response: 200 Switching to Binary mode.
Command: PASV
Response: 227 Entering Passive Mode (192,168,99,100,178,35).
Command: LIST
Error: The data connection could not be established: ECONNREFUSED - Connection refused by server