Короче, я хорошо помню, как в 2013 году я сел и написал небольшой сайт за один день.
Это был сайт про события моего родного города. На одной странице выводились все мероприятия на грядущую неделю.
Я сделал страничку с мероприятиями, и небольшую админку, где они редактировались. У меня была книжка по PHP, поэтому сайт я написал на PHP, подключил MySQL-базу, сверстал на HTML и CSS, и залил на виртуальный хостинг. Сайтом пользовались, а я усердно добавлял мероприятия каждое утро, пока не ушёл в армию, не оставив никого на поддержку. Так сайт и почил.
Идея сайта всё ещё казалась хорошей, и я решил его возродить. Казалось бы, бери и делай, но против меня играло то, что я толком не помнил PHP, и уже успел набраться опыта разработки в очень больших, средних и маленьких компаниях.
Я решил взяться за дело и стал думать.
Хм, не могу же я просто взять PHP и написать на нем несколько страничек вперемешку с HTML. Как я буду это поддерживать без ООП и вообще нормального разделения кода? К тому же, все говорят, что PHP уже не очень, да и сколько новых версий вышло!
Наверно, мне нужно взять что-то более современное, Node.js или Python. Но я, конечно, не буду просто писать на них потому, это не Best Practices. Пожалуй, возьму какой-нибудь фреймворк, например, Django или Express.js. Впрочем, это самые популярные фреймворки, а есть другие, посовременнее, надо поискать.
Определившись, что я буду использовать или Python, или Node.js, я понял, что просто так отдавать целые странички с сервера нехорошо. Как мне в таком случае сделать всплывающие окна авторизации или динамическую подгрузку? Ну уж не с jQuery, упаси боже! Пожалуй, возьму React или Vue.js, чтобы написать правильный, разбитый на компоненты, интерфейс. Angular будет уже перебором, конечно. Используя фреймворк, мне нужно подключаться к бекэнду по API, поэтому использую Django REST Framework или вроде этого. Хорошо, что Express.js умеет так сам по себе, пожалуй, стоит выбрать Node.js в итоге. На фронтенде мне стоит подключить Axios, хотя теперь есть Fetch, но поддерживается ли он всеми браузерами? А может быть мне вообще использовать Svelte, чтобы заодно научиться чему-то новому?!
Теперь стоит правильно настроить IDE, для того, чтобы соблюдать Code Styles, правильные отступы, и никогда не забывать писать тройное равно вместо двойного. Настройка получается с трудом потому, что плагины IDE спорят друг с другом и упорно делают отступ из четырёх пробелов, а не из двух.
Разобравшись, я понимаю, что мой код нужно где-то хранить. Так как я уже порядком устал, выберу популярнейший GitHub. Настроив Git и авторизацию через ssh на моем компьютере, я понимаю, что я не знаю, какую систему ветвления использовать. GitFlow слишком избыточна, пока я один, но не коммитить же все в мастер-ветку? Мало ли к проекту кто-то присоединится, или, если я покажу репозиторий на собеседовании, все будут смеяться. Остаётся и непраздный вопрос, что писать в описаниях коммитов и на каком языке, но оставим это на потом.
Стоит подумать, как это все дело развернуть на хостинге. Если бек на Python, то нужно создать виртуальное окружение и работать в нем. Почему-то на сервере сходу это не получается, что-то вечно падает. Кстати, нужно запускать приложение как сервис, чтобы всё перезапускалось после падения! Всё, теперь точно берём Ноду! Для бека на Node.js же нужно найти такой хостинг, где Node.js работает, а они все облачные и очень современные. Там нужно настроить развертывание проекта из репозитория на GitHub, но я не могу просто подключить мастер-ветку, потому, что тогда все мои изменения будут сразу же попадать на сервер, а это не очень хорошо. Конечно, можно разворачивать вручную, но это тоже как-то несовременно. Пожалуй, снова подумаю о системе ветвления.
Ах, еще же БД! Вроде PostreSQL хорошая, и я даже с ней работал, но, может, мне нужна nosql-база? Остается открытым вопрос, как ее развернуть на сервере, и как поддерживать одинаковую структуру на моём компьютере и в облаке без потери данных, но до этого пока далеко.
Ах, чуть не забыл. Раз фронтенд на JS-фреймворках, то нужно подумать о Server Side Rendering, важно, чтобы мой проект индексировался. Хм, не нужно ли для этого применить Next.js или Nuxt.js? Надо подумать.
Так как я уже стал что-то забывать, то нужно и какой-нибудь таск-трекер прикрутить, чтобы отслеживать задачи и прогресс. Стоит ли мне воспользоваться методологиями Scrum или Kanban? Или пока я один, можно и так? А как же тогда следить за дедлайнами?
Ещё я не подумал, конечно, о TS, ES6, SASS, PUG, GraphQL, ООП, функциональном программировании, иммутабельности и обо всём таком. И нужно будет сертификат HTTPS прикрутить обязательно! Может, мне позвать в команду пару друзей, чтобы сделать всё правильно вместе? Тогда без Scrum и Pull Requests не обойтись.
На этой ноте я устал окончательно и подумал, что, может, мне стоит откопать старую книжку по PHP, и сделать всё, как в 2013 году, когда я ни о чём выше не имел представления, а половина технологий ещё не появилась? Похоже, я слишком много думаю наперёд. Решу всё это потом, сейчас посмотрю сериал и пойду спать, а завтра точно начну программировать.
Mephi1984
Как мне кажется, как раз все наоборот.
В NodeJS с помощью нескольких команд можно за десять минут поднять простой сайт типа блога, и он уже будет с формой входа, с загрузкой изображений, и вполне стильно выглядящий. Представляю сколько бы это заняло у меня лет 10-15 назад.
DmitryOlkhovoi
Ну за 10 лет не скажу, а так чисто за тот же php с Yii. Показываешь ему табличку в базе и он тебе генерит CRUD. Контроллеры, вьюшки. Под ноду такое еще поискать надо, sails.js тебе только апишку даст.
В статье конечно все малость утрировано. Прежде чем брать какой-то стек нужно хорошенько подумать. Если делать блог за сотку, то вряд ли кто-то будет замарачиваться с SPA, SSR и прочим. Можно вордпресс клиенут впарить
VolCh
Что значит "блог за сотку"?
maxzhurkin
sergarcada
Нет, это просто означает задешево
AllexIn
100 000 это дешево?
Maccimo
Кто сказал, что «сотка» это именно 100 000 RUR, а не 100 USD, например?
Alert1234
за 100р студент установит готовый движок.
Xobotun
Я даже не знаю, специально вы написали RUR, подразумевая, что это 100 RUB, или это была случайность?
Ибо RUR и RUB – разные валюты, одна – советско-российский рубль, а другая – современный рубль, после деноминации, которая как раз на тысячу сократила множитель. Если вдруг кто не знал.
В любом случае, эта последняя буква ещё сильнее увеличивает неопределённость, сотка чего именно имелась в виду. :D
leonP4
Все правильно сказано — 100 000 RUR. Блог же за «сотку», подразумевая что очень дешево.)
StraNNicK
спасибо, добрый человек. Давным-давно, когда мне надо было быстро перевести сумму в USD в рубли, я писал в гугле «100 USD in RUR», потому что гугл так подсказал.
А потом у них синтаксис поменялся на RUB и мне было интересно почему. Недостаточно интересно, чтобы погуглить, но достаточно, чтобы я фоново помнил об этом все эти годы.
Теперь узнал.
Maccimo
Открывая рублёвый счёт в банке вы возмущаетесь, что номер счёта начинается с xxxxx810, а не с xxxxx643? Если верить википедии, то по ISO 4217 кодами советского рубля были SUR (810).
Единицы измерения «соток» в исходном комментарии не указаны, а значит любые предположения могут быть ошибочны. Для сотрудников минфина или ЦБ РФ «сотка» вполне может и сотней миллионов.
Xobotun
О, про SUR я слышу впервые. Значит, RUR – постоветский российский рубль, но до деноминации.
Я об этом слегка любопытном феномене узнал примерно таким же путём, как и StraNNicK, переводя в гугле валюту на рубли и получив какие-то не очень близкие к реальности цифры.
Alexufo
Какая-то кодогенерация CRUD вдруг внезапно какая-то фича, которую все вокруг пропустили, кроме А. Макарова. Разивайте мысль дальше.
Берете Strapi, там вообще даже показывать ничего не надо. Набиваете структуру и у вас уже API с готовой авторизацией, правами.
sails.js — дохлая лошадь.
DmitryOlkhovoi
Это только API, а формочки кто делать будет? Еще плати 30 баксов в месяц, вешайся на third пати.
На тайпскрипте модельку опишу, дам ее graphql через typeORM, подкину генератор под клиент и суп аля зе бест маштабируемое api — готов, бесплатно.
Суть же не в этом, а в колличестве технологий на квадратный сантиметр. Раньше это было просто пыха с файлзиллой. О чем собственно и пост.
Существует множество вещей упрощающих разботку. С этим никто не спорит. Можно сейчас как SAAS себе собрать, все, что хочешь.
Да, кому нужны эти создай, отредактируй, удали.
Ну если делать нечего, ради свадебного отелье, фигачить spa и ssr
DmitryOlkhovoi
6 минут с объяснениями, от установки до админки(CRUD) за логином и вьюх для сайта, по айтему. 2010 год.
Мне кажется я вебпак локально дольше разворачивать буду, учитывая, что node, npm уже стоит. И ради чего? На крупном проекте, долгострое да, с крупным заказчиком и супер пупер синьйорами — eсть смысл. А так, если ты мелкая фирма, шлепаешь сайт за сайтом. Какой spa, ssr? :) Я конечно предположу наработку и конвейер с готовыми решениями, но это все тоже самое, просто в профиль и явно дороже по издержкам.
Alexufo
Админка и есть strapi. Платить не нужно 30$
Вы и описываете CRUD который и ругаете.
DmitryOlkhovoi
Есть много разных задач, проектов и клиентов. Мы сравниваем разных коз
Ну вы же понимаете, что админку strapi клиенту сунуть так себе идея? Чисто для себя или под свой единый проект — окей. Хотя, интересно если кто-то так делает.
Я посмотрел прайсинг на сайте. Не всем подойдет фришная в продакшене. Или есть свой хост, то там без ограничений?
Но я обязательно заценю ее, уже не раз слышал про нее :)
AlexSpaizNet
sails.js — мы до сих пор это говно выпилить не можем =)) Зачем эта поделка вообще появилась…
Alexufo
Это же была волна новых идей. Никто не понимал какие js фреймворки и как использовать. Все занимали нишу, кто-то тащит лару в js кто-то идейно c#.
Kroid
А что с ним не так? Смотрел на этот фреймворк несколько лет назад, когда он только начинал набирать популярность, идея у них была вполне здравая — сделать что-то вроде аналога рельсов из мира руби.
Alexufo
С ним все так, только он умер. Ну то есть 0 движей. Но домен кто-то оплачивет.
AlexSpaizNet
Вот вот. Идея была хорошая потому что руби он рейлс и джанго хорошие… а вышла какашка с магией, конвенциями и мать его глобальными переменными боже спаси и сохрани… я рад что оно умерло.
Klekots
А как же Strapi?
UPD: Прошу прощения, выше уже говорили про Strapi
LborV
мне кажется тебе будет интересен мой недо-проект github.com/LborV/js-mvc
Anshi85
В 2012 году, за вечер сделал одной юридической компании сайт, на Wordpress и нечего все работало отлично, была поддержка 3 языков, поиск, форма обратной связи, при чем я тогда системным администратором работал. До сих пор думаю если не нужно какой то сложной логики или API, то проще установить Wordpress и не париться, хотя сам я сейчас пишу сервисы на Python/Django
stobaksov100
Да ровно столько же.
При использовании языка программирования, который был мейнстримом для веба тогда.
От языка программирования ничего не зависит.
Зависит — от набора используемых вспомогательных библиотек/фреймворков и от того как хорошо вы в этих библиотеках/фреймворках ориентируетесь.
А описанный функционал — заложен в библиотеки/фреймворки еще 20 лет назад.
Но, да, тогда это было в библиотеках/фреймворках — для других языков программирования, которые были в мейнстриме для веба тогда.
ganqqwerty
Дык жумлу-дрюпал-вордпресс-медиавики бы поставил и вообще ни строчки кода бы не написал.
FraiDex
Вы забли про Ruby on Rails. Почти все ТОПовые фреймворки нашего времени построенные на принципах ROR. Как раз, 10-15 лет назад, когшда JS был только фронтендом, а ноды вообще не существовало.
x86d0cent
Кстати да, через месяц именно 15 лет будет с момента выхода Rails 1.0. А то, что автор в 2013 году вместо RoR+emberjs использовал PHP + jQuery, не думал про git, sass, ООП и т.п… ну не знаю, насколько это стоит обсуждения.
Сейчас, как и в 2013-м, на RoR за день без проблем можно сделать сайт, запулить его в облако на Heroku (который у автора на картинке), и он там будет работать. И даже не будет просто так отдавать целые странички с сервера — turbolinks нынче уже идет из коробки.
VolCh
На днях было 15 лет со дня выхода symfony… А в 2013-м автор вполне мог использовать Symfony 2.0 — 2.4
samuray21x
Да и python также в принципе, можно тоже за минут 10-15 накидать на том же django с rest-ом функциональный готовый к работе сайт или rest api
Voiddancer
Расскажите — как? Спасибо.
Mephi1984
Как вариант:
Подробнее тут: github.com/jamesknelson/create-react-blog
prs123
Вспомнил тут недавно PHP и спокойненко продолжил на нем делать сайты. Просто со временем образовался небольшой ворох минимального комплекта для запуска и получается вполне шустро и по разработке, и по скорости работы.
Не знаю уж, чем так плох PHP и MySQL — пока этого мне никто объяснить не смог
Alexey2005
Ну это примерно как табличная вёрстка, которая тоже выглядит намного проще десятикратно вложенных div'ов с тоннами весьма нетривиального CSS'а, но считается «не тру», потому что недостаточно универсальна и покрывает лишь ограниченный набор юзеркейсов.
demon416nds
Но при этом таблица не разваливается при очередном обновлении браузера.
А уж как неограничено применение современных фреймворков, просто сказка, и чем дальше тем страшнее.не помню как там точно: "Шаг влево, шаг вправо — считается побегом. Прыжок на месте расцениваю как попытку улететь в космос."
KorDen32
К сожалению, таблица доставляет проблем, когда вспоминаем о мобильных устройствах, где скажем десктопный блок справа логичнее было бы выводить внизу или во всплывающем меню.
Opera 12 Mobile кажется последний браузер, который нормально умел масштабировать табличные сайты на экране смартфона.
demon416nds
Вполне достаточно отдавать мобильным устройствам отдельную мобильную версию. Это куда надёжнее и куда легче адаптивности.
Ilusha
Я бы не был таким категоричным.
Поддержка, тестирование и добавление нового функционала становятся вдвое затратнее в сложных интерфейсах.
В клиентских приложениях не редко используется комбинированный подход: разные компоненты в зависимости от размера экрана.
И, уже набивавшая оскомину истина: каждой задаче своё решение.
strvv
Это точно, зато с «простейшей» по современным меркам странички браузер как пить дай отгребает гиг озу на то что бы распознать, что наТБМвертили эти ВЕБкодемастеры.
ТБМ, как я стар, когда в «кроватке» середины-конца 90х болтали… легкие чаты, пролезающие через 2400, а не требующие онлайн-линка в 1-2МБита. я совсем не понимаю современные тенденции — это для того чтобы даже мощнейшее железо заставить ползать так, что даже 8088 кажется очень даже быстрой машинкой?
ЛЮДИ, ОЧНИТЕСЬ!
а Илюше — нахрен универсальные на все случаи гробы, которые хреново распознаются везде? нафига эти кучи слоев? информация погружена во все эти обертки, что даже нормально вычитать ее приходится изголяться!!!
Ilusha
Вы же прекрасно понимаете, почему так сложилась история развития веба, да и всей индустрии.
strvv
Во второй половине 90х, когда первично появились избытки мощностей, в первую голову процессорных, п-про, пошло такое компонентное чудо как Дельфи. Когда даже совсем безголовый олигофрен, мог тыкая мышкой собрать из компонентов красивое, но медленное приложение и в эти контейнеры сигналов и функций вложить нужную себе функциональность. Пошли производные компоненты и чем дальше тем хуже.
До них был другой подход к работе, есть атомарные компоненты, тот же mfc и между ними требовалось наращивать мясо, т.е. понимать что и как работает и зависит. А теперь даже ТБМный калькулятор занимает сотни мегабайт, требует выход в интернет и еле ползает на тех же смартфонах, которые мощнее суперэвм 20 летней давности, при несопоставимой полезности изделий.
VolCh
А полезность в чём измеряете? Если в деньгах, которые покупатели готовы платить за изделия, то полезность суперэвм и смартфонов если и несопоставима, то с другой, наверное, стороны, а не той, что вы имели ввиду. Триллион долларов уж точно в год платят за смартфоны.
Ilusha
Вы повторяетесь.
Тогда я снова скажу: вы все прекрасно понимаете. Ответы на «что, как и почему» у вас есть.
И вы ищете не объяснений, не интересных споров, а единомышленников.
Maccimo
Как я понял, вы почему-то очень не любите Delphi.
Но Visual Basic появился раньше и, по слухам, был популярнее Delphi.
Утверждения о тормознутости Delphi голословны.
Delphi всегда был компилируемым языком с приемлемой скоростью и в тормознутости современных сотнемегабайтных калькуляторов он не виноват, они не на нём написаны.
khajiit
И
брюкиDelphi превращается, превращается… в веб-приложение!Сурово ж вас приложило.
maggg
15—20 лет назад я ещё как-то мог с вами согласиться, но сейчас таблицами верстать банально сложнее, чем гридами, флексбоксами, или даже простыми блоками. А в большинстве кейсов с адаптивностью — просто невозможно.
NickiDi
При том что все еще можно сделать сайт за один день на Wordpress на том же php и не мучаться.
Да и как-то не по существу — «ну теперь просто на php я не могу сделать сайт, и надо выбрать какой-то фреймворк: Jango или Express». И как бы автор не нагуглил, что есть Laravel с огромной экосистемой, и скаффолдингами из коробоки под react или vue. Или автор лет 5 назад начал писать статью.
Ilusha
Весь вопрос: вам шашечки или ехать?
Я вас прекрасно понимаю. Сам так начинал проект. И бросал.
Хотите сделать новостной сайт: берёте Wordpress/<другая CMS>, покупаете готовый шаблон, домен и не парьтесь.
Хотите интернет-магазин? И под это готовых решений достаточно. Если не в РФ, то shopify.
Закладываете потенциал, и, вообще, это пет-проект с полным контролем — верной дорогой идёте.
А если хотите меньше париться, то на фронт берёте boilerplate, их достаточно много разных. Там уже есть всё.
Не хотите парится с бэком? headless cms.
Не хотите сильно парится с фронтом? Asp.net, Java jsf (?).
На любой вкус есть решения с разными преимуществами и недостатками.
Ilusha
И ещё добавлю, если не хотите париться с ui, то есть масса вариантов UI-kit: antd, material ui. От Uber тоже есть.
sshikov
>Теперь я не могу сделать даже маленький сайт
>Весь вопрос: вам шашечки или ехать?
Ну, судя по тексту — шашечки.
>Как я буду это поддерживать без ООП и вообще нормального разделения кода?
Прежде чем это кто-то будет поддерживать, нужно чтобы это вообще заработало. Поэтому берете то, что знаете, и делаете прототип. Потом выкидываете, и делаете продакшн решение. Вполне возможно, что на совсем других технологиях. А может, его уже другие люди сделают.
У меня на работе как-то была задача сделать ма-а-а-аленький сайт google maps. Не в таких масштабах, конечно, как настоящий, а именно прототип. И могу сказать, что решение взять знакомые технологии, и добавить к ним ровно то, чего в них не хватает (в моем случае картографию и leaflet), и не более — оно самое правильное. И кстати, самый первый прототип был сделан на Apache Flex (Flash). За пару дней.
barbaris76
Единственно, хочу заметить: ипохондрия это != хандра; ипохондрия, это когда человек постоянно выискивает у себя симптомы и признаки несуществующих болезней.
ZiggiPop
В оригинале была ипохондрия.
barbaris76
Оу, сори. С оригиналом не знаком, просто глаз немного резануло.
ZiggiPop
Формула любви — один из немногих фильмов производства СССР, которые можно смотреть без крови из глаз даже сейчас. Неисчерпаемый источник цитат на все случаи жизни.
barbaris76
Похоже, я сегодня запас пепла на голову исчерпаю — фильм-то миллион раз просмотрен, но вот цитату не признал (
stobaksov100
Это пара «сценарист Григорий Горин — режиссер Марк Захаров»
У них все фильмы подобного качества.
Xambey
Оставляю комментарий для потомков:
Если вы не мазахист, то никогда, НИКОГДА не берите Liferay (java), его разработали для наказаний
domix32
А есть ли жизнь в java без spring?
Xambey
с java EE еще можно жить, как по мне, но Spring лучше имхо :)
xxxFeLiXxxx
Друг, я так тебя понимаю! Сам когда-то работал с ним, но выбора не было — работодатель продавал решения на его основе.
Xobotun
Хе. Теперь вы не сильно паритесь, а прямо-таки погрязли в болоте энтерпрайза. И PrimeFaces вас не спасёт. :)
На самом деле, не знаю, что именно теперь стоит использовать для фронта на джаве, уже давно этим не занимался. Какой-нибудь шаблонизатор для спрингового MVC, разве что...
abar
Thymeleaf?
TyVik
А мониторить кто будет?! Вам ещё графана с каким-нибудь алертингом нужна. А то понадеплоют тут, а ты потом разбирайся.
Ilusha
А ещё обработка ошибок: sentry какой-нибудь.
Мониторинг доступности типа pingdom.
Тесты не затронули. Целый пласт решений.
Анализ уязвимостей.
markmariner Автор
С тестами я даже боялся начинать потому, что не смог бы дойти ни до чего другого, остановившись на серьёзном вопросе, писать ли мне в этом проекте тесты сначала, или потом, и в каком объёме. :)
Тут и дизайн, UI/UX, я тоже потерял, а если о монетизации задуматься, то это вообще пучина!
VolCh
Пока тесты и код в одном коммите — никто и не узнает :) Плюс есть rebase и squash ))
lockywolf
И filter-branch!
evocatus
Тот же sentry в простейшем случае устанавливается практически в одну строчку (https://develop.sentry.dev/self-hosted/)
С приходом контейнеров эра "коробочных решений" как раз в какой-то мере вернулась.
Иногда достаточно написать Docker Compose файл и решение уже почти готово.
nikolayv81
Вы упустили настройку самого dicker-а на, обычно, ограниченных ресурсах у хостера (по экономическим причинам).
VolCh
Если речь про VDS какой-то и настройку именно докера, а не оркестрацию контейнеров, то обычно настраивать особо ничего и не надо, кроме установки самого докера.
tmin10
Автор явно обошёл стороной облака: вдруг про сайт завтра напишут все мировые сми и туда зайдут десятки миллионов пользователей? Нужно обязательно хоститься в облаке и чтобы работал автоматический скейлинг. Скорее всего k8s станет хорошим решением, в aws можно воспользоваться eks для этого. Также никогда не знаешь, сколько данных придётся хранить, добавим туда интеграцию с s3. Заодно и бэкапы закидывать в glacier deep archive удобно. Кроме этого с
разворачивать всё руками — прошлый век, стоит взять terraform и исполтзовать подход infrastructure as a code. Десятки миллионов пользователей создали терабайты логов и их надо проанализировать? Как хорошо, что это можно обработать в кластере EMR. И это только начало, над cloud native частью стоит поработать, это сейчас очень популярно!
nikolayv81
Боюсь если сайт не для сбора денег на рекламе, авто-скейлинг лучше не использовать, а то кто знает как потом отдавать эи 10-20 k$ изща habra-эфыекта :)
VBKesha
В этой статье нету упоминание Docker'а и это в 2020м то.
markmariner Автор
Каюсь, очень хотел упомянуть, но забыл!
Maccimo
Вот именно поэтому написание статьи нужно было начать с установки и настройки task tracker!
Nashev
гитхаб же
yshurik
Ну что вы, ну какой docker в 2020, как минимум нужен kubernetes и чтобы мог адаптивно задеплоится на тысячу подов если много анонимусов зайдут в блог ;)
anonymous
В 2020 докер уже мёртв, разве нет?
oTm0po3ok
А что вместо докера использовать?
ForexBroker
А кто его «убил», не подскажите?
sergarcada
Это, вероятно, отсылка к статье Docker уже умер...
ForexBroker
Да это понятно, правда, и там так и не ответили, кто его «убил» и с чего взяли что вообще кто-то кого-то убил)
sergarcada
Его не убили, он просто умер. Но поскольку заменить особенно нечем (тут я не силен если честно), то все продолжают им пользоваться с надеждой, что родится какая-то новая технология.
ForexBroker
Никогда не понимал подобные высказывания. Докером пользуются сейчас поголовно все, я не знаю ни одну маленькую контору и ни одну большую контору, которая не использует Docker при локальном тестировании / разработке. А все остальные крики про «умер» — это блеф чистой воды, громогласные выкрики ради хайпа, имхо
VolCh
Справедливости ради, некоторые перешли/переходят на совместимые альтернативы или просто не используют.
ForexBroker
И первый и второй ваш вариант предполагают какие-то альтернативные средства, приведите пример, пожалуйста. Надеюсь, вы не об open-server (denver) и vagrant говорите.
Stinkynnov
Вероятно, это про Podman.
Nengchak
lxc, chroot. /s
VolCh
Первый — про, прежде всего, podman и компанию. А так и lxc только за последнее время несколько постов на Хабре было. И вообще всё это обёртки над cgroups и неймспейсами.
А вот второе — в голове была чистая олдскульщина: проект развёрнут на локальной машине разработчика без какой-либо виртуализации, конейнеризации и автоматизации. На новую машину нужно в строго определенные места склонировать репозитории, пачку /etc/* файлов, отредактировать /etc/hosts, и стандартного пользователя хорошо бы создать. Сделать один раз и забыть на годы может быть, пока не придёт письмо на группу рассылки devs: "в наших конфигах домены example.dev заменены на example.test в связи с тем, что .dev теперь делегируется. Обновите свои локальніе конфиги"
LastDragon
А что не так с вагрантом? Для разработки (под виндой по крайней мере) очень удобно — буквально за день сделал шаблон, и постепенно перетащил все проекты в отдельные виртуалки, при этом у каждой отдельный домен (на основе имени из
composer/package.json
). Как это сделать на докере сходу не нашел.VolCh
https://github.com/nginx-proxy/nginx-proxy вот так например, автоматически изменять конфиги "главного" nginx при старте новых "виртуалок"
LastDragon
Спасибо. Правда судя по беглому взгляду в Windows 10 оно просто так не заведется (
hosts
как минимум обновлять оно, похоже, не умеет).VolCh
Я dnsmasq использую, чтобы все запросы **.test на докер шли
tmin10
А какие есть альтернативы? Firecracker на ум только приходит, но он скорее для FaaS.
Ilusha
Основная проблема, что нет определения понятия «умер» в контексте технологии.
В вышеуказанной статье вывод сделан по одному признаку: на конференции в Питере не было докладов.
Alexrook
Так еще не все поняли, что это такое, а уже появляются статьи, что его уже хоронить собираются ))) Сам уже не знаю, стоит ли в нем разбираться или уже поздно.
pierser
Обилие технологий не должно смущать. Выбрать фреймворк под задачу в 2020, очевидно, сложнее, чем в 2000 — но, сделав правильный выбор, развернуть решение и получить результат зачастую удается в разы быстрее.
p.s. вдогонку к готовым cms типа вордпресса, если вдруг хочется попроще в плане архитектуры — любой статический генератор (gatsby, etc.), который даже на условные github pages из коробки встает (а это значит — без геморроя весь CI, мало ли в резюме показать :) ), решает описанную задачу.
AlexHell
и как вы узнаете что вы сделали правильный выбор?
а чем больше технологий, тем выше шанс ошибиться
плюс туториалы сложней релевантные найти, если выбрал одну часть одну, а другую другую
так приходиться полюбому больше информации читать, и выбирать по каким-то критериями
выбор это сложно, это факт
почему не должно? кто сказал что не должно? меня смущает, автора смущает
потому что объективно выбор — смущает
он требует ресурсов мозга, это факт
понимаете ли автор, и плюсующие говорят о том что раньше то выбора было меньше, и туториалы читались быстрей, и релевантные причем
а сейчас надо в разы больше инфы перелопатить, ради пустякового дела
я даже не про себя, а давно на веб-разработку забил
в моей области (gamedev и сервера) тоже выбора прилично
titsi
Да из за обилия выбора тратишь время.((( Вот чтобы был какой сайт где все технологии представлены и хотя бы статистика по миру кто какие использует и какие проблемы они решают.
Прилично, тоесть его меньше чем в веб-разработке? А рутина, кол-во используемых технологий, овертаймы, многословность кода, часто переделывать? это по сравнению с вебразработкой в геймдеве как?
AlexHell
* рутина есть везде, и в геймдеве, там же тоже надо отлаживать баги, тестировать, кодить чтото 10 раз что вы уже делали
* кол-во используемых технологий — иногда можно взять чтото простое что работает, иногда приходиться делать серьезный выбор, оценивая очень многое, и в геймдеве часто надо чтото оптимальное, но иногда это оптимальное это долго кодить, и выбирается сначала нечто среднее, или потом переписывается на более оптимальное, другую архитектуру и т.п, и все эти оптимизации они тоже требуют выбора (что делать и когда)
* овертаймы — в геймдеве частые на сколько я слышал, хотя у меня бывают редко потому что я физически не могу авралить часто (голова уже не варит)
* многословность кода (как и качество кода, и кач-во проектирования и тестов) — зависит от опыта разраба, впрочем там где я работал — в основном разрабы сильные, новичков откровенных почти не было, ну и копипаста и лапша в коде конечно бывала но явно меньше чем я видел в (условно) «плохих примерах кода на php\js»
* часто переделывать — см выше — переделывается для оптимизаций, либо для портирования на другие девайсы (мобилки, веб, консоли, пк)
titsi
спасибо
AlexHell
еще хочу дополнить, отвечу на свой комментарий
с научной точки зрения, человек может сделать выбор 2мя способами
1) лимбической системой — это псевдо-выбор основнанный на эмоциях, и зачастую в жизни именно он активно работает, например нам нравится какая-то еда, или мы привыкли вставать в опеределнное время и идти на работу, играть в определенные игры, и часто мы перенимаем этот опыт у кого-то, а потом зкрепляем за ним эмоцию и желание действовать также или не действовать
… в примере с технологиями это может быть хайп (ктото гдето написал что это клевая теха), а никак не ваш разумный выбор, и потом есть высокий риск что вы выбрали не корректно, потому что вы то доверились комуто
2) неокортексом — т.е. логическое осмысление множества факторов, но тут проблема — если сравнить 5 технологий (раньше) vs 500 (сейчас) то комбинаторный взрыв мешает сделать логический выбор за разумное время, и в конце концов человек или выбирает нечто «достаточно хорошее» как ему кажется, за N время (не макс время), или тратит слишком много энергии\времени на реально оптимальное решение
поэтому о каком «правильном» выборе может идти речь, если для логического его осмысления неокортексом надо непомерное кол-во энергии
VolCh
Ох, помню сколько я времени убил на выбор стэка для простенького сайта на шаред хостинге: И C, и C++, и Perl, и ещё что-то Остновился на PHP. И это только язык.. А ещё выбор Linux или BSD. В чём под Windows писать код сайта… В чём писать разметку и стили...
Просто автор для первого своего сайта по сути и не выбирал стэк: была одна книжка по ней и делал
marabou44
Я тоже сделал свой первый сайт на чистом PHP + JS около 20 лет назад. Через несколько лет свои наработки превратились в собственную CMS. Сейчас это ретро никому не нужно, кроме меня. Поэтому я, использую свои наработки, только для себя. За несколько часов делаю простой сайт и back-end для мобильного приложения.
А своим клиентам рекомендую нанять другого разработчика для получения красивого и современного результата.
Почему не изучаю зоопарк современных фреймворков и CMS? Да просто не хочется тратить на это время, разработка приложений под Android гораздо интереснее.
Alexufo
Сейчас придет Дмитрий Карловский и покажет как на моле за сутки сделать вебсервис, где можно жестами для вебки двигать картой в браузере.
0xd34df00d
Он сейчас занят — ищет языки с поддержкой четырёхзначной логики.
nin-jin
Я много чем занимаюсь. Конкретно сейчас математически расчитываю дизайн. Есть в планах и своя штука на которой можно будет накликивать хоть CMS, хоть чат, хоть баг-реткер и тп. Хоть всё это вместе.
babylon
В смысле лейаут элементов + цвета невырвиглазные? Хотим подробности. Пролог это правильно, но зачем там 4-х значная логика?
Пора оставить PHP и MySQL для птушников. Dart интереснее, но медленно всё движецца
nin-jin
Пока только различные отступы.
Четырёхзначная логика необходима для корректных рассуждений. Я думал использовать пролог для валидации доказательств, но похоже он недостаточно силён для анализа произвольных выражений. Так что придётся пилить свой пролог с четырёхзначной логикой и релевантной импликацией.
VolCh
Не хочу в ПТУ даже преподавать ) Современный PHP не имеет фатальных недостатков в своих нишах, а работать может не только с MySQL. полный переход переход на другие технологии, хоть "хайповые", хоть "мэйнстрим" существующему бизнесу особых плюсов не даст. Точечный — вполне, и давно практикуется, даже до моды на микросервисы.
nin-jin
Мы тут, кстати, на днях хакатонили. Так я прям заскринил, что сделала команда, которая использовала модный стек React+Redux:
Понятно, что ребята не опытные, что дизайнера у них не было, что надо было использовать какой-либо набор компонент. Проблема именно в том, что многие разрабы ведутся на хайп, надеясь, что можно будет не заморачиваясь сделать конфетку за три копейки. Но в итоге оказывается, что кода написано куча, а выглядит всё ещё стрёмно, работает на половину, а время уже всё потрачено и нужно ещё минимум в два раза больше на доработки.
Для сравнения, наше решение на настолько не модном стеке, что организаторы срезали нам баллы за то, что использовали "экзотическую технологию, в которой не разбираемся, которую не используем каждый день":
А победили ребята пилившие на Ангуляре вчетвером:
Итого, можно сказать, что для вкручивания лампочки нужно либо 4 Angular разработчика, либо 1 $mol.
К слову сказать, больше всех успели сделать ребята, что пилили на 1С. Выглядит оно, конечно, "интуитивно понятно". Не заскринил, но 1с-интерфейсы все одинаковые.
E_STRICT
playnet
ух, сколько нам приносил «радости» переход с 5.1 на 5.2, а потом на 5.3… помнится, именно 5.3 — прилично поменялся язык. Поэтому до сих пор есть сайты на 5.2, потому что «и так работает до обновления»
VolCh
5.3 — я бы сказал язык переродился, но сильных BBC не помню до 7.0. Там скорее желание всё переписать было "по уму" с активным использованием новых возможностей: неймспейсов, нормального ООП, интерфейсов и т. п.
acmnu
В 5.3-5.4 была история с резким сбросом кучи деприкейтов. В частности ссылки, глобальные переменные и ещё что-то по мелочи. Как следствие вся кодовая база, которая пришла ещё со времен PHP 4 отхватила.
VolCh
А, может почти не заметил потому что всегда активно боролся с деприкейтами. Хотя как-то выиливал на новом для себя проекте PHP4 конструкторы в процессе перевода с 5.6 на 7.0
tmin10
Я свой сайт написал по книжке году а 2008-2010, там была пятая версия языка. Сейчас без особых проблем мигрировал на хостинг с 7 версией (переписал mysql вызовы только, поддержка закончилась у библиотеки). Так что для простых сайтов это справедливо.
OZR
У меня до сих пор сайт на PHP 4.4 dev. В своё время переход на PHP 5 не удался… А теперь уже утекло слишком много времени. Сервер поменять страшно. Ну и по старой админской привычке «работает, не трожь»… До сих пор боюсь этой «радости» перехода.
Arris
Тут уже лучше не переходить, а написать всё с нуля. Только, конечно, без того зоопарка, как у автора поста. Что-нибудь поменьше взять, покомпактнее.
Arris
Главное не забыть использовать
mysql_connect()
, а потом задолбать гугл и тостер вопросами "У меня не работает MySQL что делать".tmin10
Я просто переписал на
mysqli_connect()
, там почти тоже самое.xndr
Вах! Вы сделаль мой день!
Я в веб особо не лезу, но со стороны все видится именно так.
Понаплюсовал бы, но тут кармы-шмармы, и я как-то дискриминирован, поэтому просто спасибо, читал с удовольствием.
Baigildin
Да автор какой-то странный, делает из мухи слона. Он бы ещё начал микросервисную архитектуру разворачивать для своего новостного блога города. Все эти инструменты же сделаны для конкретных задач. Для него подошёл бы тот же самый wordpress. А он начал забивать гвозди микроскопом, и жаловаться, что что-то тяжеловато.
DmitryLTL
Можно тэги к статье посмотреть и не удивляться прочитанному.
Baigildin
А чёрт! Для меня было слишком тонко :D.
Paskin
Для автора подошел бы и Wix.com (или его аналоги).
jetcar
Так и написал бы что нет опыта разработки с нуля, всё для тебя подготавливали. После первого раза разработки с нуля в любой средней/большой конторе вопросов в принципе не возникает. Берёшь то что удобно и быстренько херачишь сайт не заморачиваясь вообще ни о чём. Новые технологии позволяют не писать кучу кода которую тебе нужно будет написать на ПХП, тут уже всё готово бери и используй. И исходя из опыта могу сказать что вообще не важно на чём писать, главное это на чём умеешь хорошо, чтоб не изучать туеву хучу новых инструментов.
VolCh
Если делать всё "по уму", "чтоб пацанам не стыдно было показать", то почти без разницы какой конкретно современный стэк использовать, включая PHP и MySQL. Библиотеки, фреймворки, обёртки, кодогенераторы везде в мэйнстрим сейчас есть. Половина, если не больше современной инфраструктуры language agnostic.
Feeel
Истинно так!
А чем плох вариант сайта "из коробки"?
Wordpress/bitrix/Joomla + тема по вкусу + доработать напильником, кладём на популярный виртуальный хостинг = обычный типовой сайт! И никакого геморроя!
С каждым годом все больше осознаю, что главное — это КОНТЕНТ! Даже сайт сверстанный черти как, с поехавшей вёрсткой, без мобильной версии и прочих свистоперделок вполне себе будет популярным и посещаемых, если там есть важная и/или нужная информация.
Вспомните старую корзину Вайлдберриз — при оформлении заказа хотелось замучить до смерти того, кто её написал, но многие (и я тоже) ценой невероятных усилий таки оформляли заказ. Почему? Цена, удобная доставка, нет предложения от конкурентов, доверие к крупному ритейлеру. Остальное все от лукавого.
До сайта на ларавел или дотнет надо сначала дорасти! А там уже видно будет на чем и как оно должно работать.
okjaeo
Поддерживаю. Рутрекером спокойно пользуюсь без всех этих всплывающих окошек и прочей ерунды. А наш городской портал наоборот перестал посещать, когда там начали внедрять кучу нововведений в надежде сохранить посещаемость.
Spark9
самый лучший комментарий! жаль не могу плюсануть.
E_STRICT
markmariner Автор
Конечно, и мне стоит знания освежить! Нашёл курсы на Нетологии за 55 000, если друзей четверо, то выйдет всего 220 000 рублей. Плюс за Джиру по 7 долларов. Недорого, главное побыстрее найти инвестора!
anonymous
Лучше бросить дурацкую идею создавать сайт и сразу начать с курсов по созданию сайтов.
VolCh
Создать таки сайт, записываю все действия, и продавать как курс.
sergarcada
Создать сайт, где будут продаваться курсы по созданию сайтов с курсами…
kAIST
Ну, мастер-классы по ведению мастер-классов были не редкостью.
Но бум инфоюизнеса и инфоцыганства вроде бы уже прошел.
Nikola_Piterskiy
эта песня будет вечной
vladshulkevich
Создать агрегатор сайтов, где продают курсы, а лучше агрегатор агрегаторов с отзывами.
boomcol
Прямо в точку! Именно поэтому я начал работать над проектом viewi https://viewi.net/ чтобы решить эту проблему. Стадия PoC.
Acuna
boomcol
Можно узнать версию хрома ?
Acuna
68
boomcol
Слишком старая версия, flex is not supported, вам нужно обновить хром
JustDont
Хорошая попытка, но нет.
boomcol
Ну тогда вам к автору www.muicss.com
boomcol
Апдейт: это не флекс, это плагин в хроме, буду решать проблему
Acuna
Дак в том-то и дело что я не должен обновлять версию годовой давности как в 2000-х потому-что что-то там не поддерживается, ибо это и есть та кросс-браузерность, о которой все мечтали. И да, flex поддерживается, выше уже сказали.
boomcol
Issue with browser's extensions has been resolve. Спасибо Acuna за помощь.
Acuna
Подтверждаю, дело было в очередном корявом расширении
sumanai
Шёл 2020 год, а у нас до сих пор проблемы с юникодом
boomcol
Good catch, спасибо, повторюсь, PoC версия
boomcol
Unicode has been fixed
Nalivai
Хех
dmitryb-dev
Аналогичные чувства испытал, когда еще в универе без проблем клепал сайтики, а потом спустя несколько лет, когда снова потребовалось быренько склепать страничку, обнаружил webpack, node, npm, react, боль.
Вот это все только вот от неопытности. Если нужно быстро — делай на том что знаешь и умеешь. Есстественно кто-то умеет делать и на этом всем быстро. Я вот сейчас на спринге могу бэк клепать с космической (для меня) скоростью. И это при том что Spring — это чуть ли не худший фреймворк для быстрой раработки (что проверено и на своем опыте, параллельно с изучением спринга писал на других фреймворках). Но это лишь потому что у меня все эти вещи, на которые новички тратят месяца, уже на уровне рефлексов. Тоже было и с фронтом. По началу ты страдаешь, и постоянно думаешь, может ну нафиг это, может JQuery? Но уже получив навык React и Vue я как то попробвал склепать страничку без них. Быстро на это забил и подлючил Vue.
Но как бы так оно везде: простые популярные фреймворки обычно просты не за счет концепций, а просто банально потому что там меньше функционала. А сложные очень затратны на изучение, но зато «в бою» они выигрывают — очень много чего есть из коробки, но на изучение этого порой ты тратишь намного больше времени, чем на написание велосипеда на простом фреймворке. Поэтому такие штуки выигрывают на дистанции.
Ну а тему целесобразности инструмента я даже поднимать не буду — выше уже упоминали.
PsyHaSTe
Коротко о том, почему все эти фпшные "монады" — сложные, но везде рекламируются.
mikaakim
Тогда почему не брать Spring Boot? Много чего есть просто в коробке с ним)
anonymous
Подобный агрегатор новостей делал тоже, куда городские события подтягивал с разных RSS-лент других сайтов. Публиковались новости в черновики, потом я их редактировал и включал на сайте. Каждодневная эта процедура заняла меня тогда на целых полтора года. Потом, внезапно, все перешли читать новости в телегу и к сайту у народа интерес пропал.
Вообще, когда-то в 2008 году мне один программист сказал, что в принципе на PHP можно что угодно написать, хоть аналог Windows. Так ли это, не знаю, сомневаюсь, конечно. Но, однажды, видел сайт с шаблоном, как у проводника Windows, один в один, как на XP.
Xambey
Время некромантии, сейчас этого всего очень не хватает, пока спасаюсь только inoreader'ом. Статьи нынче фильтровать уже очень сложно, слишком много источников и чаще всего они так сделаны, что внутри фильтрацию не задать, да и ходить каждый день проверять 20+ сервисов/блогов, можно чекнуться
JustDont
Так и не понял, что мешает автору в 2020 году склепать сайт, который в своем минимальном воплощении всё так же представляет собой набор html-страниц (plaintext), как и в 1994 году.
Хочется «по высоким стандартам»? Так изучите их. Вы не можете за час поднять бек на ноде (или на пару слоев абстракций вверх от ноды) и фронт на каком-нибудь реакте — а я могу, например. Просто вы пытаетесь это сделать без каких-либо знаний, а я и то и другое пару лет назад делал, и таки да, с опытом оно в принципе как раз час и занимает, а остальные время этого «одного дня» — уже на содержимое пойдет.
Но и вариант «просто нафигачить хтмл-страниц и захостить их» тоже работает, и за день можно очень много нафигачить, я проверял (правда, тут совсем другие практические навыки нужны, в основном по работе с шаблонами текста руками).
VolCh
На самом деле, если руку набить, то всё это делается на автомате почти и быстро. Сложно только в первый раз, особенно если не работал на хорошо обустроенном проекте и результат хороший плохо представляешь.
402d
Будьте проще.
Шансы, что что-то станет настолько популярным, что появиться коммерческий смысл допиливать меньше 5%.
Увы, но идеальные системы оказываются завершенными к моменту, когда тема себя изжила.
Городские информационные порталы протухли лет 12-15 назад.
maggg
Мне интересна тема локальных городских медиа. Что на ваш взгляд пришло на смену городским информационным порталам?
sumanai
Группы «Подслушано в ххх» в ВК?
i360u
Справедливости ради, на той же голой ноде можно сделать сайт так-же как раньше делали на PHP, а то и проще. И без какого-либо оверинжиниринга. Но если бы такой подход был достаточно хорошим, вам бы не понадобилось переделывать старый…
Sano000
Акценты расставлены не правильно.
В 2013 году я пилил простые сайты на пэхэпэ в одно лицо за пара сотен долларов.
Сейчас одностраничник у нас обойдется тыщь в 170 долларов, 2 месяца, коллектив из 4 инженеров, плюс дизайнер плюс пол менеджера и стек из пол сотни технологий.
И это не плохо.
janvarev
Кому неплохо? :)
unsignedchar
Я думаю, что одностраничник обойдется в те же пару сотен. Стек из пары сотен технологий — и что с того? В 2013 году для запиления сайта ведь не нужно было собирать кастомное ядро, apache из исходников и vlan'ы прописывать? Раньше «под капотом» тоже было много чего спрятано. Сейчас — больше. Но упарываться во всё не обязательно.
Nalivai
Одностраничник обойдется в 0 рублей 0 секунд, он в качестве дефолтного примера с фреймворком идет.
А можно вообще мышкой в конструкторе за три бакса накликать.
unsignedchar
Те, кто умеет в фреймворк — ему одностраничник не нужен. Те, кому нужен — не умеют, но у них найдется несколько денег. Думаю, они договорятся ;)
Vaitek
А какой минимальный набор сейчас нужно изучить начинающему в веб строительстве? Бэк и фронт?
markmariner Автор
Я думаю, что можно взять любые технологии из тех, что упоминаются в статье, и из тех, что не упоминаются. Или даже любой курс на Udemy или Coursera. До поры до времени никакой разницы в технологиях заметно не будет. Я бы выбирал те, где документация проще читается.
Главное не уподобляться лирическому герою рассказа.
sergarcada
Наверное имелось ввиду другое. Что проще — учиться делать на голом на php или сразу учить какой-то фреймворк?
ForexBroker
Глупый вопрос, как можно делать что либо на фреймворке, не зная фишки языка и паттерны?
Alexufo
копипастить с гугла и поиска на гитхабе.
ForexBroker
Мне кажется, подобное подойдет для создания какой-то дырявой формы авторизации или решения лабораторной работы в университете (к примеру, реализация пузырьковой / альтернативной сортировки)
VolCh
Есть разница большая между знать язык и делать сайт на голом языке. Конкретно в PHP она смазана немного всякими суперглобалами и стандартными функциями типа header(), но вот, например, знание Java как языка мало поможет перевести сайт с PHP (не на Symfony :)) на Spring. Большую часть времени будешь гуглить как получить распарсить входящий запрос, как установить куки, как сделать запрос к БД и т. п., а не как объявить класс или переменную типизированную
VolCh
Сделать одну основную страничку несложную, но с современными "маст хэв" типа валидации, авторизации тройкой-пятком способов и т. п. на голом, а потом учить фремворк, чтоб понимать что там плюс-минус под капотом и, главное, а зачем он собственно нужен
ov3rfl0w
Полностью с вами согласен.
Добавлю ещё такие забавные линки:
BackEnd
FrontEnd
JustDont
HTML, CSS, JS.
Внезапно вы уже можете и бэк и фронт.
С самими инструментами, конечно, тоже придётся ознакомиться, с той же нодой. И реактом каким-нибудь. Но инструменты по важности сильно меньше фундамента.
HankRearden
Но есть Wordpress и Joomla!
Я так понимаю, главное отличие их от фреймворков — масштабируемость.
Alexufo
аахахаа я помню один слезный ишью на гихабе, где чувак недоумеевал. Он 10 лет писал под пресс и темы и плагины в блокноте, а ему теперь сказали изучай вебпак и реакт, потому что теперь никак)))
HankRearden
Я забыл поставить метку «сарказм».
abbey
не знаю как Scrum или Kanban, но начинать надо точно со структуры Octopus. Не благодарите :-)
KonstantinSpb
А можно сначала погуглить, может такое уже кто-то делал, например
1. github.com/fossasia/open-event-frontend
2. github.com/fossasia/open-event-server
eventyay.com (где крутится данный фронтенд и бэкенд)
1. edgeryders.eu/t/list-open-source-software-for-resource-scheduling-and-booking/6629/21
2. github.com/coderbyheart/open-source-meetup-alternatives
v1000
Немного напоминает историю, что когда делали первые автомобили, то для них все детали были сделаны вручную и подходили только для одной машины. Зато, когда появилась стандартизация, вопрос ремонта и запчастей стал гораздо проще, даже с учетом усложнения самой конструкции автомобиля.
anonymous
И сколько деталей от БМВ подходит к Тойоте и наоборот?
Noortvel
Если заедите в гаражный автосервис, то будете удивленны сколько запчастей от ВАЗа можно запихать в БМВ или Тойоту.
Kazikin
Не так и мало. Датчики разнообразные, фильтра, подшипники, ремни навесного, лампочки, предохранители, провода и многое другое.
anonymous
Обычно так — одна модель, одно поколение, чуть разные года выпуска — запчасти разные.
Molokastiy
Очевидно автор имел ввиду другое. К примеру у любой модели (одной модели) производства BMW возьми любые 2 машины(сколько угодно машин) у них все запчасти взаимозаменяемы.
titsi
Незнаю, но к форду подходят многие запчасти от мазды, и еще какой то марки. К сеату подходят от VW(хотя да они на одном платформе). если задаться целью то запчасти можно от других машин поискать и да они подойдут.
Angerslave
Нужно заранее предусмотреть будущую гетерогенность микросервисов и впихнуть MQ и Kafka до кучи, ведь когда хайлоад придёт — это будет некогда делать. А, и мастер-мастер репликацию с шардированием, и везде HA proxy, чтобы ни в коем случае нигде SPOF не образовался.
symbix
Просто веб вырос и стал годен для разработки полноценных клиент-серверных приложений.
Если нужен простой сайт — берешь и делаешь простой сайт, наличие микроскопа не обязывает забивать им гвозди. На современном фреймворке — если с ним знаком — это даже проще и быстрее, но и по-старинке никто не запрещает.
Valsha
Я так и не прочитал ответ на «вопрос» — « Хм, не могу же я просто взять PHP и написать на нем несколько страничек вперемешку с HTML. »
Так все же, почему нет?
edik-petrof
Всё просто и одновременно сложно. У лирического героя рассказа присутствует довольно явно выраженная профдеформация в сторону «голый php для школоты, а уважающему себя сеньору нужен более глубокий стек технологий», что и выливается в вышеуказанную несовместимость пушки с воробьями.
Но и с фреймворками на самом деле не всё так гладко, как может показаться на первый взгляд. Был у меня коллега, который для решения каких-то прикладных задач, слабо связанных с основным профилем деятельности конторы в целом, решил выучить фреймворк для web-разработки. И по этому поводу выучил...codeigniter. Это я к тому, что не всегда бывает возможно правильно предугадать вектор развития той или иной технологии.
VolCh
К слову, освоив codeigniter, на другие фреймворки переходить гораздо проще чем с "голого php" — ничего, концептуально противоречащего современным версиям популярных PHP-фреймворков, в нём нет.
edik-petrof
Возможно и так. Сложно сказать, поскольку с web-разработкой я связан менее, чем никак.
PsyHaSTe
Не увидел особой пушки по воробьям. Ну может не за день он это напишет, а за два. Но там текста больше чем реальных размышлений. "Ой, где хранить код" — ну блин, на гитхабе, разрабатывать можно или по облегченному гитхаб флоу, или вообще по принципу "все фигачим в мастер", раз уж разработчик на проекте единственный. Делается репа и заливается код ну за 5 минут.
Так что сарказм статьи понятен, но на самом деле все не так уж страшно. Если знать все используемые технологии, то выйдет не дольше чем на пхп. Если не знать — ну что поделать, я вот PHP не знаю, на нем у меня дольше займет, чем на реакте и шарпе.
edik-petrof
Хранение кода в контексте рассказа это как раз меньшее из зол. Начинается всё с того, что герой выбирает между несколькими разными способами сделать сайт. Реально можно взять для этого что угодно из перечисленного: хочешь — Symphony, хочешь — Node.js, а хочешь — связку Python + Django. Любой вариант так или иначе подходит. Вместо этого разработчик начитает метаться между всеми зайцами сразу, и результат оказывается закономерным.
Про это там тоже есть. Основной аргумент против — «так не делается». Упор моего изначального комментария был сделан на то, что в случае возникновения описанной в статье ситуации проблему необходимо искать не столько в выбранном стеке инструментов, сколько в самом себе. И не пытаться вместо MVP выдать сразу идеальный конечный релиз продукта, разумеется.nektobit
Так же не понимаю, кто вам запретит (ну кроме заказчика разве что, но из контекста заказчик — автор статьи). Pet проекты как и 10 лет назад прекрасно пишутся за вечер, единственное что изменилось — теперь есть пара вспомогательных инструментов которые не так уж сложно освоить за вечер — как то composer в случае PHP и npm в случае JS.
Bakuard
На мой взгляд, автор начал разработку не с того конца. Мне почему-то всегда казалось, что выбор инструментов разработки должен исходить из требований к ПО (бизнес требований, требований пользователя, функциональных требований и т.д.).
VolCh
Вы забыли про такие условия как компетенция команды разработки и её мотивация. Если вам удалось собрать хорошую команду и вы хотите её сохранить, то её желание или нежелание попробовать что-то новое может значить больше чем какие-то внешние требования, для реализации которых есть 100500 способов, если речь не идёт о хайлоаде и т. п. В экосистемах любых, наверное, мэйнстримовых и хайповых языков давно есть веб-фреймворки, позволяющие быстро создать веб-приложение с типовыми решения типовых инфраструктурных задач типа авторизации или маппинга реляционных данных на модель.
WicRus
Автор полон сомнений. Ему не стек выбрать хочется, а уверенность получить в том, что силы будут потрачены не зря.
Суть software, в то что это именно soft. Ошибка в выборе среды разработки/языка/фреймворка/и т.д. несёт потери только времени на разработку. Вам не придётся перепаивать платы, фрезеровать новые корпуса, заказывать пресс-формы. Сделал сайт, попользовался, костылями доделал, что можно. Когда накопилось N проблем, которые нельзя решить на данной архитектуре — берётся новая архитектура и повторяется разработка с начала.
Из опыта, переписывание уже имеющегося проекта с нуля на новой архитектуре ощутимо улучшает понимание и навыки разработчика.
EVolans
Не обязательно. Я вот в статье себя узнал, хотя вебом не занимаюсь и автор пишет немного о другом. Для меня это скорее перфекционизм/максимализм. Вместо того чтобы взять какой нибудь игровой движок и начать делать хоть что-то, я изучаю и разворачиваю дома связку confluence + jira + bitbucket как минимальный набор где вести документацию, ставить себе ленивому задачи и учиться работать в команде. Запускаю это все в связке между собой, с доступом через nginx, настроив https + бекап всего этого. Т.е. желание создать максимально правильную рабочу среду, прежде чем приступить, еще даже не поняв: «а то к чему я собираюсь приступать мне вообще интересно будет или нет»?
Еще есть аналог как проходить побольше «курсов» чтобы прийти во все оружии и понимать что и зачем, а не решать задачи/проблемы по мере их появления, но при этом так же сидеть и ничего толком не делать.
Andrey_Rogovsky
Маленький сайт — это HTML для браузера по стандартам W3C.
Если у вас какой-то бакенд, то это уже не маленький сайт.
VolCh
Html может быть на десятки тысяч страниц, а form — обычный! Html и он предлагает бэкенд. Может один простой php скрипт, но бэкенд
DenisTrunin
igrishaev
Просто выросли требования. Откройте сайт за 2013 год — скорей всего, он будет выглядеть убого.
sumanai
Тут уже упоминали рутрекер. Он на перепиленном движке phpBB из 2007 года.
igrishaev
По нему и видно, что сайт старый. Соверменный сайт — это много картинок, растягивающийся дизайн, адаптивная под все девайсы верстка.
sumanai
Но выглядит он не убого, а отлично. Вёрстка там кстати резиновая. А адаптивность там даром не нужна.
tmin10
Зачем, если он отлично выполняет свою функцию?
0xd34df00d
Это типа хорошо?
Я с нулевыми знаниями CSS и HTML сделал такое для своего блога полутора media query'ями (статически генерируемого, кстати, и не на JS и не на питоне). Вроде даже неплохо получилось.
Зачем вот эта вся ерунда из исходного поста для адаптивности?
vladkorotnev
Это не типа хорошо, это просто замечательно!
Чтобы ваш сайт стал совсем современным, не забудьте ещё добавить прибитый гвоздями вебфонт на 25 мегабайт с непрописанными фолбэками — нищеброды, которые не проплатили мобильник и вынуждены сидеть на 56кб/с до конца месяца, нам не нужны.
Однако, они могут железно выставить фонт браузера на расово верную Тахому и всё равно прочитать сайт, да ещё и без задуманных вами завитушек над каждой буквой имени директора. Не беда! Просто рисуем спиннер в непрозрачном слое и отключаем скролл, пока не загрузятся все ресурсы, в том числе шрифты, а грузим их так же со скриптов.
Вуаля! Ваш сайт теперь современен как никогда раньше, и заодно защищён от неплатёжеспособных нищебродов с медленными каналами, полуразряженными телефонами, а также подозрительных хакеров, ходящих читать новости компании со включённым NoScript.
LevOrdabesov
КМК имеются в виду «реклама, скрытая реклама, скрытое позиционирование марки, „интересное“, „посмотрите ещё вот это“, „оставьте свой емейл сейчас чтобы быть со скидками“, „напишите свой вопрос мы онлайн!“, трекеры, анализаторы и прочая воронка продаж».
От благодарного пользователя: нет, спасибо. Верните HTML.
driftwood
И всплывающих окон?
raiym
Почему-то, только мельком упомянут CI/CD, deployment, release management. К этому вопросу нужно тоже серьезно подойти. Возможно выбор GitHub не достаточно хорошо обдуман.
Может лучше развернуть Jenkins? Или использовать GitLab, ведь если делать сборку прямо в GitHub, может не хватить бесплатных минут, готовы ли вы доплачивать за это?
PsyHaSTe
Есть же github actions, я растовый петпроект собираю без проблем
anonymous
Очень похоже на ту гусеницу, у которой спросили, а с какой ноги ты начинаешь идти?…
szanislo
А как же микросервисы? Неужто ли для каждой новой фичи пересобирать весь проект.
miner2100
В последнее время все поделия в интернете, любой сложности вызывают тошноту. Просто монбланы бессмысленности. Растрачивание себя.
Реально крутой сайт выглядит вот так: www.malinov.com/Home/sergeys-projects
Прожить жизнь так, чтобы вот после тебя осталось такое.
vladshulkevich
От это реально крутяк.
PsyHaSTe
Вот так
Mitai
Чувак бери Dart, он умеет и в backend and frontend, а еще aot компиляция, в нативный код, закинул на сервер и все))
статья огонь))
Mishkauka
Получается «продолжение следует»? Окей, мы ждем
Murimonai
Ну вот автор и узнал про глубину значения слов «архитектура веб-приложения». Когда приложение маленькое и простое — то и архитектура у него укладывается в условный php+mysql с фронтом без мудреных скриптов. А если начать закладывать решения под еще не поставленные перед вами проблемы (типа хранения кода, пул реквестов, мониторинга, деплоя свежих версий и так далее) — то и архитектура предсказуемо усложняется.
Добро пожаловать, что называется.
Кстати, слышал со временем люди поднабравшиеся всякого такого начинают зарабатывать продажей вот таких готовых решений в стиле all inclusive. В стиле: тебе деньги на сервисы и людей, а ты им кубернетисы, инстану с прометеусом, деплоймент в рандеке, битбакет с разными проектами под фронт и бек, CDN какой до кучи, все задокументировано в какой-нибудь конфлюенс — и обязательно красивые графики посещаемости и доступности каждую неделю.
Короче, холоптное такое дельце, как у нас говорят.
rpiontik
Мне кажется — все логично. Сейчас не нужно делать простенькие сайты. Трудиться для этого. Есть ресурсы, которые за ограниченное время, с хорошим результатом делают это за тебя. Например — tilda.
Остается именно то, что стоит разрабатывать. Т.е. тратить на это время разработчика. Отсюда релевантные (но сложные) инструменты и процессы.
dominigato
Так надо было в армии и оставаться, там все одно и тоже, все как всегда). Как десять лет назад зубной щёткой плац мыли, так и через десять лет будут. Никакой угрозы новых технологий)
trawl
Насчет 10 лет не знаю, но 14 лет назад плац подметали ломом. Так что, похоже, и там технологии меняются
Scarred
Это скорее местные традиции: где-то зубной щеткой, где-то ломом, а где-то граблями… :)
Kyubey
Понимаю автора. Но в статье не сделан вывод — бывают времена, когда не знаешь, с какого бока подступиться к новым технологиями, появившимся на рынке за то время, пока ты за ним не следил. Но и 10 лет назад было то же самое, и это хорошо, что такая тенденция сохраняется. Это значит, что появляются новые вещи, совершаются скачки, появляются новые ниши. Хотя иногда хочется, чтобы время текло чуть помедленнее, чтобы было, как в киберпанке — чтобы вокруг уже стояли дома в сотни этажей, а люди всё ещё звонили по старой мотороле, ну вы поняли — технологический экстремум. Всем не хочется уходить с тёплой насиженной технологии, хочется, как в игре, продолжать и продолжать её развивать. Но другие люди приходят с другими идеями и забирают рынок.
Можно и сейчас на пхп писать странички, но теперь вам всегда будет этого мало. Как только вы прикоснулись к миру этих красивых названий, вы будете знать, что вот сейчас вы пишете страничку на хтмл+пхп, а где-то там есть штука, которая поможет это сделать быстрее, красивее и откроет вам что-то новое. Да ещё и сайт будет быстрее грузиться. Вот только для этого нужно изучить эту технологию (скажем, пусть это будет ReactPHP и его асинхронный цикл), встретить другие сложности, решить другие проблемы. А может, вы вовсе решите сделать блог на Jekyll+Ruby, кто знает.
Я считаю, что это закономерный процесс. (Но я не говорил, что считаю нужными все перечисленные в посте технологии)
jaiprakash
tempick
Помню, был некоторое время безработным, пришёл на «собеседование» к 22-летним парням (мне самому столько же), у которых своя «веб-студия» — пообщались, всё нормально. И Первым проектом дали задачу сделать PWA-приложение небольшого интернет-магазина (местный магазин одежды). Также добавили, что у них с этим проектом проблемы в плане сроков и их недоделанное решение пришлось выбросить и надо писать с нуля (и закончить за 2 недели). Я говорю — так, может, не PWA, а просто на Yii2 + pjax + flexbox быстро накидаю просто рабочее решение, чтобы показать можно было заказчику, а потом уже допиливать потихоньку. Челы переглянулись и сказали, мол, «PHP сейчас не нужен, можешь rest api написать на нем, но на фронте нужен nuxt.js и PWA».
Я: Заказчик сам попросил вас именно PWA, а не просто интернет-магазин?
ОНИ: Нет, но мы понимаем, что нужен PWA. Сейчас все делают PWA, так что в первую очередь делаем его, а потом уже полноценный сайт запилим.
Pavel1114
И что? Почему подобное так часто попадает в топ хабра? Любим поныть на пустом месте?
Alexufo
Как на медузе.
Если вы не приемлите это видео, лучше почитайте про котиков, или посмотрите статью про восстановление рукописей
https://m.habr.com/ru/post/521870/
titsi
Кмк, обмен некоторым опытом. что то да ведь узнаешь из таких статей+комментов.
bayarsaikhan
Я тут решил сделать что-то типа простого блога. Взял просто HTML файл, запихнул туда текст и зааплоадил. Когда записей будет слишком много, просто разобью на очередную страницу. Когда я это сделал, озирался по сторонам, чтобы убедиться, что никто не видит. Заняло минут 5-10. Никакого кода, за исключением CSS и HTML, поддерживать не надо. Знаю точно, что ничего не сломается: JavaScript'а ни одной строчки; серверного кода ни одной строчки. Появилась удивительная легкость в членах тела.
0xd34df00d
А теперь вам надо сделать теги, автоматическую генерацию оглавления для статей побольше, и подсветку синтаксиса для кусков кода в постах в блоге. И вот простым HTML-файлом уже не отделаешься.
Впрочем, у меня как раз тоже такой блог есть, и там тоже джаваскрипта ни строчки, и серверного кода тоже. Но генератор используется, а контент в markdown пишется.
ganqqwerty
Я на работе для таких вещей пользуюсь заклинанием:
maggg
Я угадал заклинание под спойлером и довольно улыбаюсь. :)
0xd34df00d
Ну хоть подсветка синтаксиса нужна!
А если серьёзно, то оглавление полезно — когда читаешь статью, представляешь, что там будет и с какой структурой. Не зря это самое оглавление есть практически во всех книжках, диссерах и так далее.
Теги — тоже полезно. Если я вижу чей-то блог, и чувак пишет о куче разных тем, из которых мне интересна одна, то я могу просто выбрать этот тег и почитать статьи под ним.
Megadeth77
IT нужно учиться, открытие! А казалось бы был поваром, закончил пару курсов и бегом по 300 тонн в месяц заколачивать.
micho1973
Лет 10 назад я сделал электровелосипед из старого Туриста, стартёра и аккумулятора от копейки. А сейчас делаю электромобиль с расчетом на сертификацию для дорого общего пользования…
northmule
Какую технологию не выбери, всё равно потом «турбо страницы» нужно будет делать
sumanai
Не нужно, и даже вредно.
qalalab
Автор ты не догуглил про джангу. Берешь pypi.org/project/djangocms-blog — и прикручиваешь это к базе. Админка в джанге из коробки с UI вполне юзабельный. В чем сложность?
AlexTheLost
Дед говорил — раньше трава была зеленее и вообще как то без ваших сайтов жили.
p.s.
Статья ни о чём — ничего не мешает сделать быстро маленький сайт ещё и лучшего качества.
И уже тем более никто не мешает все делать как в 90-х, распростанять кстати можно через каталоги, а то эти гуглы требуют какой то оптимизации и т.п.
CrashLogger
Я бы сделал на php и jquery. А когда/если на этот сайт придут миллионы пользователей — идем к инвестору, берем денег и нанимаем ребят с фреймворками и канбаном.
ganqqwerty
По-моему, в обычном мейнстримном галечном фронте сейчас раздолье — ничего не меняется уже несколько лет, сиди да почитывай одну статью в три месяца.
springme
Зато вы можете сделать большой сайт.
iDmitriyWinX
Солидарен с криком души автора, столько информации надо поглощать, да в прочем — это же интересно! Для любителей самообразования тут целое раздолье!
Все эти реакты с ангулярами на фронте, node js’ы с electron’ами на бэке, для всех найдется что-то интересное. А когда начинаешь погружаться в интересующую сферу — то глаза разбегаются, сколько же нюансов.
Пишу сервер для своей игры и параллельно почитываю книгу Куроуза по сетям, мда, поражаюсь иногда тому, сколько же человечество создало за годы своего существования.
В общем, удачи автору в написании сайта :)
agalitsyn
Как раз недавно написал eshop, бек на django, фронт частично на django частично на react, деплой на ansible (nginx + gunicorn + django + postgres + memcached на 1 сервер). Но я не скажу что справился быстро. По моим ощущениям чертовски долго долбался с динамическими кусками на UI, это страница просмотра товара и оформление заказа. Делать перезагрузку на + — из корзины уже вообще не смотрится, так же как на переключение опций товара. На jquery программировать было очень убого, особенно обновление соседних элементов таблице. Нужно было какое-то красивое обновление контейнера целиком. Поэтому втащил реактовые мини-приложения, которые у меня каждое в своем файле, они просто подключаются и рисуют контент часть в body. Конечно несколько api методов пришлось сделать через DRF. Работает и можно расширять. В коде конечно частично каша, надо полностью отделять фронт от бека. Зарабатывает сайт скромно пока что.
А вот кулстори от создателя remoteok, который сделал сайт в 1 php файле и зарабатывает под $60к в месяц с него. Кто из нас дурак, очевидно
MRD000
А зачем поддерживать сервер, если можно в Google Apps Engine или Lambda все положить. Взял шаблон и всё. Сервер нужно апгрейдить постоянно и т.п. На простых хостингах это вроде как не нужно, конечно.
VolCh
Дорого.
motoroller95
Не понимаю в чем посыл статьи. Хотите простенький сайт? пожалуйста, пишите как удобно. Хотите свистелки-перделки? Пожалуйста, в статье их куча. Выбирайте инструменты под задачу, а не потому что об этом все говорят.
MikiRobot
imho, проблема выдумана. Если вы уже поработали в "маленьких и средних" компаниях у вас уже сложился некоторый стек технологий. Для описываемой задачи не нужно принимать столько решений, просто берете то что умеете и применяете на практике.
Вопрос о языке коммитов или ветвлении вообще не нужно поднимать если проект изначально не планируется в широкие массы — скорее всего, когда это понадобится вы перепишите 90% кода и смените хотя бы половину применяемых технологий.
pervehou
Ну, я несколько со своей стороны — жаба+томкат+(жсп или хсл+хмл) — чем плохое решение? Я понимаю, что здесь некое сьезжание с фронтенда на бэкенд. Но все же
virtual_hack2root
А взял бы C# — ничего из вышеуказанного изучать бы не пришлось, т.к. можно и веб компоненты и фронтенд на C# писать
xRay
Пост о том когда много знаешь и умеешь, то простое можешь сделать сложным. :)
Надо быстро и просто. Просто бы взял bootstrap. Стилизовал. И дальше усложняй как угодно.
sarapinit
Забавно, что в топе за неделю сразу за этим постом идет пост «Мама, я сделал хабр»
petrovnn
Последний абзац напомнил:
Напишу-ка я песню о любви,
Только что-то струна порвалась,
Да сломалось перо, ты прости,
Может, в следующий раз…
А сейчас пора спать…
anonymous
Плохие решения. Надо брать руби и рельсы, добавить к ним постгрес и эрспеки.
Потом можно, если потребуется прикрутить и вьюджиес.
maxys146
Прочитал пост и как-то немного защемило в душе…
Мне кажется смысл поста вовсе не в том что слишком много технологий, большой выбор и так далее.
Смысл в том что чем больше опыта — тем больше сомнений.
Раньше не задумываясь берешь то, что знаешь и пилишь то, что хочешь. Общажный сайт на голом php в блокноте? Легко. Это весело и интересно, ты создаешь своими руками что то новое, не знаешь что из этого получится, и не думаешь как поддерживать это дальше. Зато каждый день видишь как это нечто растет и развивается, как на него приходят люди и пользуются тем что ты сделал. И это вдохновляет.
А сейчас давит груз опыта, который мешает наслаждаться процессом созидания. Ты не хочешь допускать глупых ошибок которые допускал ранее, хочешь сразу сделать всё правильно, продумать архитектуру, стек технологий, этапы реализации и даже выгоду. И глядя на всё это возникает такой шквал сомнений, что просто ни за что не берешься, прекрасно понимаешь что работы очень много, изучить надо кучу всего… И всё, руки опускаются.
Именно это я увидел в посте. Именно это откликнулось во мне.
Автору огромное спасибо, я как про себя прочитал :)
web1nick
Самое забавное, что многие так и работают, — как мартышки используют модные технологии ради технологий, а не ради практичности, т.е. там, где они действительно нужны