ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: Vladimir Lettiev <crux@gorodmasterov.com>
To: ALT Devel discussion list <devel@altlinux.ru>
Subject: Re: [devel] Re: idea: webapps packaging and webapps control system
Date: Fri, 04 Mar 2005 02:41:59 +0300
Message-ID: <4227A0C7.3000308@gorodmasterov.com> (raw)
In-Reply-To: <20050226164227.GS5646@osdn.org.ua>

[-- Attachment #1: Type: text/plain, Size: 2146 bytes --]

Michael Shigorin wrote:
> Вот алгоритм примерно обрисовать получается?  Задачи-то ясны, 
> а вот реализация без копий или вагонов симлинков, которые
> неизбежно будут искушать "поправить ручками" либо требовать
> отдельного окучивания (и порй создавать странные проблемы) --
> непонятна.

Чем дольше думаю над алгоритмом, тем больше понимаю, что ничего лучше 
симлинковой "фермы" придумать не могу. Т.е. устанавливая веб-приложение 
в /usr/share/... мы тем самым делаем его readonly, но поскольку 
практически всегда требуется изменение каких-то файлов (причём в каждом 
виртуальном хосте своё), то необходимо эти изменяемые файлы _копировать_ 
в виртохост, а на ro-{файлы|каталоги} делать ссылки.

На данный момент такое клонирование я реализовал в виде небольшой 
утилитки farmer. Она умеет клонировать файлы, умеет обновлять их (при 
повторном запуске). В командной строке просит два параметра: 
директория-источник и директория-назначение.
Вначале скрипта есть такая конструкция:
my %config = (
                 "confFiles"=> ["config/*php","config/conf.xml"]
         );

Тут в квадратных скобках, перечисляются названия файлов (и/или 
директорий), которые надо _копировать_, т.е. те самые изменяемые файлы. 
Имена перечисляемых файлов(директорий) указываются относительно 
директории источника. Как видно, можно использовать символ '*' - любая 
последовательность символов (в том чиcле нулевая).

Скриптец я заатачил. Есть ли есть желающие протестировать -- welcome. 
Можно пробовать расширять список confFiles, затем уменьшать и смотреть 
на результат.

Что в итоге. Если каждый веб-пакет, снабжать неким конфигом с указанием: 
списка rw-файлов, конфигурацией для apache, где вместо реальных путей, 
указывать некую переменную ($DocumentRoot). То этого уже вполне 
достаточно для нормального функционирования и обновления веб-приложения. 
Будет утилита, которая будет по требованию клонировать веб-приложение и 
подсовывать корректный конфигурационный файл для апаче для конкретного 
виртохоста.

p.s. Тему СУБД я пока не затрагиваю - это наверно можно решать отдельно.

-- 
С уважением, Владимир Леттиев aka crux <crux@gorodmasterov.com>

[-- Attachment #2: farmer.gz --]
[-- Type: application/x-gzip, Size: 1305 bytes --]

  parent reply	other threads:[~2005-03-03 23:41 UTC|newest]

Thread overview: 25+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-02-26 14:08 [devel] " Vladimir Lettiev
2005-02-26 15:12 ` [devel] " Michael Shigorin
2005-02-26 18:06   ` Volkov Serge
2005-02-26 15:14 ` Michael Shigorin
2005-02-26 15:26   ` Vladimir Lettiev
2005-02-26 16:07     ` Michael Shigorin
2005-02-26 16:21       ` Vladimir Lettiev
2005-02-26 16:42         ` Michael Shigorin
2005-02-26 17:23           ` Vladimir Lettiev
2005-03-03 23:41           ` Vladimir Lettiev [this message]
2005-03-04  8:09             ` Michael Shigorin
2005-03-10 10:21             ` Vladimir Lettiev
2005-03-10 10:30               ` Michael Shigorin
2005-03-10 11:19                 ` Vladimir Lettiev
2005-03-10 10:53             ` Ivan Fedorov
2005-03-10 11:10               ` Michael Shigorin
2005-03-10 11:22                 ` Anton Farygin
2005-03-10 11:39                   ` Michael Shigorin
2005-03-10 12:40                     ` Anton Farygin
2005-03-10 12:53                       ` Ivan Fedorov
2005-03-11 10:46                       ` Michael Shigorin
2005-03-11 10:48                         ` Ivan Fedorov
2005-03-15  8:52                           ` Anton Farygin
2005-03-15  8:51                         ` Anton Farygin
2005-03-10 11:38                 ` Ivan Fedorov

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4227A0C7.3000308@gorodmasterov.com \
    --to=crux@gorodmasterov.com \
    --cc=devel@altlinux.ru \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link

ALT Linux Team development discussions

This inbox may be cloned and mirrored by anyone:

	git clone --mirror http://lore.altlinux.org/devel/0 devel/git/0.git

	# If you have public-inbox 1.1+ installed, you may
	# initialize and index your mirror using the following commands:
	public-inbox-init -V2 devel devel/ http://lore.altlinux.org/devel \
		devel@altlinux.org devel@altlinux.ru devel@lists.altlinux.org devel@lists.altlinux.ru devel@linux.iplabs.ru mandrake-russian@linuxteam.iplabs.ru sisyphus@linuxteam.iplabs.ru
	public-inbox-index devel

Example config snippet for mirrors.
Newsgroup available over NNTP:
	nntp://lore.altlinux.org/org.altlinux.lists.devel


AGPL code for this site: git clone https://public-inbox.org/public-inbox.git