To test vCSA 6.5 built-in backup, I need a FTP server. Since I already have a Windows Server 2012 R2 running IIS 8 with web service, adding the FTP server feature is just a few clicks.
Even I have not used the Microsoft FTP server since IIS 6, and there are lot of changes between IIS 6 and IIS 8, I thought setting up the FTP server should be a piece of cake. I was wrong! The following are what I have learned on setting up the FTP server in IIS 8.
Lesson #1: Windows Firewall
After installing the FTP service and creating a new FTP site in IIS Manager, I can’t connect to the FTP site from a remote computer; FTP from the server to itself is okay. It must be a Windows firewall issue.
- I check the Windows Firewall’s Inbound Rules, three FTP rules are created and enabled; and Outbound Rules, two FTP rules are created and enabled. I guess they are automatically created by the FTP service installation. These rules look right, but I still can’t connect from a remote computer.
data:image/s3,"s3://crabby-images/c0d74/c0d7491c0c7b78c9aebee1cf24ff8a30ec572d5c" alt="Windows.Firewall.Inbound.Rule.FTP Windows.Firewall.Inbound.Rule.FTP"
data:image/s3,"s3://crabby-images/541ed/541edcf38cc1d62857d1c7319ffd01969482fd0d" alt="Windows.Firewall.Outbound.Rule.FTP Windows.Firewall.Outbound.Rule.FTP"
- Disabling the Windows Firewall on the server, I can connect. This confirms the Windows Firewall causing the issue, but what is the problem? I don’t want to disable Windows Firewall.
- The default FTP rules are allowed the program “%windir%\system32\svchost.exe”. I’m not sure what the executable runs the FTP service. (Later, I find it via Microsoft FTP Service, General, Path to executable: “C:\Windows\system32\svchost.exe -k ftpsvc”)
- I created my own FTP rules required in my case - two inbound rules and one outbound rule (highlighted in above pictures) with the same protocol and port number, except that I allow any program. This works! I can connect to the FTP site from a remote computer. (Actually, see Lesson #2 below - it’s not fully working yet. I get another error after entering the login name).
- I think the default FTP rules don’t work, until I find this post.
- I delete the FTP rules I created, and restart the “"Microsoft FTP Service”. The FTP connect is still working.
Summary:
- When troubleshooting issues related to Windows Firewall, restart the application service or the server after adding or changing the rules.
- Restarting the FTP site in IIS Manage does not work; disabling and enabling the firewall or rule does not work. Restarting the FTP service is required.
Lesson #2: FTP site virtual host name
After the connection problem is resolved (see lesson #1), I continue further on the FTP login. However, after entering the user name, I get the error message “530 Valid hostname is expected. Login failed”.
data:image/s3,"s3://crabby-images/bbb2b/bbb2b2d662facffb118628aeb21064dc3f56dc6e" alt="FTP.Valid.Hostname.Is.Expected FTP.Valid.Hostname.Is.Expected"
After searching the error message, I learn about the FTP virtual host name
In the past I had used the IIS web site virtual hostname to handle multiple web sites on a single IP address and port number. But I don’t recall if the FTP service in IIS 6 has the host name option. When creating the FTP site, I entered the DNS name of the FTP site as the host name.
data:image/s3,"s3://crabby-images/7a415/7a41535221dcc445a1564579d4eb1384c50d62ff" alt="FTP.Host.Name FTP.Host.Name"
Summary:
- use <ftp virtual hostname>|<ftp username> as the login name for the FTP server uses the virtual hostname
data:image/s3,"s3://crabby-images/05324/05324c1a0c4de00ddfbc5c847d66b3e735bd9907" alt="FTP.Virtual.Hostname.Login FTP.Virtual.Hostname.Login"
- If you are not going to run multiple FTP sites on the same IP address and port number, leave the host name blank.