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: Thu, 10 Mar 2005 13:21:12 +0300
Message-ID: <42301F98.4050103@gorodmasterov.com> (raw)
In-Reply-To: <4227A0C7.3000308@gorodmasterov.com>

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

Блин, симлинковые фермы тоже не всегда спасают и даже могут поломать 
веб-приложение.
В частности, в случае php-приложений, частенько используют константу 
__FILE__ для определения полного имени файла запускаемого скрипта. В 
случае если файл является символической ссылкой, то __FILE__ следует 
ссылке и возвращает полное имя файла, на который ссылается ссылка. В 
дальнейшем этот путь может используется для доступа (include, open) к 
другим файлам (по относительным смещениям). В итоге, приложение просто 
не видит и не использует rw-файлы, которые были скопированы ему в 
виртуальный хост.

> На данный момент такое клонирование я реализовал в виде небольшой 
> утилитки farmer.

А утилитку я доделал -- теперь это пакет, который и реализует все те 
фичи, о которых говорилось в топике. Правда на первом же запакованом 
пакете я и нарвался на "мину", описанную выше :(

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


  parent reply	other threads:[~2005-03-10 10:21 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
2005-03-04  8:09             ` Michael Shigorin
2005-03-10 10:21             ` Vladimir Lettiev [this message]
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=42301F98.4050103@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