🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

ルーティング

ルーティングとは、TCP/IPネットワークにおいて、目的のホストまでパケットを送る為のパス選定のプロセスを言います。

ネットワーク

ネットワークとは、複数のコンピューター間を接続する技術です。インターネットが最も主流なネットワークの形態で、TCP/IP・HTTP・DNSなどの様々なプロトコルや、ルータやサーバーなどの様々な機器の上に成り立っています。

Q&A

解決済

1回答

1369閲覧

packetの経路変更ができません

urbainleverrier

総合スコア200

CentOS

CentOSは、主にRed Hat Enterprise Linux(RHEL)をベースにした、フリーのソフトウェアオペレーティングシステムです。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

ルーティング

ルーティングとは、TCP/IPネットワークにおいて、目的のホストまでパケットを送る為のパス選定のプロセスを言います。

ネットワーク

ネットワークとは、複数のコンピューター間を接続する技術です。インターネットが最も主流なネットワークの形態で、TCP/IP・HTTP・DNSなどの様々なプロトコルや、ルータやサーバーなどの様々な機器の上に成り立っています。

0グッド

0クリップ

投稿2019/09/15 06:45

編集2019/09/15 16:20

実現したいこと

  • 内部のサーバー同士をprivateな通信にさせたいです
  • globalなnetworkの帯域を消費させたくないと思っています

わからないこと

クラスターを組んでいるサーバー同士で、global ip addressを使ってWANで通信するところを、LANのinterfaceの経路に変更したのですが、一部WANのinterfaceを使う通信が起きるのはなぜでしょうか。
iptablesではLANに向かわせたいpacketを完全に捕捉できていると思うのですが、なぜかWANになってしまいます。

起きている問題

eth0がglobal networkのinterfaceです。

root@host ~]# tcpdump -ieth0 dst host 150.22.10.3 -n tcpdump: verbose output suppressed, use -v or -vv for full protocol decode listening on eth0, link-type EN10MB (Ethernet), capture size 262144 bytes 15:38:28.418688 IP 150.22.13.3.sun-sr-https > 150.22.10.3.48112: Flags [.], ack 4010106138, win 270, options [nop,nop,TS val 1732446 ecr 44156350], length 0

150.22.13.3と150.22.10.3が内部のhostです。これをWAN用のeth0を使うことなく、eth1以降のLAN用のinterfaceを使って通信をしたいです。

設定した内容

ipsetでhostのaddressを登録し、iptablesでOUTPUT CHAINとFORWARD CHAINで宛先がipsetに合致するものをMARKしました。
policy based routingでMARKされたpacketをLANのinterfaceに流すといった具合に行いました。

ipset

[root@host ~]# ipset list internal-hosts Name: internal-hosts Type: hash:net Revision: 6 Header: family inet hashsize 1024 maxelem 1048576 Size in memory: 1272 References: 2 Number of entries: 14 Members: 150.22.10.3 150.22.12.4 ...

iptables

[root@host ~]# iptables -t mangle -nvL | grep MARK -B2 -A2 Chain FORWARD (policy ACCEPT 11083 packets, 3982K bytes) pkts bytes target prot opt in out source destination 434K 154M MARK all -- * * 0.0.0.0/0 0.0.0.0/0 match-set internal-hosts dst MARK set 0x100000 0 0 ACCEPT all -- * * 0.0.0.0/0 150.22.10.3 mark match ! 0x100000/0x100000 1200 251K ACCEPT all -- * * 0.0.0.0/0 150.22.10.3 mark match 0x100000/0x100000 -- Chain OUTPUT (policy ACCEPT 104 packets, 11776 bytes) pkts bytes target prot opt in out source destination 102 4576 MARK all -- * * 0.0.0.0/0 0.0.0.0/0 match-set internal-hosts dst MARK set 0x100000 0 0 ACCEPT all -- * * 0.0.0.0/0 150.22.10.3 mark match ! 0x100000/0x100000 0 0 ACCEPT all -- * * 0.0.0.0/0 150.22.10.3 mark match 0x100000/0x100000 [root@host ~]# iptables -t filter -L | grep MARK -B2 [root@host ~]# iptables -t nat -L | grep MARK -B2 [root@host ~]# iptables -t raw -L | grep MARK -B2 [root@host ~]

ip rule

[root@host ~]# ip rule show 0: from all lookup local 100: from all fwmark 0x100000/0x100000 lookup ecmp 32766: from all lookup main 32767: from all lookup default

ip route

eth1-eth5がprivateなinterfaceです。

[root@host ~]# ip r show table ecmp 150.22.0.0/16 src 150.22.13.3 nexthop dev eth1 weight 1 nexthop dev eth2 weight 1 nexthop dev eth3 weight 1 nexthop dev eth4 weight 1 nexthop dev eth5 weight 1

150.22.0.0/16はお借りしているvpsサーバーのもつaddressです。
srcで指定している150.22.13.3は、iptablesやrouteが設定されている対象のhostです。

追記1

コメントを受けまして、
以下のようにeth1(LAN)にrouteを追加するとeth0(WAN)へのpacketはなくなりました。

[root@host ~]# ip route add 150.22.10.3/32 dev eth1

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

TaichiYanagiya

2019/09/15 08:29

よくわかりませんが、150.22.10.3 ホストから "arping -I eth1 150.22.13.3" で eth1 宛 ARP に応答するなら(デフォルト arp_ignore = 0)、"ip route add 150.22.13.3/32 dev eth1" でいいのではないでしょうか。 仮想サーバー、仮想スイッチで、ARP の扱いが物理と違うのであれば、ダメかもしれませんが。
urbainleverrier

2019/09/15 08:47

質問いただきありがとうございます。 "ip route add 150.22.13.3/32 dev eth1"にすると、eth1からeth5まで、またホストの数だけルーティングを記入しなければいけなくなり、ホストの数が増えると管理できなくなる気がしました。 その解決策としてipsetを使ったのですが、どうでしょうか。
urbainleverrier

2019/09/15 08:49 編集

ip route addの結果も追記いたします。申し訳ございませんが、夜間に追記させていただきます。
urbainleverrier

2019/09/15 15:54

150.22.10.3宛のpacketについては、iptablesで全てMARKしていると思うのですが、なぜmainのtableまで通過するのでしょうか。
guest

回答1

0

自己解決

投稿2019/09/15 17:41

urbainleverrier

総合スコア200

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問