Russian Qt Forum
Ноябрь 23, 2024, 20:56
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Общие вопросы
>
[РЕШЕНО] Вебсервер: логика маршрутизации
Страниц:
1
[
2
]
3
4
...
6
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: [РЕШЕНО] Вебсервер: логика маршрутизации (Прочитано 38750 раз)
V1KT0P
Гость
Re: Вебсервер: логика маршрутизации
«
Ответ #15 :
Май 01, 2012, 22:13 »
Цитата: alexis031182 от Май 01, 2012, 21:49
Можно и так конечно, но этот вариант мне не нравится. Ради простейшей в общем-то ситуации...
Цитата: alexis031182 от Май 01, 2012, 21:49
Регистратора соответствия хостов сайтам - да. Но не запросов. Хост - составная часть в запросе.
Цитата: alexis031182 от Май 01, 2012, 21:49
То есть делегировать плагинам возможность устанавливать статус ответа? Этот вариант мне понятен, он вроде как сам собой напрашивается, но мне не хочется передавать таковые полномочия плагинам. В Апаче, вроде, этого нет. Заголовки там всякие - это пожалуйста, а вот статус... Да и ситуация с иконкой говорит о том, что могут возникнуть всяческие недоразумения, что приведёт к снижению производительности. То есть подобные вещи, по идее, не должны касаться сайта. Он там у себя колупается в своей песочнице, и не особо лезет на сервер. Это было бы гут.
Снова ты не понимаешь. Допустим запускается сервер. У сервера есть два плагина forumPlugin и newsPlugin. Каждый из них регистрирует обработчик.
forumPlugin просто регистрирует forum.
newsPlugin регистрирует регулярку которая проверяет что запрос имеет вид даты типа 2012/05/01.
Далее рассмотри запросы:
forum/thread_9000
Сервер сперва проверяет наличие обработчика forum, находит его и передает ему запрос thread_9000. Обработчик парсит его и получает thread и 9000. По логике первое значение это команда, в данном случае thread возвращает страницу с темой номер 9000.
forum/post_100500
Тоже самое но возвращается страница показывающая только одно собщение номер 100500.
forum/blabla
Тоже самое но плагин не находит команду blabla. Если плагин не предусмотрел вывод сообщения о том что темы нет, то просто возращает серверу ошибку. Сервер уже разбирается что делать, то ли кидать на главную то-ли ошибку 404. Если же плагин предусмотрел ошибку то либо показ ошибки либо переброска на главную страницу форума.
2012/05/01/Super_News
Сервер сперва проверяет наличие обработчика 2012, не находит. Дальше проверяет обработчик регулярок. Находит обработчик newsPlugin, и передает ему строку 2012/05/01/Super_News. Новостной плагин парсит строку и выдает страницу новости. Если нету то либо сообщение об ошибке из плагина, либо переадрисация на главную новостей или сайта либо отдача ошибки серверу, который сам решит что делать на главную переадресовать или ошибку послать.
2013/05/01/Blabla
Тоже самое но ошибка.
favicon.ico
Сервер проверяет на наличие обработчика favicon.ico, не находит. Дальше проверяет обработчик регулярок. Тоже не находит. Дальше проверяет на наличие файла на диске. Если не находит то отсылает 404 (как это делает апач).
blablabla/bla
Тоже самое не находит обработчик blablabla и нет совпадений в регулярках. И файла такого нету, возвращает 404 (как это делает апач), либо перекидывает на главную сайта.
Записан
alexis031182
Гость
Re: Вебсервер: логика маршрутизации
«
Ответ #16 :
Май 01, 2012, 22:44 »
Да, понял теперь, что ты имеешь ввиду, но у меня как бы немного иначе построено. Рассматриваемые плагины forumPlugin и newsPlugin - это не что иное, как, например, forum.ru и news.ru (при этом на тот же forumPlugin может указывать и другой хост - forum.com). То есть плагин - это сайт.
Всё, что идёт после имени хоста относится уже к конкретному плагину. Допустим я предварительно зарегистрирую его обработчик. Тогда как-то на регулярках сайт должен будет описать все возможные варианты, ведь favicon и favicon.ico - могут присутствовать вместе: первый, как страница, а второй, как файл. И если, допустим, сейчас я, как разработчик конкретного сайта, не использую этот злосчастный favicon.ico, а потом добавлю его в папку на сервере, то мне придётся править код плагина, и выполнять перекомпиляцию dll-ки.
Это конечно вариант. Надо обмозговать идею с обработчиками, спасибо,
V1KT0P
. Просто я хотел сделать так, чтобы разработчик сайта по минимуму определял вариации, ограничившись, например, лишь чем-то подобным:
/action
и/или
/controller/action
и/или
/module/controller/action
.
Записан
V1KT0P
Гость
Re: Вебсервер: логика маршрутизации
«
Ответ #17 :
Май 01, 2012, 22:57 »
Цитата: alexis031182 от Май 01, 2012, 22:44
Тогда как-то на регулярках сайт должен будет описать все возможные варианты, ведь favicon и favicon.ico - могут присутствовать вместе: первый, как страница, а второй, как файл.
Повторю еще раз сперва проверяется наличие файла на диске, если его нет то происходит попытка вызова динамического контента. Проще всего для этого использовать nginx, он для этого и создавался.
Записан
alexis031182
Гость
Re: Вебсервер: логика маршрутизации
«
Ответ #18 :
Май 01, 2012, 23:08 »
Цитата: V1KT0P от Май 01, 2012, 22:57
Повторю еще раз сперва проверяется наличие файла на диске, ...
Да, да, это само собой. Я так и сделал пока.
Цитата: V1KT0P от Май 01, 2012, 22:57
... если его нет то происходит попытка вызова динамического контента.
Да, пожалуй. Только управление статусом ответа пихать в плагины не буду, лишь просто возврат ошибки, а сервер подытожит: 404 или ещё какой вариант.
Цитата: V1KT0P от Май 01, 2012, 22:57
Проще всего для этого использовать nginx, он для этого и создавался.
Статику мой сервер отдаст прекрасно и без nginx. Дополнительная прослойка не нужна в данном случае. Это больше для Апача актуально, где множество предварительных "настроечных" действий выполняется, прежде чем возникнет решение об отдаче.
Спасибо
Записан
Bepec
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #19 :
Май 02, 2012, 06:57 »
Совет - используй уже имеющиеся наработки. Сотни, если не тысячи разработчиков реализовали почти все идеи, которые можно реализовать в веб направлении. Ну или описали, почему не стоит реализовывать.
Собственный велосипед - хорошо, поехали. А вот собственный танк уже плохо - то с места не сдвинется, то боезапас взорвётся
Записан
alexis031182
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #20 :
Май 02, 2012, 09:59 »
Цитата: Bepec от Май 02, 2012, 06:57
Совет - используй уже имеющиеся наработки.
Тогда и писать ничего не надо
Цитата: Bepec от Май 02, 2012, 06:57
Сотни, если не тысячи разработчиков реализовали почти все идеи, которые можно реализовать в веб направлении. Ну или описали, почему не стоит реализовывать.
Да наверное и без "почти" реализовали. Но мне сам процесс интересен. Разработка ради разработки - это не великий гут, но если прёт, то и хорошо ))
Цитата: Bepec от Май 02, 2012, 06:57
Собственный велосипед - хорошо, поехали. А вот собственный танк уже плохо - то с места не сдвинется, то боезапас взорвётся
Этот результат может получить в итоге и не только велосипедо-ваятель
А вообще, я поставил скорость работы программы в наивысший приоритет. Очень приятно смотреть, как в считанные миллисекунды формируется страница. Скорость передачи - тут уж не улучшить, от сетей зависит (сжатие само собой использовать буду), но наблюдать за скоростью работы сайта на С++ очень интересно. Особливо, когда вспоминаешь потуги пыхпыха.
Записан
Bepec
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #21 :
Май 02, 2012, 10:09 »
Извиняюсь, а можно результаты в студию?
Страница сгенерирована за 0.059 секунд. Запросов: 19. - Это форумный php выдаёт. А у вас? Стоило того?
Записан
alexis031182
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #22 :
Май 02, 2012, 10:25 »
Цитата: Bepec от Май 02, 2012, 10:09
Извиняюсь, а можно результаты в студию?
Пока в худшем и редком случае 0.002, а так 0.000 - 0.001. Но справедливости ради следует заметить, что я лишь собрал пока простенький статический документ и без обращения к БД (начал писать проект недавно). Ориентируюсь для себя на скорость 0.020 - таковую заметил у главной страницы гугла.
Цитата: Bepec от Май 02, 2012, 10:09
Страница сгенерирована за 0.059 секунд. Запросов: 19. - Это форумный php выдаёт. А у вас? Стоило того?
Форум на кеше сидит, если его отключить, вообще каюк будет. А если на кеше, да на С++, я думаю определённо имеет смысл хотя бы поэкспериментировать.
Записан
V1KT0P
Гость
Re: Вебсервер: логика маршрутизации
«
Ответ #23 :
Май 02, 2012, 14:02 »
Цитата: alexis031182 от Май 01, 2012, 23:08
Статику мой сервер отдаст прекрасно и без nginx. Дополнительная прослойка не нужна в данном случае. Это больше для Апача актуально, где множество предварительных "настроечных" действий выполняется, прежде чем возникнет решение об отдаче.
Я бы не стал недооценивать nginx. Ты вообще знаешь зачем стали ставить фронтэнды? Причина банальна: быстрое освобождение простаиваемых мощностей из-за того что отдача контента не моментальна. Решили все путем добавления фронтэнда которому сразу отдается запрос и осовобождаются ресурсы. А уж фронтэнд оптимизирован под отдавание контента. Также я бы на твоем месте сразу начертил на листе А1 архитектуру сервера. И по максимуму использовал бы динамическое подключение всего и вся. Чтоб одной кнопкой можно было на лету например заменить старый плагин форума на новый. Да да я все-таки за плагины. Зачем перекомпиливать весь сервер если можно всего навсего перекомпилить один плагин и заменить его без перезапуска онного сервера?
Записан
alexis031182
Гость
Re: Вебсервер: логика маршрутизации
«
Ответ #24 :
Май 02, 2012, 14:42 »
Цитата: V1KT0P от Май 02, 2012, 14:02
Я бы не стал недооценивать nginx. Ты вообще знаешь зачем стали ставить фронтэнды? Причина банальна: быстрое освобождение простаиваемых мощностей из-за того что отдача контента не моментальна. Решили все путем добавления фронтэнда которому сразу отдается запрос и осовобождаются ресурсы. А уж фронтэнд оптимизирован под отдавание контента.
Нет, нет, я не недооцениваю. Если понадобится, будет резон, то почему бы и нет. А статический контент я у себя отдаю сразу же, без дополнительных телодвижений в плагинах.
Цитата: V1KT0P от Май 02, 2012, 14:02
Также я бы на твоем месте сразу начертил на листе А1 архитектуру сервера.
Это хорошая идея. Документированием я не занимался ещё. Через одно место получается делаю ))
Цитата: V1KT0P от Май 02, 2012, 14:02
И по максимуму использовал бы динамическое подключение всего и вся. Чтоб одной кнопкой можно было на лету например заменить старый плагин форума на новый. Да да я все-таки за плагины. Зачем перекомпиливать весь сервер если можно всего навсего перекомпилить один плагин и заменить его без перезапуска онного сервера?
Именно так и сделано. Для изменения сайта достаточно заменить файл либы, ну и выполнить на сервере функция загрузки. То есть, что-то типа "горячего" переподключения имеется.
Записан
alexis031182
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #25 :
Май 06, 2012, 17:48 »
Всем привет
Кто может сейчас протестировать вебсервер? Помогите, пожалуйста
По этому адресу -
http://78.81.31.38/qqq.webm
- видеоролик (осторожно, 20 Мб)
Здесь
http://78.81.31.38/novgorod.jpg
- картинка
Спасибо
Записан
V1KT0P
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #26 :
Май 06, 2012, 18:12 »
Цитата: alexis031182 от Май 06, 2012, 17:48
По этому адресу -
http://78.81.31.38/qqq.webm
- видеоролик (осторожно, 20 Мб)
Здесь
http://78.81.31.38/novgorod.jpg
- картинка
Firefox 11, Chrome 18, картинка и видео работает нормально.
Записан
alexis031182
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #27 :
Май 06, 2012, 18:19 »
Цитата: V1KT0P от Май 06, 2012, 18:12
Firefox 11, Chrome 18, картинка и видео работает нормально.
Спасибо
Сделал отдачу статики через смену буферов. Пока один наполняется, другой отдаёт данные в сеть. Затем меняются местами. Всё в отдельном потоке, чтобы не тормозить основной на приём новых соединений.
Записан
alexis031182
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #28 :
Май 07, 2012, 18:37 »
Добавил пару сайтов:
http://78.81.31.38/html/index.html
http://78.81.31.38/karma/index-3d-1.html
Заметил гуглобота. Пришла мысль вести информацию о ботах прямо на сервере (что, мол, такой-то приходил), и предоставлять её сайтам по требованию. Имеет смысл?
Записан
V1KT0P
Гость
Re: [РЕШЕНО] Вебсервер: логика маршрутизации
«
Ответ #29 :
Май 07, 2012, 18:45 »
Цитата: alexis031182 от Май 07, 2012, 18:37
Заметил гуглобота. Пришла мысль вести информацию о ботах прямо на сервере (что, мол, такой-то приходил), и предоставлять её сайтам по требованию. Имеет смысл?
Если собираешься монетизировать прогу, то чем больше статистики тем лучше. Клиенты будут довольны если ее будет много =).
Записан
Страниц:
1
[
2
]
3
4
...
6
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...