4
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

IBM Cloud: CIS Rangeを利用したFTP接続構成

Last updated at Posted at 2021-06-30

1. はじめに

インターネット経由でftp接続をするのであれば、通信が暗号化されてActive mode/Passive modeなども意識する必要がないsftpやscpを利用するべきだと思うが、(暗号化されていなくてもいいので)どうしてもftpを利用してCIS Range(= Cloudflare Spectrum)経由で接続したいというケースのために検証した。
なお、Originサーバーは、IBM Cloud上のVPCサーバーを利用。

以下は注意点

  • Cloudflare社のdocsによるとactive modeはサポートされておらず、passive modeを利用する必要がある(そもそもFTPサーバー側から接続を開始するactive modeだとCIS Rangeでの保護にはならないし、FTPサーバーから見た接続元はCISなんだから、そりゃあうまく行かないだろうなとは思う)。
  • CIS Rangeを利用するためにはEnterprise planが必要。プラン比較表はこちら
  • あくまでftpをCIS Range経由で構成できるかどうかの確認のために検証を実施したのであって、上述のようにインターネット上ではftpではなく、sftpやscpを利用するべきだと思う。(sftpやscpをCIS Range経由にするのは、単一ポートを利用するため特に大きな考慮点はない)。

最終的な構成は以下のようになり、CIS RangeでSourceとDestinationのIPアドレスがNATされる。

Client  -> CIS Range(Control Port:20021, Data Port:20000-20005) -> Origin Server(Control Port:20021, Data Port:20000-20005)

以下では、example.tkがCISで構成済みのドメインであり、ftp.example.tkがCIS Range上のendpointと仮定して設定および検証例を記載する。

2. 設定

2-1. Originサーバーへのvsftpdの導入と設定

vsftpdの導入
# cat /etc/redhat-release
CentOS Linux release 7.7.1908 (Core)
# yum install -y vsftpd
# vsftpd -v
vsftpd: version 3.0.2

https://developers.cloudflare.com/spectrum/ftp のガイドに従い、vsftpd.confに以下を追記。

  • 最低限の設定しか入れていないので、セキュリティー観点の考慮は別途参照して下さい。
  • なぜかCIS RangeではEdge portやOrigin Portとして、21番(FTPのControl portのデフォルト値)を指定できなかったので、20021を指定しています(まぁ、21番をそのまま公開したくないのでそれでもいいかという気もします)。
  • data portは20000-20005を指定(本当は20個ぐらい開けても良いのですが、CIS rangeで20個近く設定を入れるのが面倒だったので今回はこれぐらいにしておきました)
/etc/vsftpd/vsftpd.conf
# 以下に修正(IPv6でListenしているとPassiveモードでの接続に失敗したため)
listen=YES
listen_ipv6=NO

# 以下を新規に追加
listen_port=20021
pasv_min_port=20000
pasv_max_port=20005
pasv_enable=YES
pasv_address=ftp.example.tk
pasv_addr_resolve=YES
pasv_promiscuous=YES
vsftpdの起動
# systemctl start vsftpd
ftp用のローカルユーザーの追加とパスワードの設定
# useradd -U syasuda
# id syasuda
uid=1001(syasuda) gid=1001(syasuda) groups=1001(syasuda)
# passwd syasuda
ユーザー syasuda のパスワードを変更。
新しいパスワード:
新しいパスワードを再入力してください:
passwd: すべての認証トークンが正しく更新できました。

転送用のデータも適当に作っておいてください。

2-2. (IBM Cloud VPC上のOrigin Serverに対する)Security Groupの設定

Security GroupでControl Port(20021)およびData Port(20000-20005)を開ける。
なお、接続元IPも絞る方が望ましい。CISの接続元IPは、https://cloud.ibm.com/docs/cis?topic=cis-cis-allowlisted-ip-addresses&locale=en を参照。

2-3. CIS Rangeの設定

「はじめに」に記載したとおり、example.tkがCISで構成済みのドメインであり、ftp.example.tkがCIS Range上のendpointと仮定して設定例を記載する。

  • 以下のようにControl Port(20021)およびData Port(20000-20005)に対してそれぞれCIS Range Applicationを作成する(これだけでも7個作る必要がある)。
image.png名
  • 最終的な結果は以下のようになる。
    image.png

※2021/07/01追記
Edge portおよびOrigin portとして21を選択した場合は、UIではエラーになってしまう。これはCIS Rangeを実装したタイミングでCloudflare Specturmでも使用できなかった(?)ポートだったらしく、UIで意図的に利用できないように構成していたらしい。今はこの制約は取り除かれているが、UIでは現時点で未対応らしい(修正依頼中)。そのため、21を指定したい場合はCLIで実施する必要がある。以下はその実行例。

$ ibmcloud cis instance-set <CIS Instance Name>
Setting context service instance to '<CIS Instance Name>' ...
OK
Context service instance set succeeded.

$ ibmcloud cis domains
Listing domains for service instance '<CIS Instance Name>' ...
OK
ID                                 Name          Status   Paused   Type
a4135402d38fff24e32ef13c82c1ab4a   example.tk    active   false    full

$ export ZONEID=a4135402d38fff24e32ef13c82c1ab4a

$ ibmcloud cis range-app-create $ZONEID --name ftp.example.tk --edge-port 21 --origin-direct tcp://162.xx.xx.xx:21 --ip-firewall on
Creating range application for domain 'a4135402d38fff24e32ef13c82c1ab4a' ...
OK

ID                      ba1866a2e48048d4b645d5a516c82694
Name                    ftp.example.tk
Edge Port               tcp/21
Origin
                        tcp://162.xx.xx.xx:21
Proxy Protocol          off
IP Firewall             On
Edge IPs Connectivity   all
Edge Tls                off
Traffic Type            direct
Created On              2021-06-30T20:11:29.140333Z
Modified On             2021-06-30T20:11:29.140333Z

3. 接続テスト

$ ftp
ftp> open ftp.example.tk 20021
Trying 172.xx.xx.xx...
Connected to ftp.example.tk (172.xx.xx.xx).
220 (vsFTPd 3.0.2)
Name (ftp.example.tk:syasuda): syasuda
331 Please specify the password.
Password:
230 Login successful.
Remote system type is UNIX.
Using binary mode to transfer files.
ftp> dir
227 Entering Passive Mode (xx,xx,xx,xx,xx,xx).
150 Here comes the directory listing.
-rw-r--r--    1 1000     1000            0 Jun 30 00:03 hoge
226 Directory send OK.
ftp> get hoge
local: hoge remote: hoge
227 Entering Passive Mode (xx,xx,xx,xx,xx,xx).
150 Opening BINARY mode data connection for hoge (0 bytes).
226 Transfer complete.
ftp>
4
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
4
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?