はじめての自宅サーバ構築 - Fedora/CentOS -
Last Update 2018/05/30
[ 更新履歴 ] [ サイト マップ ] [ 質問掲示板 ] [ 雑談掲示板 ] [ リンク ]
トップ >> 当サイト情報 >> スレッド

????????????????????¨????°???¨??§????????°???????¨??????¬???????????°?????±??????????????§??????

 バーチャルホストの重複
????????? 2008/02/27 08:59
????????? ばーちぇ

[warn] _default_ VirtualHost overlap on port 80, the first has precedence

バーチャルホストの設定をしたとき、上記のようなエラーが出てきます。
apacheを再起動した際にこのように出ました。
原因はポートが重複しているそうなのですが、どのように対処すればよいのかわかりません。
OSはCentOS 5.1です。よろしくお願いします。

■ コンテンツ関連情報

 Re: バーチャルホストの重複 ( No.1 )
????????? 2008/02/27 09:09
????????? バーチェ

BIND等はやっておりません。
もしかしてapacheの下記の部分を変更する必要があるのでしょうか?
apache解説ページの引用したものですみません。

#
# VirtualHost example:
# Almost any Apache directive may go into a VirtualHost container.
# The first VirtualHost section is used for requests without a known
# server name.
#
※:以下<VirtualHost xxx>〜</VirtualHost>ディレクティブ(xxx:nn)
 xxx:IPアドレス
 nn :ポート
特定のホスト名や IP アドレスのみに適用されるディレクティブを囲む
サーバが、指定されたバーチャルホストにあるドキュメントへの リクエストを受け付けた場合、
<VirtualHost> セクションの中にある ディレクティブが適用されます
#<VirtualHost *:80>
#  ServerAdmin webmaster@dummy-host.example.com
#  DocumentRoot /www/docs/dummy-host.example.com
#  ServerName dummy-host.example.com
#  ErrorLog logs/dummy-host.example.com-error_log
#  CustomLog logs/dummy-host.example.com-access_log common
#</VirtualHost>

〜 Sample 〜 「複数のドメインでアクセスを受けるようにするには?」
NameVirtualHostにWAN側IPアドレスを指定
NameVirtualHost xxx.xxx.xxx.xxx
abcdeドメイン側の設定
<VirtualHost xxx.xxx.xxx.xxx>
ServerName www.abcde.co.jp
ServerAdmin webmaster@abcde.co.jp
DocumentRoot /var/www/abcde
</VirtualHost>
vwxyzドメイン側の設定
<VirtualHost xxx.xxx.xxx.xxx>
ServerName www.vwxyz.co.jp
ServerAdmin webmaster@vwxyz.co.jp
DocumentRoot /var/www/vwxyz
</VirtualHost>
 Re: バーチャルホストの重複 ( No.2 )
????????? 2008/02/27 09:14
????????? 管理者

バーチャルホスト設定に「NameVirtualHost」ディレクティブは以下の様になっていますか?

NameVirtualHost *:80
 Re: バーチャルホストの重複 ( No.3 )
????????? 2008/02/27 09:22
????????? ばーちぇ

迅速な対応ありがとうございます。
現状では何も書いていなかったため下記の通りでした。

#NameVirtualHost *:80
#
# NOTE: NameVirtualHost cannot be used without a port specifier
# (e.g. :80) if mod_ssl is being used, due to the nature of the
# SSL protocol.
#

#
# VirtualHost example:
# Almost any Apache directive may go into a VirtualHost container.
# The first VirtualHost section is used for requests without a known
# server name.
#
#<VirtualHost *:80>
#  ServerAdmin webmaster@dummy-host.example.com
#  DocumentRoot /www/docs/dummy-host.example.com
#  ServerName dummy-host.example.com
#  ErrorLog logs/dummy-host.example.com-error_log
#  CustomLog logs/dummy-host.example.com-access_log common
#</VirtualHost>

これにNameVirtualHost *:80を追加して


#NameVirtualHost *:80
#
# NOTE: NameVirtualHost cannot be used without a port specifier
# (e.g. :80) if mod_ssl is being used, due to the nature of the
# SSL protocol.
#

NameVirtualHost *:80

#
# VirtualHost example:
# Almost any Apache directive may go into a VirtualHost container.
# The first VirtualHost section is used for requests without a known
# server name.
#
#<VirtualHost *:80>
#  ServerAdmin webmaster@dummy-host.example.com
#  DocumentRoot /www/docs/dummy-host.example.com
#  ServerName dummy-host.example.com
#  ErrorLog logs/dummy-host.example.com-error_log
#  CustomLog logs/dummy-host.example.com-access_log common
#</VirtualHost>


このようにすればよろしいのでしょうか・・?
よろしくお願い致します。
 Re: バーチャルホストの重複 ( No.4 )
????????? 2008/02/27 09:35
????????? 管理者

そうですね。
サンプルなので各バーチャル定義がどの様になっているか不明ですが、当サイトでも紹介しているので以下を参考なさってみてください。

『バーチャルホストの公開方法 : http://kajuhome.com/tips/tips_03_004.shtml
 Re: バーチャルホストの重複 ( No.5 )
????????? 2008/02/27 09:57
????????? ばーちぇ

NameVirtualHost 192.168.24.81
<VirtualHost 192.168.24.81>
ServerName main.com
ServerAdmin webmaster@main.com
DocumentRoot /var/www/html
</VirtualHost>

<VirtualHost 192.168.24.81>
ServerName sub.com
ServerAdmin webmaster@su.com
DocumentRoot /var/www/html/sub
</VirtualHost>

このように追記し、


<VirtualHost *:80>
  ServerName main.com
</VirtualHost>

<VirtualHost *:80>
  ServerName sub.com
  DocumentRoot /var/www/html/sub.com
  ErrorLog logs/virtual-error_log
  CustomLog logs/virtual-access_log combined env=!no_log
</VirtualHost>

このように設定しております。
このようにしたら、内部からのアクセスはできたのですが、外部からのアクセスはできないままでした。
また、ポートのエラーもでたままです。
何度もすみません、どうか他に問題の箇所を指摘してもらえないでしょうか・・・
apacheの必要最低限の設定のみをこのサイトを参考にさせていただき、バーチャル定義はこれ以外ではしtないつもりです。
どうかよろしくお願いします。
 Re: バーチャルホストの重複 ( No.6 )
????????? 2008/02/27 10:22
????????? 管理者

No.1のレスでBINDは構築していないとの事ですが、外部からはどのようにアクセスしているのでしょうか?
複数のドメインを所有していて、各々がばーちぇさんのグローバルIPに紐付いていますか?

再確認ですが、以下の様になっていますよね?

NameVirtualHost *:80
<VirtualHost *:80>
  :
  :
</VirtualHost>
<VirtualHost *:80>
  :
  :
</VirtualHost>

「*」はIPアドレスに置き換えず、そのまま「*」にして下さい。(上記構文のまま。)
 Re: バーチャルホストの重複 ( No.7 )
????????? 2008/02/27 10:59
????????? ばーちぇ

何度もありがとうございます。

>複数のドメインを所有していて、各々がばーちぇさんのグローバルIPに紐付いていますか?

ドメインは複数所有しておりますが、IPも同様に二つ必要であり、各ドメインに別々のグローバルIPを割り当てないといけないということでしょうか?
ひとつしかないので、BINDの設定をする必要があるということでしょうか?

また、先ほどの「*:80」となっておらず、これに変えたためエラーがでなくなりました。
しかしアクセスできないままですのでやはりグローバルIPなのでしょうか。
以前BINDがうまくいかず、諦めてそのままでしたので…
 Re: バーチャルホストの重複 ( No.8 )
????????? 2008/02/27 11:35
????????? 管理者

> ドメインは複数所有しておりますが、IPも同様に二つ必要であり、各ドメインに別々のグローバルIPを割り当てないといけないということでしょうか?

IPは1つで問題ありません。

apacheのバーチャル設定は2つの設定方法があります。「名前ベース」「IPベース」
簡単に説明すると以下の様になります。

「名前ベース」
 ・1つのIPアドレスで、複数のバーチャルホストを公開できる
  例)
     URL        G-IP         表示URL
    aaa.com  →  xxx.xxx.xxx.aaa  →  aaa.com
    bbb.com  ─────┘ ↑     →  bbb.com
    bbb.com  ───────┘     →  bbb.com
「IPベース」│┘
 ・複数のIPアドレスで、複数のバーチャルホストを公開できる
  例)
     URL        G-IP         表示URL
    aaa.com  →  xxx.xxx.xxx.aaa  →  aaa.com
    bbb.com  →  xxx.xxx.xxx.bbb  →  bbb.com
    bbb.com  →  xxx.xxx.xxx.ccc  →  bbb.com

よって、今回のばーちぇさんの構築は「名前ベース」となります。

> ひとつしかないので、BINDの設定をする必要があるということでしょうか?

BINDの設定をする必要は、何処を指していますか?
  ・外部のDNS設定?
  ・自サーバのDNS設定?
   自サーバの場合は、外部DNS公開向け?それともLAN内用?

外部のDNS、にばーちぇさんが取得したドメインを自身のグローバルIPに紐付けるならば、自サーバにBINDを構築する必要はありません。
ご自身が取得したドメインのレジストラで、複数のドメインをご自身のグローバルIP(1個)に紐付けてください。
※:レジストラの設定方法は、そのレジストラのページで確認下さい。(当方は説明できません)

ご自身のサーバを外部公開用のDNSとするならば、BIND(外向き用の設定)とレジストラにネームサーバの登録を行う必要があります。(難易度大)

一番良い方法は前者の方法で、レジストラにて一つのグローバルIPに対して取得した複数のドメインを紐付け(登録)するのが良いでしょう。

■ その他

ページ先頭へ


Copyright(©)2004-2018 First home server construction. All Right Reserved.