- Поисковые системы
- Практика оптимизации
- Трафик для сайтов
- Монетизация сайтов
- Сайтостроение
- Социальный Маркетинг
- Общение профессионалов
- Биржа и продажа
- Финансовые объявления
- Работа на постоянной основе
- Сайты - покупка, продажа
- Соцсети: страницы, группы, приложения
- Сайты без доменов
- Трафик, тизерная и баннерная реклама
- Продажа, оценка, регистрация доменов
- Ссылки - обмен, покупка, продажа
- Программы и скрипты
- Размещение статей
- Инфопродукты
- Прочие цифровые товары
- Работа и услуги для вебмастера
- Оптимизация, продвижение и аудит
- Ведение рекламных кампаний
- Услуги в области SMM
- Программирование
- Администрирование серверов и сайтов
- Прокси, ВПН, анонимайзеры, IP
- Платное обучение, вебинары
- Регистрация в каталогах
- Копирайтинг, переводы
- Дизайн
- Usability: консультации и аудит
- Изготовление сайтов
- Наполнение сайтов
- Прочие услуги
- Не про работу
Зачем быть уникальным в мире, где все можно скопировать
Почему так важна уникальность текста и как она влияет на SEO
Ingate Organic
Как по мне так тут возможны несколько подходов / подводных камней:
SQLite это база или файл? Можно ли считать систему на ее базе файловой?
Если отказываться от SQLite, то как хранить инфу дальше? Изобретать велосипед вместо скулайт и хранить все в одном файле или иметь целые деревья папок в каждом файле по одной записи?
Для работы с файлами нужно прописывать права. Спрашивать доступ к фтп при инсталяции или заставлять пользователя прописывать права самому?
Главный вопрос - а зачем это все? Простота установки? Фрихосты без базы? Простота переноса?
Как по мне так тут возможны несколько подходов / подводных камней:
SQLite это база или файл? Можно ли считать систему на ее базе файловой?
Если отказываться от SQLite, то как хранить инфу дальше? Изобретать велосипед вместо скулайт и хранить все в одном файле или иметь целые деревья папок в каждом файле по одной записи?
Для работы с файлами нужно прописывать права. Спрашивать доступ к фтп при инсталяции или заставлять пользователя прописывать права самому?
Главный вопрос - а зачем это все? Простота установки? Фрихосты без базы? Простота переноса?
Для своих целей сделал как-то CMS, которая всё берёт из Subversion (тоже, в каком-то смысле, БД), и автоматически перегенерирует все изменившиеся страницы сайта скриптом, вызываемым как хук post-commit.
Плюс - все страницы статические (тем не менее, на таком CMS вполне можно делать хоть наши любимые блоги, хоть что-то ещё), такой сайт минимально загрузит Web-сервер при прочих равных.
Минус - для "обычного" пользователя всё равно нужна минимальная Web-морда, поскольку средний пользователь Subversion не пользуется.
Для преимущественно статических сайтов (контент читается на несколько порядков чаще, нежели пишется) вполне годно.
Мускул тоже хранит данные в файлах. К.О.
Есть готовые решения, такие как:
Gladius DB
textSQL DB - вроде так называется она
Я в Template CMS юзал обычные текстовые файлы данные разделял специальными символами. собственно свой велосипед.
В Template CMS 2 использую XML для хранения данных - это очень удобно.
Не надо хранить вот так, как в Template CMS 1:
admin{|}11f504164d5a111d6a820e11614a1109{|}awilum@msn.com{|}admin
а вот так:
плюс свой велосипед для работы с этими данными :)
Простота установки?
да
Фрихосты без базы?
да
Простота переноса?
да
- просто перенести данные с одного сервака на другой
- проще и быстрее делать бэкап данных
- кроссплатформенность.
- данные сайт можно править не посредственно по FTP
- сайт построенный таким образом на шаред хостингах будет выигрывать в скорости остальные сайты если SQL будет перегружен. Так как сайт не зависит от SQL
- подобные системы безопасны от SQL-инжекций.
- более высокая скорость генерации страницы. Так как открыть файл и прочитать его быстрее чем обратиться к SQL серверу -> таблице -> выбрать запись.
- Низкие требования к хостингу.
SQL - это гибкая работа с контентом.
Файлы - топорный вариант адаптации к хреновому хостингу.
Имея контент в базе, никто не мешает сделать его моментальную генерацию в статику, если есть такая необходимость.
Файловые CMS в 99% не имеют ни какого контроля за целостностью данных, поэтому если на файлах сообщений об ошибках нет, это совершенно не значит, что эти самые ошибки отсутствуют. А уж про контроль за связями данных, можно вообще не говорить :)
Сделать модификацию для файловой CMS в десятки раз сложнее чем для базы. То что в базе делается элементарным селектом из пары таблиц, в файлах превращается в прочесывание сотен файлов и директорий.
Так что удел файловых цмс - это дорвеи, сплоги и прочий мусор.
Главный вопрос - а зачем это все?
Скорость.
SQL - это гибкая работа с контентом.
Файлы - топорный вариант адаптации к хреновому хостингу.
Ничего так, что SQL это всего лишь (утрирую) язык обращения к информации хранящейся в файле?
Скорость.
не факт и не всегда.
Индексы в базах, тоже какбы не спроста придуманы. И зачастую фнукция написанная на сях будет быстрее работать чем та же, на пхп.
Индексы в базах, тоже какбы не спроста придуманы.
Речь идёт о скорости доступа - выборака информации это уже дело второстепенное. Можно организовать такую FS, что индексы будут "нервно курить в сторонке".
фнукция написанная на сях будет быстрее работать чем та же, на пхп
Я этого не отрицаю, но, повторюсь: при грамотной организации файловой структуры, ПХП-шные аналоги СИ-шных функций просто не потребуются.
Как по мне так тут возможны несколько подходов / подводных камней:
SQLite это база или файл? Можно ли считать систему на ее базе файловой?
однозначно можно. потому что в данном случае, в сборке веб страницы участвует только апач. соответственно, нет зависимости от сервера бд
Если отказываться от SQLite, то как хранить инфу дальше? Изобретать велосипед вместо скулайт и хранить все в одном файле или иметь целые деревья папок в каждом файле по одной записи?
я когда-то читал про "плоские файлы". но руки в своё время не дошли. писал в свое время и под один файл для базы, и под деревья папок. тут всё зависит от задачи.
Для работы с файлами нужно прописывать права. Спрашивать доступ к фтп при инсталяции или заставлять пользователя прописывать права самому?
тут моя позиция, как разработчика однозначна. чем меньше у пользователя доступа к тому, что он может по незнанию сломать или потерять, тем лучше. система управления, на то и система управления, чтобы пользователь не заморачивался на технических проблемах. это для разработчика важны скрипты. пользователь хочет хвастаться результатом и генерить контент.
Главный вопрос - а зачем это все? Простота установки? Фрихосты без базы? Простота переноса?
однозначно. а так же добавьте в список - невысокие побочные расходы. когда ко мне приходит совсем бедный заказчик, которому просто надо что-то сейчас, для решения конкретной задачи, самый лучший выход - предложить тот же вп на sqlite. пусть работает криво-косо, но результат быстро и недорого. ну и опять же - писал выше, что нет зависимости от еще одного сервера
можно организовать такую FS, что индексы будут "нервно курить в сторонке".
но чем больше мы удаляемся в сторону постройки кастомной файловой системы, тем ближе мы приближаемся к эффективности использования уже готовых решений, ибо начинают играть роль вопросы тестирования и.т.д.
И для большинства случаев проще использовать что-то готовое, чем городить нечто своё, и это вполне может какая-то реляционная база, которая может быть в чём-то теряет, но для подавляющего большинства решений имеет свои преимущества в плане выборок и универсальности настроек.
Хотя и любое свое решение имеет право на жизнь. Например, сейчас мне пишут систему, которая будет работать на связке MySQL+MongoDB - основные данные будет хранится в MySQL и работа с ними будет проводить через ORM, и похожий но со своими особенностями слой будет лежать над MongoDB, но в этой NoSQL базе будут хранится дополнительные поля для материалов и разделов.
Первоначально хотели делать используя паттерн EAV, но моя настороженность и мнение программиста всё же объединились вместе и мы пришли к выводу, что это будет не совсем рациональный подход. С другой стороны минусом NoSQL (в частности MongoDB) есть средняя отказоустойчивость и время для восстановления после сбоев. В итоге, сошлись, что основные данные храним в MySQL и если MongoDB в дауне или же идёт процесс восстановления данных, то соответствующие данные просто не учитываются при поиске и не отображаются.
Сейчас должна выйти новая версия MongoDB и там будет журналирование, но пока что полного доверия нет, поэтому остановились на этой схеме.
И ? Надеюсь не надо объяснять, что под sql подразумевается работа с базой, или же еще базы данных перечислить ?
Вообще скорость доступа и измеряет выбор информации.
под sql подразумевается работа с базой
Базы данных - это не обязательно SQL-базы данных. Поэтому замечание Brand from Amber справедливо.