ALT Linux Team development discussions
 help / color / mirror / Atom feed
From: Alexey Tourbin <at@altlinux.ru>
To: devel@lists.altlinux.org
Subject: Re: [devel] вопрос про BDB и блокировки.
Date: Fri, 27 Apr 2007 15:02:31 +0400
Message-ID: <20070427110231.GC11839@solemn.turbinal> (raw)
In-Reply-To: <200704271538.52277.asy@altlinux.ru>

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

On Fri, Apr 27, 2007 at 03:38:52PM +0500, Sergey Y. Afonin wrote:
> On Friday 27 April 2007, Alexey Tourbin wrote:
> 
> > DB_INIT_CDB дает "прозрачный" локинг для каждой операции. 
> > То есто операция начинается берётся блокировка.  Операция заканчивает
> > блокировка снимается.
> > 
> > DB_INIT_LOCK по идее специально указывать не надо, если указано
> > DB_INIT_CDB|DB_INIT_MPOOL.
> > 
> > Там есть ещё другой режим вместо локинга, он log может писать.
> 
> Но этот другой режим - тоже режим блокировок ? Хочется понять, почему
> сейчас работает, когда нет явного указания на использование блокировок. 
> Обязательно уже должно было несколько процессов к одной базе сунуться 
> и не раз. Ан нет, пашет... 

Скорее всего, не работает.  Просто если чтение с записью
не пересекается, то это, может быть, прокатывает.  Ну или там один в
базу записал а другой старую копию базы видит, и это работает, пока
постраничные данные не перезаписаны.  

Режима два разных: либо блокировать всю базу (ну или там постранично),
либо писать write-ahead log (это транзакции, там сложнее уже).  Либо
блокировать своими средствами.

Делайте как у меня, лучше пока ничего не придумано. :)  Похожим образом
сделано в /usr/sbin/amavisd, только там BerkeleyDB::Env->new ничем не
блокируется.  По-моему при одновременных попытках инициализировать evn
будет капут.

При использовании логинкга или DB_INIT_CDB очень важно сигналы правильно
заблокировать.  /usr/share/doc/db-4.4.20/ref/program/appsignals.html
К сожалению в перле это делается проще чем в C.

[-- Attachment #2: Type: application/pgp-signature, Size: 189 bytes --]

  reply	other threads:[~2007-04-27 11:02 UTC|newest]

Thread overview: 9+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-04-27 10:05 Sergey Y. Afonin
2007-04-27 10:20 ` Alexey Tourbin
2007-04-27 10:38   ` Sergey Y. Afonin
2007-04-27 11:02     ` Alexey Tourbin [this message]
2007-04-27 12:00       ` Sergey Y. Afonin
2007-04-27 12:07         ` Sergey Y. Afonin
2007-04-27 11:19     ` Alexey Tourbin
2007-04-27 11:40       ` Sergey Y. Afonin
2007-04-27 10:24 ` Sergey Y. Afonin

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=20070427110231.GC11839@solemn.turbinal \
    --to=at@altlinux.ru \
    --cc=devel@lists.altlinux.org \
    /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