Re: расщепить на несколько хостов
- From
- Valentin Davydov (2:5020/400)
- To
- Vadim Goncharov (2:5054/37.63)
- Date
- 2006-12-11T10:32:58Z
- Area
- RU.UNIX.BSD
From: Valentin Davydov <val@sqdp.trc-net.co.jp>
> From: Vadim Goncharov <vadimnuclight@tpu.ru>
> Date: Fri, 8 Dec 2006 16:16:18 +0000 (UTC)
>
> >>Есть хост А и некий сервер Б. Софтина на хосте А хочет сделать множество
> >>подключений к серверу Б на порт определенного сервиса, но у сервиса вшит
> >>низкий лимит на одновременное количество TCP-соединений с одного IP-адреса.
> >>Хочется странного: прозрачно для хостов А и Б, представить для сервера Б
> >>соединения приходящими с разных (фэйковых) IP-адресов (роутинг
> >>обеспечить можно). Но не представляю, как.
> VD> Совсем-совсем прозрачно? Нельзя ли, скажем, софтине велеть, чтобы она не
> VD> на Б ходила, а на (пусть тот же порт на) А?
>
>Можно, конечно, сменить ей адрес и порт, забыл написать (просто он один,
>а не несколько).
>
> VD> А на хосту А на этот порт
> VD> повесить tcp-proxy, слепленный жвачкой из inetd, netcat, bounce и т.д.
> VD> и умеющий всё что ни попадя, в том числе и src ip round-robin.
>
>Хм, а вот тут поподробнее - как это будет выглядеть? Эти src ip таки
>придется алиасами вешать или оно (кстати, кто из связки?) умеет
>raw-сокеты?
Берёшь сетку, скажем, 10.40/16. Пишешь на сервере Б роутинг на эту сетку
так, чтобы он доходил до хоста А. Затем на хосту А ставишь все 65536 адресов
из этой сетки на lo0 алиасами (с маской 32, разумеется). Пишешь в inetd.conf
слушать тот порт, на который будет ходить твоя софтина, и запускать на каждое
соединение примерно такой скрипт:
#!/bin/sh
exec nc -s 10.40.$(sockstat -4 -c |\
awk "\$3==$$&&\$4==0{gsub(\".*:\",\"\",\$7);
print int(\$7/256) \".\" \$7%256}"\
) $Б $порт_сервера
Там ещё могут быть всякие тонкости, связанные с ограничениями количества
одновременных соединений в inetd, корректностью закрытия tcp-соединений
клиентом и/или сервером, environmentом запускаемых из скрипта команд, но
при должной аккуратности всё это более-менее тривиально настраивается.
Вал. Дав.
--- ifmail v.2.15dev5.3
* Origin: Demos online service (2:5020/400)
SEEN-BY: 50/12 400/814 450/159 1024 461/43 132 640 469/999 4616/3 4625/8
SEEN-BY: 4641/444 5000/76 5000 5006/1 5007/1 5010/70 5011/13 5012/46 5015/28
SEEN-BY: 5019/26 5020/18 175 194 400 545 982 1057 1909 1922 2238 2395 2871
SEEN-BY: 5020/4441 5021/29 5025/3 5026/14 45 5027/12 5030/1080 1957 5034/10 13
SEEN-BY: 5035/3 38 5036/1 5045/7 5049/1 5051/15 5054/1 4 8 9 11 28 35 36 37 45
SEEN-BY: 5054/66 67 70 75 84 85 5059/9 5060/88 5061/15 5062/10 5063/3 5064/7
SEEN-BY: 5066/18 5075/5 5076/1 5077/70 5080/1003 5084/9 5085/13 5095/20
SEEN-BY: 5096/18 6001/10
PATH: 5020/400 545 5054/1 37