Модераторы: feodorv

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Как лучше организовать много-поточный сервер 
:(
    Опции темы
io2me
Дата 15.3.2006, 20:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 3.3.2006
Где: .NET

Репутация: нет
Всего: нет



Здраствуйте. Вот хотел спросить сабж.
Помоему есть 2 варианта:
1. Запустить N потоков, каждый ждет поключения (помоему что попало)
2. Запустить цыкл while, ожидающий подключения, и если ктото коннектиться обрабатывать его в потоки, чтобы сразу ждать других коннектов.

Что скажете ? Как лучше ?
PM MAIL   Вверх
adonin
Дата 16.3.2006, 12:18 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 166
Регистрация: 16.12.2005
Где: Новочеркасск Рост овская обл.

Репутация: 1
Всего: 5



Лучше так:

в основном потоке делаете listen(), затем accept(). accept() возвратит вам описатель нового сокета, через который вы можете общаться с данным клиентом.
После этого создаёте новый поток для работы через данный сокет. а в основном потоке опять делаете listen(). и accept().
--------------------
Тот, кто слизывает мед с крапивы, платит за него слишком дорого. (Томас ФУЛЛЕР)
PM MAIL   Вверх
io2me
Дата 16.3.2006, 15:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 3.3.2006
Где: .NET

Репутация: нет
Всего: нет



можно пример ?
PM MAIL   Вверх
adonin
Дата 16.3.2006, 17:25 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 166
Регистрация: 16.12.2005
Где: Новочеркасск Рост овская обл.

Репутация: 1
Всего: 5



Код

#include <conio.h>
#include <stdio.h>
#include <winsock2.h>

#pragma comment (lib, "ws2_32.lib")
#define MAX_PACKET_SIZE    0x10000
#define SIO_RCVALL         0x98000001

char src[10];
char dest[10];
char ds[15];
unsigned short lowbyte;
unsigned short hibyte;

DWORD WINAPI ThreadProc(
  LPVOID lpParameter   // thread data
)
{

    SOCKET S=(SOCKET)lpParameter; 
    // Работа с клиентом
    // recv(S,...);
    // send(S,...);
    // и т.д.

    return 1;
}
void main()
{
  WSADATA     wsadata; 
  SOCKET      s;  
  char        name[128]; 
  HOSTENT*    phe;       
  SOCKADDR_IN sa;        
  IN_ADDR sa1;        
  unsigned long        flag = 1;  

  WSAStartup(MAKEWORD(2,2), &wsadata);
  s = socket( AF_INET, SOCK_RAW, IPPROTO_IP );
  gethostname(name, sizeof(name));
  phe = gethostbyname( name );
  ZeroMemory( &sa, sizeof(sa) );
  sa.sin_family = AF_INET;
  sa.sin_addr.s_addr = ((struct in_addr *)phe->h_addr_list[0])->s_addr;
  bind(s, (SOCKADDR *)&sa, sizeof(SOCKADDR));

  SOCKADDR SIN;
  SOCKET S2;

  while(1)
  {
    DWORD TreadId;
    listen(s,10); // 10 - количество возможных соединений
    int i=sizeof(SIN);
    S2=accept(s,&SIN,&i);

    CreateThread(NULL,0,ThreadProc,(PVOID)S2,0,&TreadId);
  }
  closesocket( s );
  WSACleanup();
}



Примерно так. smile
--------------------
Тот, кто слизывает мед с крапивы, платит за него слишком дорого. (Томас ФУЛЛЕР)
PM MAIL   Вверх
io2me
Дата 16.3.2006, 17:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 3.3.2006
Где: .NET

Репутация: нет
Всего: нет



спасиб, идея понятна.. а можна без win32 ?
а то я буду на linux переводить !
PM MAIL   Вверх
adonin
Дата 16.3.2006, 17:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 166
Регистрация: 16.12.2005
Где: Новочеркасск Рост овская обл.

Репутация: 1
Всего: 5



Не-а smile
Спроси в форуме "Программирование под linux". Но принцип тот же. Особо переделывать не придётся.
--------------------
Тот, кто слизывает мед с крапивы, платит за него слишком дорого. (Томас ФУЛЛЕР)
PM MAIL   Вверх
io2me
Дата 16.3.2006, 21:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 8
Регистрация: 3.3.2006
Где: .NET

Репутация: нет
Всего: нет



да в том форуме все молчат )))
маздаевцы smile
PM MAIL   Вверх
YanTsys
Дата 23.3.2006, 01:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 77
Регистрация: 22.3.2006

Репутация: нет
Всего: нет



Как я понимаю после открытия сокет активен пока его принудительно не закрыть...
А нет нигде параметра позволяющего сокету автоматически закрываться в случае если оборвана связь?
Или нужно по таймеру делать опрос всех открытых сокетов на живность?
PM MAIL ICQ   Вверх
Kill_em_all
Дата 29.3.2006, 11:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 52
Регистрация: 2.4.2005

Репутация: нет
Всего: нет



А с помощью асинхронных сокетов?
Еще лучший вариант! Забудьте про использование
потоков для такой цели
PM MAIL   Вверх
adonin
Дата 29.3.2006, 13:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 166
Регистрация: 16.12.2005
Где: Новочеркасск Рост овская обл.

Репутация: 1
Всего: 5



Цитата(Kill_em_all @ 29.3.2006, 11:52 Найти цитируемый пост)
А с помощью асинхронных сокетов?

Так делать не хорошо: клиенты будут обслуживаться по очереди!!! им придётся ждать, если нагрузка на сервер будет значительной. И потом, если у вас многопроцессорная система, Вы получите значительный выигрыш в скорости, если будете использовать потоки.

Цитата(YanTsys @ 23.3.2006, 01:54 Найти цитируемый пост)
А нет нигде параметра позволяющего сокету автоматически закрываться в случае если оборвана связь?
Или нужно по таймеру делать опрос всех открытых сокетов на живность?

Жаль, нет под рукой MSDN. Скорее всего, уровень TCP скажет вам о разрыве соединения (recv не получит данные, а GetLastError возвратит ошибку!=0). Но, возможно и нет. Легче всего проверить на двух машинах: выдернуть сетевой кабель из клиента, когда сервер будет ожидать запрос.
Посмотрите функцию SetSockOpt() возможно там что-нибудь будет: что-то типа SO_KEEP_ALIVE

--------------------
Тот, кто слизывает мед с крапивы, платит за него слишком дорого. (Томас ФУЛЛЕР)
PM MAIL   Вверх
LuckLess
Дата 29.3.2006, 13:45 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 180
Регистрация: 15.9.2004

Репутация: нет
Всего: 1



Цитата(adonin @ 16.3.2006, 12:18 Найти цитируемый пост)
а в основном потоке опять делаете listen(). и accept().

listen опять не надо

Цитата(Kill_em_all @ 29.3.2006, 11:52 Найти цитируемый пост)
А с помощью асинхронных сокетов?
Еще лучший вариант! Забудьте про использование
потоков для такой цели

Цитата(adonin @ 29.3.2006, 13:26 Найти цитируемый пост)
Так делать не хорошо: клиенты будут обслуживаться по очереди!!! им придётся ждать, если нагрузка на сервер будет значительной. И потом, если у вас многопроцессорная система, Вы получите значительный выигрыш в скорости, если будете использовать потоки.

клиентам в любом случае придеться ждать. и к томуже 1 процесс может создать всего около 1300 потоков(в винде)
лучший вариант - комбинированный - асинхронные сокеты + потоки.
но не знаю как его реализовать под nix системы.
PM MAIL   Вверх
Romikgy
Дата 29.3.2006, 14:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель-программер
****


Профиль
Группа: Участник Клуба
Сообщений: 7326
Регистрация: 11.5.2005
Где: Porto Franco Odes sa

Репутация: нет
Всего: 146



Имхо в
Цитата(LuckLess @ 29.3.2006, 12:45 Найти цитируемый пост)
nix

нет потоков

Цитата(LuckLess @ 29.3.2006, 12:45 Найти цитируемый пост)
listen опять не надо

имхо надо , т.к. аксепт сьедает под себя сокет, а при создании нового ему снова надо говорит "слушай"


--------------------
Владение русской орфографией это как владение кунг-фу — истинные мастера не применяют его без надобности. 
smile

PM   Вверх
LuckLess
Дата 29.3.2006, 16:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 180
Регистрация: 15.9.2004

Репутация: нет
Всего: 1



Цитата(Romikgy @ 29.3.2006, 14:28 Найти цитируемый пост)
имхо надо , т.к. аксепт сьедает под себя сокет, а при создании нового ему снова надо говорит "слушай"

Не надо .
Листен лишь говорит какова максимальная очередь ожидающих соединения и все.
Добавлено @ 16:12
Цитата(Romikgy @ 29.3.2006, 14:28 Найти цитируемый пост)
нет потоков

Ну наверняка чтото похожее естьsmile
Добавлено @ 16:12
не fork()-иться же каждый раз..

Это сообщение отредактировал(а) LuckLess - 29.3.2006, 16:13
PM MAIL   Вверх
Бонифаций
Дата 29.3.2006, 16:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 827
Регистрация: 15.9.2005
Где: Brisbane

Репутация: нет
Всего: 40



Цитата(Romikgy @ 29.3.2006, 14:28 Найти цитируемый пост)
Имхо в
Цитата(LuckLess @ 29.3.2006, 12:45 Найти цитируемый пост)
nix

нет потоков


Есть. Куда же они денутся. mysql к примеру многопоточный сервер, oops прокси, firebird-ss.


--------------------
 Бонифаций.
 
PM MAIL ICQ Skype GTalk Jabber YIM   Вверх
Romikgy
Дата 29.3.2006, 16:53 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Любитель-программер
****


Профиль
Группа: Участник Клуба
Сообщений: 7326
Регистрация: 11.5.2005
Где: Porto Franco Odes sa

Репутация: нет
Всего: 146



Цитата(LuckLess @ 29.3.2006, 15:11 Найти цитируемый пост)
Не надо .
Листен лишь говорит какова максимальная очередь ожидающих соединения и все.

точно не надо аксепт создает новый сокет

Цитата(LuckLess @ 29.3.2006, 15:11 Найти цитируемый пост)
Ну наверняка чтото похожее есть

есть эт точно smile но что я не в курсе



--------------------
Владение русской орфографией это как владение кунг-фу — истинные мастера не применяют его без надобности. 
smile

PM   Вверх
Бонифаций
Дата 29.3.2006, 19:36 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 827
Регистрация: 15.9.2005
Где: Brisbane

Репутация: нет
Всего: 40



Цитата(YanTsys @ 23.3.2006, 01:54 Найти цитируемый пост)
А нет нигде параметра позволяющего сокету автоматически закрываться в случае если оборвана связь?
Или нужно по таймеру делать опрос всех открытых сокетов на живность?


А зачем? если связь оборвется, вы просто получите ошибку в recv() при приеме. Или сигнал SIGPIPE если будете писать в неисправный сокет.



--------------------
 Бонифаций.
 
PM MAIL ICQ Skype GTalk Jabber YIM   Вверх
040375
Дата 7.4.2006, 04:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 42
Регистрация: 6.4.2006

Репутация: 2
Всего: 2



Если Вы хотите писать многопоточный сервер, и писать будете под Линукс - то Вам лучше всего разобраться с вызовом select, именно с помощью него работает большинство серверов в линукс, т.к. у многопоточной идеи много минусов, рассказывать не буду про них - лучше найдите в инете ман, про select есть даже русский ман и разберитесь с ним. Весь смысл в том, что select "берёт на обслуживание" любое (по теории) кол-во сокетов не блокируя основной цикл программы и экономя ресурсы процессора при таймаутах. У этого вызова есть ещё библиотечная обработка - pselect - это более новая ф-я. Пример приводить не буду пока - их в инете предостаточно, могу позже про выслать по почте.
PM MAIL   Вверх
adonin
Дата 7.4.2006, 08:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 166
Регистрация: 16.12.2005
Где: Новочеркасск Рост овская обл.

Репутация: 1
Всего: 5



Цитата(040375 @ 7.4.2006, 04:43 Найти цитируемый пост)
многопоточной идеи много минусов

Покажите хотя бы один недостаток, чтобы утверждение голословным не было. Вообще говоря, существует только два способа обработки параллельных запросов: многопоточность и ассинхронный ввод/вывод. Остальные методы должны сводиться к одному из них. Итак, select сводится к одному из этих способов, следовательно, обладает его недостатками.
Если я не прав, поправьте меня.
--------------------
Тот, кто слизывает мед с крапивы, платит за него слишком дорого. (Томас ФУЛЛЕР)
PM MAIL   Вверх
adonin
Дата 7.4.2006, 08:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 166
Регистрация: 16.12.2005
Где: Новочеркасск Рост овская обл.

Репутация: 1
Всего: 5



Нашёл статью:
Подходы к организации серверного приложения
Итак, select - это разновидность ассинхронного ввода/вывода и ему присущи недостатки этого метода (см. статью)
Цитата

Сервер - процесс, использующий небольшое количество нитей, каждая
из которых обслуживает некоторое количество сокетов одновременно.

для Linux это лучший вариант.

Это сообщение отредактировал(а) adonin - 7.4.2006, 08:29
--------------------
Тот, кто слизывает мед с крапивы, платит за него слишком дорого. (Томас ФУЛЛЕР)
PM MAIL   Вверх
Necias
Дата 7.4.2006, 20:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 45
Регистрация: 7.4.2006

Репутация: нет
Всего: 2



жабер сервер - опенсорс, под линух, очень прямо написанный, можно работу с сокетами оттуда взять. Если кому интересно - в маздае эта проблема решается порождением класса CSocket в новом потоке. Но сервера с такой "в лоб" реализованной многопоточностью на коммерческом уровне не делаются ибо макс число потоков даже на Крее будет весьма ограниченным. Техника плавающего (до опр числа потоков в каждом изних находится по 1у сокету, затем они заполняются по 2й и тд) распределения сокетов не сложна, но безопасна и эффективна и при реализации многопоточности не следует о ней забывать.
PM MAIL ICQ   Вверх
blur
Дата 5.5.2006, 13:51 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 126
Регистрация: 9.11.2004

Репутация: 1
Всего: 1



А у меня вот такой вопрос: если к серверу будут подключаться десятки тысяч клиентов, то как в таком случае организовать их работу. Не в отдельный же поток каждого   smile  
PM MAIL   Вверх
cozzzy
Дата 5.5.2006, 14:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 54
Регистрация: 29.4.2006
Где: Харьков

Репутация: нет
Всего: нет



Использовать ACE  smile  
PM MAIL   Вверх
blur
Дата 5.5.2006, 14:50 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 126
Регистрация: 9.11.2004

Репутация: 1
Всего: 1



Цитата(cozzzy @  5.5.2006,  14:38 Найти цитируемый пост)
Использовать ACE 

Это что?
 
PM MAIL   Вверх
cozzzy
Дата 5.5.2006, 15:26 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 54
Регистрация: 29.4.2006
Где: Харьков

Репутация: нет
Всего: нет



Цитата(blur @  5.5.2006,  13:50 Найти цитируемый пост)
Это что?

The ADAPTIVE Communication Environment (ACE) 

Фактически - лучшая сетевая библиотека, которой пользуются многие крупнейшие компании. 
Кроссплатформенная, гибкая, защищенная + достаточно легка в изучении и использовании
 
PM MAIL   Вверх
Nuzur
Дата 20.6.2006, 16:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1019
Регистрация: 4.7.2004

Репутация: нет
Всего: 5



cozzzy, А можете в 2-х словах описать как им пользоваться?
А то я чего-то недопонял... Вещица интерестная особенно прочитав кто ею пользуеться... 
Есть ли какое-то опиание сего на русском? 

Это сообщение отредактировал(а) Nuzur - 20.6.2006, 16:05


--------------------
Never again...
PM MAIL   Вверх
Nuzur
Дата 21.6.2006, 16:59 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1019
Регистрация: 4.7.2004

Репутация: нет
Всего: 5



Не все-таки не смог я АСЕ осилить, буду пользоваться стандартными средствами! 

Это сообщение отредактировал(а) Nuzur - 21.6.2006, 17:02


--------------------
Never again...
PM MAIL   Вверх
Nuzur
Дата 22.6.2006, 09:20 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Завсегдатай
Сообщений: 1019
Регистрация: 4.7.2004

Репутация: нет
Всего: 5



adonin, Что-то я очень плохо понял ваш пример, тоесть до упора создаються потоки причем потом даже с "пустыми" сокетами. Всем все побарабану, подключился к нему кто-то или нет...
Можете пролить свет на происходящее? 

И код клиента который будет конектиться к такому серверу как бут выглядить? 

Это сообщение отредактировал(а) Nuzur - 22.6.2006, 09:46


--------------------
Never again...
PM MAIL   Вверх
Goryachev
Дата 29.3.2007, 16:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 67
Регистрация: 23.2.2005
Где: Израиль

Репутация: нет
Всего: нет



Цитата(Romikgy @  29.3.2006,  14:28 Найти цитируемый пост)
Имхо в 

Цитата(LuckLess @ 29.3.2006, 12:45 )
nix


нет потоков


А про pthread.h слышали? POSIX threads standard.
Работает отлично в nixe.

Для компиляции, используйте -lpthread флаг

Это сообщение отредактировал(а) Goryachev - 29.3.2007, 16:52
PM MAIL   Вверх
Owen
Дата 30.3.2007, 12:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 71
Регистрация: 5.7.2006
Где: Русь

Репутация: нет
Всего: нет



Под 'nix'ом не писал, но  почему не использовать такое явление, как порты завершения?( CreateIOCompletionPort( ) ) Это будет вполне логично, в случае если сервер расчитан на большое кол-во пользователей.

Создавать потоки на каждый сокет имеет смысл лишь в том случае, если ожидается сравнительно мелое количество пользователей. На мой взгляд около 20. Однако от многопотоковости отказываться не стоит. Просто распределить обработку данных на несколько потоков. Особенно продуктивно в многопроцессорных машинах.
PM ICQ   Вверх
SenkraD
Дата 6.4.2007, 17:09 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 933
Регистрация: 3.2.2006
Где: Украина::Киев

Репутация: 1
Всего: 23



Могу вывесить свой курсач по Linux - это HTTP - сервер. Там несколько вариантов работы сервера и через fork, и через потоки, и через пул потоков.

Если надо пиши!


--------------------
 Имеющий язык - да не убоится спросить! 
user posted image
PM MAIL ICQ   Вверх
phprus
Дата 14.4.2007, 08:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 129
Регистрация: 22.8.2006

Репутация: 1
Всего: 3



SenkraD
Если вам не трудно, то пожалуйста выложите.
PM MAIL WWW ICQ   Вверх
SenkraD
Дата 17.4.2007, 18:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 933
Регистрация: 3.2.2006
Где: Украина::Киев

Репутация: 1
Всего: 23



Вот.

Присоединённый файл ( Кол-во скачиваний: 48 )
Присоединённый файл  tshttpd.rar 27,82 Kb


--------------------
 Имеющий язык - да не убоится спросить! 
user posted image
PM MAIL ICQ   Вверх
phprus
Дата 17.4.2007, 19:54 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 129
Регистрация: 22.8.2006

Репутация: 1
Всего: 3



SenkraD
Спасибо.
PM MAIL WWW ICQ   Вверх
Страницы: (3) [Все] 1 2 3 
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Сети | Следующая тема »


 




[ Время генерации скрипта: 0.1263 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.