EverKB

Knowledge Base Ever

En CentOS-server med et dobbelt NIC installeret i LAN og forbundet til det dobbelte intranetsegment kan realisere samtidig adgang til dobbelt offentlig IP gennem routerport-videresendelse.

2019-11-11 17:09:37

tag: CentOS, dual network interfaces, ip command, Dual NIC, dual NIC routing, dual public IP

Scenario: En server er i LAN og leverer tjenester gennem routingens portkortlægning.Serveren er udstyret med dobbelt netværkskort, der hører til forskellige intranetsegmenter. Hvert netværkssegment har en offentlig IP-adresse, der er kortlagt til serveren.

Symptom: Den offentlige IP-adresse, der svarer til standard NIC i serverens to NIC'er, kan få adgang til serveren normalt, og den anden IP kan ikke fås adgang til.

Løsning: Du skal konfigurere de to offentlige IP-adresser for at få adgang til serveren. Antag, at de to netværkssegmenter er: 192.168.0 og 192.168.1, og IP-adresserne på serveren på de to netværkssegmenter er: 192.168.0.9 og 192.168.1.9, og netværkskortnavne er: enp2s0 og enp3s0. Routingkonfigurationen er som følger:
echo "101 Net1" >> /etc/iproute2/rt_tables
echo "102 Net2" >> /etc/iproute2/rt_tables

ip route add default via 192.168.0.1 dev enp2s0 table Net1
ip route add default via 192.168.1.1 dev enp3s0 table Net2

ip rule add from 192.168.0.9 table Net1
ip rule add from 192.168.1.9 table Net2

tag

CentOS7 CentOS PHP Linux Python3 Python MySQL MariaDB YUM JavaScript caching_sha2_password HTML mysql_native_password PHP7 CSS Redis MySQL8 daemon HTTP particles.js Slim Vincent Garreau Failed to build these modules: _uuid MongoDB Sudo DATE_ADD ip command pg_bha.conf SQL Server width Compiling Apache Frameworks MySQL-python scrollbar Tcp BBR Apache2.4 Elasticsearch libpython3.7m.so.1.0 PHPStorm ss5-3.8.9 CURLOPT_POSTFIELDS NodeJs show VIM Bluetooth Failed to build these modules: _ctypes Minimal ISO substr date sub INTERVAL PECL SQL Date Funcitons Wi-Fi CodeIgniter font-size root Tag Cloud apache httpd dual network interfaces Laravel ss5 CURLFille horiz-align node.js ShadowsocksR vertical-align BarManager exec mb_substr PyCharm SUBDATE date add IntelliJIDEA PEAR SOCKS5 Proxy Server WebStorm Chrome find remi Tag Apache du jQuery PHP5.5 src cURL hide nginx Shadowsocks-Python V2Ray availability eth0 MariaDB10.4 PostgreSQL sub folder date Install MongoDB pdo_sqlsrv SOCKS5 Web Server File Upload mssql-tools register_shutdown_function Symfony ADDDATE DevExpress JetBrain php-fpm sqlsrv Zend Framework height network interface Shadowsocks-Libev unixODBC-devel Aura error_get_last Port 80 string data INDENTIFIED BY password policy requirements SOCKS Web Development Fedora Media Writer msodbcsql Redis5 SVN absolute Deepin jemalloc SQLAlchemy convert FuelPHP mysqlclient Shadowsocks toggle at-symbol Error Control Operator margin PHPUnit Framework ss5.passwd daemon process IIS password SOCKET vps center Fatal Errors MongoDB4 sudoers .htaccess DATE_SUB Phalcon SQL Server 2017 WiFi Compiling PHP frequency conflict set_error_handler TestCase apr Elasticsearch7.3 PHPUnit ss5.conf