У меня два разных доменных имени, которые я хочу разместить на одном и том же частном хостинге. Я хочу, чтобы они указывали на один и тот же IP-адрес, но при этом имели разный контент (конечно). Как я могу это сделать? Есть разные способы сделать это? В таком случае, как лучше всего. Спасибо.
Apache2 поддерживает обслуживание различного содержимого в зависимости от доменных имен, даже если все эти домены относятся к одному и тому же IP-адресу. Каждое из доменных имен обрабатывается виртуальный хост, таким образом, имя виртуальный хост на основе имени.
Вот пример конфигурации для двух доменов:
NameVirtualHost *:80
<VirtualHost *:80>
ServerName www.yourfirstdomain.tld
DocumentRoot /www/yourfirstdomain.tld/
</VirtualHost>
<VirtualHost *:80>
ServerName www.yourseconddomain.tld
DocumentRoot /www/yourseconddomain.tld/
</VirtualHost>
Вы найдете официальную документацию на поддержка виртуального хоста на основе имени здесь.
Однако обратите внимание, что это будет работать только с обычными HTTP-соединениями, а не с HTTPS (HTTP через SSL): виртуальные хосты на основе имен полагаются на знание того, какое имя запрашивается, но эта информация не может быть известна Apache, пока не будет зашифрован SSL соединение установлено.
Если вам нужно, чтобы ваша установка также работала с HTTPS, вам нужно полагаться на расширение протокола SSL, называемое Индикация имени сервера (SNI) (RFC4366). По сути, клиенты с поддержкой SNI (например, веб-браузеры) добавляют дополнительную текстовую информацию при установке зашифрованного SSL-соединения, позволяя серверу узнать запрошенное имя до того, как SSL-соединение будет готово.
Все браузеры пока не поддерживают SNI. На момент написания и согласно Википедии, эти:
Для размещения нескольких виртуальных хостов на основе имен, доступных через HTTPS, необходимо включить mod_ssl и добавить конфигурацию, аналогичную приведенной в примере выше:
Listen 443
NameVirtualHost *:443
# Accept connections for these vhosts from non-SNI clients
# Clients without SNI will be handled by the first defined vhost.
# If you only want SNI-enabled client, put on instead
SSLStrictSNIVHostCheck off
<VirtualHost *:443>
ServerName www.yourfirstdomain.tld
DocumentRoot /www/yourfirstdomain.tld/
</VirtualHost>
<VirtualHost *:443>
ServerName www.yourseconddomain.tld
DocumentRoot /www/yourseconddomain.tld/
</VirtualHost>
Помните, что использование SSL требует, чтобы вы купили SSL-сертификаты для своих доменов или сгенерировали несколько автоматически подписанных сертификатов и настроили Apache для использования их для SSL-соединений.
Вероятно, вы захотите использовать виртуальный хостинг Apache. Это хорошо поддерживаемый метод для размещения множества доменов на одном IP-адресе.
http://httpd.apache.org/docs/2.2/vhosts/
В частности, виртуальные хосты на основе имен: http://httpd.apache.org/docs/2.2/vhosts/name-based.html