<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Aleksey Parshukov &#187; Linux</title>
	<atom:link href="http://www.filosof.name/tags/linux/feed" rel="self" type="application/rss+xml" />
	<link>http://www.filosof.name</link>
	<description>Aleksey Parshukov persoonal blog</description>
	<lastBuildDate>Sat, 29 Jan 2011 20:59:47 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.0</generator>
		<item>
		<title>grep, N строк до, N строк после</title>
		<link>http://www.filosof.name/articles/grep-n-%d1%81%d1%82%d1%80%d0%be%d0%ba-%d0%b4%d0%be-n-%d1%81%d1%82%d1%80%d0%be%d0%ba-%d0%bf%d0%be%d1%81%d0%bb%d0%b5.xhtml</link>
		<comments>http://www.filosof.name/articles/grep-n-%d1%81%d1%82%d1%80%d0%be%d0%ba-%d0%b4%d0%be-n-%d1%81%d1%82%d1%80%d0%be%d0%ba-%d0%bf%d0%be%d1%81%d0%bb%d0%b5.xhtml#comments</comments>
		<pubDate>Thu, 23 Sep 2010 08:24:36 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Операционные системы]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[grep]]></category>
		<category><![CDATA[log]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=326</guid>
		<description><![CDATA[Очень полезная штука для анализа логов через grep. Выводит N строк до совпадения, N строк после: -A NUM, --after-context=NUM Print NUM lines of trailing context after matching lines. Places a line containing -- between contiguous groups of matches. -B NUM, --before-context=NUM Print NUM lines of leading context before matching lines. Places a line containing -- [...]]]></description>
			<content:encoded><![CDATA[<p>Очень полезная штука для анализа логов через <strong>grep</strong>.<br />
Выводит N строк до совпадения, N строк после:</p>
<pre><code class="pre">       -A NUM, --after-context=NUM
              Print NUM lines  of  trailing  context  after  matching  lines.
              Places  a  line  containing  --  between  contiguous  groups of
              matches.

       -B NUM, --before-context=NUM
              Print  NUM  lines  of  leading  context  before matching lines.
              Places a  line  containing  --  between  contiguous  groups  of
              matches.</code></pre>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/grep-n-%d1%81%d1%82%d1%80%d0%be%d0%ba-%d0%b4%d0%be-n-%d1%81%d1%82%d1%80%d0%be%d0%ba-%d0%bf%d0%be%d1%81%d0%bb%d0%b5.xhtml/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>mdadm, Мигрируем на новые физические диски</title>
		<link>http://www.filosof.name/articles/mdraid-migration.xhtml</link>
		<comments>http://www.filosof.name/articles/mdraid-migration.xhtml#comments</comments>
		<pubDate>Wed, 02 Jun 2010 13:24:03 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[RAID]]></category>
		<category><![CDATA[Ubuntu]]></category>
		<category><![CDATA[mdadm]]></category>
		<category><![CDATA[Все]]></category>
		<category><![CDATA[Высокие технологии]]></category>
		<category><![CDATA[Операционные системы]]></category>
		<category><![CDATA[fdisk]]></category>
		<category><![CDATA[fstab]]></category>
		<category><![CDATA[grub]]></category>
		<category><![CDATA[hdd]]></category>
		<category><![CDATA[mdraid]]></category>
		<category><![CDATA[migration]]></category>
		<category><![CDATA[raid]]></category>
		<category><![CDATA[swap]]></category>
		<category><![CDATA[ubuntu]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=271</guid>
		<description><![CDATA[Сегодня мы будем переносить mdraid разделы с одних физических дисков на другие. Причём делать это будем на горячую - то есть без остановки работающих приложений. Что мы имеем: Ubuntu Linux 9.10 4 физических диска: два старых по 250 Gb и два новых по 500 Gb. Все диски SATA. На старых дисках размечен совтовый Mdraid по следующей схеме: [...]]]></description>
			<content:encoded><![CDATA[<p>Сегодня мы будем переносить <strong>mdraid </strong>разделы с одних физических дисков на другие. Причём делать это будем на горячую - то есть без остановки работающих приложений.</p>
<h3>Что мы имеем:</h3>
<p>Ubuntu Linux 9.10<br />
4 физических диска: два старых по 250 Gb и два новых по 500 Gb. Все диски SATA.<br />
На старых дисках размечен совтовый Mdraid по следующей схеме:</p>
<ul>
<li>/dev/md0 level=raid1 &#8211; бут;</li>
<li>/dev/md1 level=raid0 &#8211; своп;</li>
<li>/dev/md2 level=raid1 &#8211; рут и данные.</li>
</ul>
<p>Отдельно стоит упомянуть SWAP раздел на нулевой рейде &#8211; плохая мысль) Во-первых на нормально функционирующей Linux системе своп использоваться не должен. Во-вторых при неполадках в дисковой системе север необратимо зависает. И того: выигрыш в производительности ни как не используется, за то мы изрядно теряем в стабильности. Сэкономленные в нашем случае 16Gb дискового пространства в рамках SATA дисков выглядят даже не смешно.</p>
<p>Кроме того из старых дисков один уже умер. Swap не работает.</p>
<p>Листинг /dev/sd*:<br />
<code class="console"># ls /dev/sd*<br />
/dev/sda  /dev/sda1  /dev/sda2  /dev/sda5  /dev/sda6  /dev/sdb  /dev/sdc</code><br />
Как видно из листинга один из старых дисков даже не определяется.</p>
<pre>
<code class="console"># cat /proc/mdstat

Personalities : [linear] [multipath] [raid0] [raid1] [raid6] [raid5] [raid4] [raid10]
md2 : active raid1 sda6[0]
238099264 blocks [2/1] [U_]
md1 : inactive sda5[0](S)
5855552 blocks
md0 : active raid1 sda1[0]
240832 blocks [2/1] [U_]
unused devices: &lt;none&gt;</code>
</pre>
<p>Задачи будет две:</p>
<ol>
<li>Перенести <em>md0</em> и <em>md2 </em>на новые диски</li>
<li>Пересоздать swap в виде зеркального RAID (raid1). К счастью сделать это будет не сложно. В Swap разделе не храниться важных данных. к тому-же в текущей конфигурации он просто отсутствует. А вот если бы пришлось пере собирать диск с данными- то данные пришлось бы временно перемещать. А сделать это на горячую без LVM вряд ли получиться.</li>
</ol>
<p>И так, поехали:<br />
1. Нужно создать разделы под рейд на новых дисках:</p>
<pre>
<code class="console">#fdisk /dev/sdb
Command (m for help): m
Command action
a   toggle a bootable flag
b   edit bsd disklabel
c   toggle the dos compatibility flag
d   delete a partition
l   list known partition types
m   print this menu
n   add a new partition
o   create a new empty DOS partition table
p   print the partition table
q   quit without saving changes
s   create a new empty Sun disklabel
t   change a partition's system id
u   change display/entry units
v   verify the partition table
w   write table to disk and exit
x   extra functionality (experts only)

Command (m for help): n
Command action
e   extended
p   primary partition (1-4)
1
Invalid partition number for type `1'
Command action
e   extended
p   primary partition (1-4)
1
Invalid partition number for type `1'
Command action
e   extended
p   primary partition (1-4)
p
Partition number (1-4): 1
First cylinder (1-60801, default 1): 1
Last cylinder, +cylinders or +size{K,M,G} (1-60801, default 60801): 30

Command (m for help): t
Selected partition 1
Hex code (type L to list codes): L

0  Empty           1e  Hidden W95 FAT1 80  Old Minix       bf  Solaris
1  FAT12           24  NEC DOS         81  Minix / old Lin c1  DRDOS/sec (FAT-
2  XENIX root      39  Plan 9          82  Linux swap / So c4  DRDOS/sec (FAT-
3  XENIX usr       3c  PartitionMagic  83  Linux           c6  DRDOS/sec (FAT-
4  FAT16 &amp;lt;32M      40  Venix 80286     84  OS/2 hidden C:  c7  Syrinx
5  Extended        41  PPC PReP Boot   85  Linux extended  da  Non-FS data
6  FAT16           42  SFS             86  NTFS volume set db  CP/M / CTOS / .
7  HPFS/NTFS       4d  QNX4.x          87  NTFS volume set de  Dell Utility
8  AIX             4e  QNX4.x 2nd part 88  Linux plaintext df  BootIt
9  AIX bootable    4f  QNX4.x 3rd part 8e  Linux LVM       e1  DOS access
a  OS/2 Boot Manag 50  OnTrack DM      93  Amoeba          e3  DOS R/O
b  W95 FAT32       51  OnTrack DM6 Aux 94  Amoeba BBT      e4  SpeedStor
c  W95 FAT32 (LBA) 52  CP/M            9f  BSD/OS          eb  BeOS fs
e  W95 FAT16 (LBA) 53  OnTrack DM6 Aux a0  IBM Thinkpad hi ee  GPT
f  W95 Ext'd (LBA) 54  OnTrackDM6      a5  FreeBSD         ef  EFI (FAT-12/16/
10  OPUS            55  EZ-Drive        a6  OpenBSD         f0  Linux/PA-RISC b
11  Hidden FAT12    56  Golden Bow      a7  NeXTSTEP        f1  SpeedStor
12  Compaq diagnost 5c  Priam Edisk     a8  Darwin UFS      f4  SpeedStor
14  Hidden FAT16 &amp;lt;3 61  SpeedStor       a9  NetBSD          f2  DOS secondary
16  Hidden FAT16    63  GNU HURD or Sys ab  Darwin boot     fb  VMware VMFS
17  Hidden HPFS/NTF 64  Novell Netware  b7  BSDI fs         fc  VMware VMKCORE
18  AST SmartSleep  65  Novell Netware  b8  BSDI swap       fd  Linux raid auto
1b  Hidden W95 FAT3 70  DiskSecure Mult bb  Boot Wizard hid fe  LANstep
1c  Hidden W95 FAT3 75  PC/IX           be  Solaris boot    ff  BBT
Hex code (type L to list codes): fd
Changed system type of partition 1 to fd (Linux raid autodetect)

Command (m for help): a
Partition number (1-4): 1

Command (m for help): w
The partition table has been altered!

Calling ioctl() to re-read partition table.
Syncing disks.</code>
</pre>
<p>Не забудем изменить тип диска с Linux на <strong>Linux raid autodetect</strong><br />
Команда: &laquo;t&raquo;, Hex код: &laquo;fd&raquo;.<br />
А также добавить бут флаг для загрузочного раздела (если такой имеется).</p>
<p>Ещё, в случае переноса разделов я рекомендую указывать размер диска в цилиндрах, а не в байтах. Так проще создать идентичный раздел. Посмотреть размер можно через<strong> &laquo;fdisk -l {путь диска}</strong>&laquo;.</p>
<p>Проделываем тоже самое со вторым диском <strong>/dev/sdc</strong></p>
<pre>
<code class="console">#fdisk /dev/sdс
.
.
.</code>
</pre>
<p>Разбиваем оставшееся дисковое пространство, чтобы оно было идентично старым дискам. В моем случае это немного не так. Я выделаю дополнительный раздел под своп. В остальном размеры логических дисков идентичны. вот что получилось:</p>
<pre>
<code class="console"># fdisk -l /dev/sdc

Disk /dev/sdc: 500.1 GB, 500107862016 bytes
255 heads, 63 sectors/track, 60801 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Disk identifier: 0x6f91c38c

Device Boot      Start         End      Blocks   Id  System
/dev/sdc1   *           1          30      240943+  fd  Linux raid autodetect
/dev/sdc2              31       60801   488143057+   5  Extended
/dev/sdc5              31        2120    16787893+  fd  Linux raid autodetect
/dev/sdc6            2121       31762   238099333+  fd  Linux raid autodetect
# ls /dev/sd*
/dev/sda  /dev/sda1  /dev/sda2  /dev/sda5  /dev/sda6  /dev/sdb  /dev/sdb1  /dev/sdb2  /dev/sdb5  /dev/sdb6  /dev/sdc  /dev/sdc1  /dev/sdc2  /dev/sdc5  /dev/sdc6</code>
</pre>
<p>PS у меня после записи изменение fdisk выдал ошибку о невозможности заменить таблицу разделов:</p>
<pre>
<code class="console">WARNING: Re-reading the partition table failed with error 16: Device or resource busy.
The kernel still uses the old table.
The new table will be used at the next reboot.</code>
</pre>
<p>Это произошло потому, что к этому моменту я уже добавил в рейд один из логических дисков.<br />
В этом случае нужно выполнить команду <strong>partprobe</strong>, и диски сразу появятся в системе.</p>
<p>Теперь нужно добавить эти разделы в md0.<br />
Но для начала не мешает взглянуть на состояние диска через <strong>mdadm  &#8211;detail /dev/md0</strong></p>
<pre>
<code class="console"># mdadm /dev/md0 --add /dev/sdb1
mdadm: added /dev/sdb1

# mdadm /dev/md0 --add /dev/sdc1
mdadm: added /dev/sdc1</code>
</pre>
<p>Изменим количество активных дисков для синхронизации, чтобы избавиться от spare дисков.</p>
<pre>
<code class="console">mdadm --grow -n 3 /dev/md0
mdadm --grow -n 3 /dev/md2</code>
</pre>
<p>Аналогично с остальными дисками.</p>
<p>Теперь нужно создать раздел под Swap. Я буду делать это через пересоздание <strong>md1</strong>.</p>
<p>Как видно из листинга своп у меня отсутствует.<br />
<code class="console"># swapon -s<br />
Filename </code></p>
<p>Убиваем неработающий диск<br />
<code class="console"># mdadm -S /dev/md1<br />
mdadm: stopped /dev/md1</code></p>
<p>Создаем на его месте новый<br />
<code class="console"># mdadm --create /dev/md1 --level=1 --raid-devices=2 /dev/sdb5 /dev/sdc5<br />
mdadm: array /dev/md1 started.</code></p>
<p>Создадим файловую систему на новом диске:<br />
<code class="console"># mkswap /dev/md1<br />
Setting up swapspace version 1, size = 16787772 KiB<br />
no label, UUID=33ca1464-316a-4d97-be87-7128758b86c1</code></p>
<p>Сразу активируем только что созданный SWAP.<br />
<code class="console"># swapon /dev/md1</code></p>
<p>И проверяем<br />
<code class="console"># swapon -s<br />
Filename                                Type            Size    Used    Priority<br />
/dev/md1                                partition       16787768        58464   -1</code></p>
<p>Редактируем <strong>/etc/fstab</strong><br />
Узнать UUID диска можно через команду <strong>blkid</strong>.<br />
<code class="console"># /etc/fstab: static file system information.<br />
#<br />
# Use 'vol_id --uuid' to print the universally unique identifier for a<br />
# device; this may be used with UUID= as a more robust way to name devices<br />
# that works even if disks are added and removed. See fstab(5).<br />
#<br />
#<br />
proc            /proc           proc    defaults        0       0<br />
# / was on /dev/md2 during installation<br />
UUID=3b3646e2-6865-4e0d-af35-65d938a55fb3 /               ext3    relatime,errors=remount-ro 0       1<br />
# /boot was on /dev/md0 during installation<br />
UUID=0bc279df-f2e3-4ad9-b409-ae396eb73f18 /boot           ext2    relatime        0       2<br />
# swap was on /dev/md1 during installation<br />
UUID=33ca1464-316a-4d97-be87-7128758b86c1 none            swap    sw              0       0<br />
/dev/scd0       /media/cdrom0   udf,iso9660 user,noauto,exec,utf8 0       0</code></p>
<p>В моём случае я пересоздал только раздел для SWAP, поэтому мне пришлось отредактировать только 1 UUID. Если перенос осуществляется без пересоздания разделов, то <strong>fstab</strong> править не нужно.</p>
<p>Затем берём информацию из <strong>mdadm &#8211;examine &#8211;scan</strong> и записываем в <strong>/etc/mdadm/mdadm.conf</strong> иначе новые md* диски подниматься не будут.</p>
<p>Устанавливаем GRUB на каждый новый диск:</p>
<pre>
<code class="console"># grub
grub&gt; root (hd1,0)
root (hd1,0)
grub&gt; setup (hd1)
setup (hd1)
Checking if "/boot/grub/stage1" exists... no
Checking if "/grub/stage1" exists... yes
Checking if "/grub/stage2" exists... yes
Checking if "/grub/e2fs_stage1_5" exists... yes
Running "embed /grub/e2fs_stage1_5 (hd1)"...  17 sectors are embedded.
succeeded
Running "install /grub/stage1 (hd1) (hd1)1+17 p (hd1,0)/grub/stage2 /grub/menu.lst"... succeeded
Done.

grub&gt; root (hd2,0)
root (hd2,0)
grub&gt; setup (hd2)
setup (hd2)
Checking if "/boot/grub/stage1" exists... no
Checking if "/grub/stage1" exists... yes
Checking if "/grub/stage2" exists... yes
Checking if "/grub/e2fs_stage1_5" exists... yes
Running "embed /grub/e2fs_stage1_5 (hd2)"...  17 sectors are embedded.
succeeded
Running "install /grub/stage1 (hd2) (hd2)1+17 p (hd2,0)/grub/stage2 /grub/menu.lst"... succeeded
Done.</code>
</pre>
<p>Осталось перезагрузить, проверить как это всё работает, а также отключить старые диски.</p>
<h3> Хорошие ссылки на тему</h3>
<ul>
<li><a href="http://ru.wikipedia.org/wiki/Mdadm">Mdadm в wikipedia</a>;</li>
<li><a href="http://www.xgu.ru/wiki/raid">Программный RAID в Linux</a>;</li>
<li><a href="http://blog.sozinov.eu/2007/05/software-raid-1.html">Инструкция по восстановлению Software RAID 1</a>;</li>
<li><a href="http://www.howtoforge.com/software-raid1-grub-boot-debian-etch">How To Set Up Software RAID1 On A Running System (Incl. GRUB Configuration) (Debian Etch)</a>.</li>
</ul>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/mdraid-migration.xhtml/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Как переименовать сетевые интерфейсы в Linux (eth0 в eth1, eth1 в trr_lala т.д.)</title>
		<link>http://www.filosof.name/articles/rename-linux-network-interfaces.xhtml</link>
		<comments>http://www.filosof.name/articles/rename-linux-network-interfaces.xhtml#comments</comments>
		<pubDate>Fri, 19 Mar 2010 10:23:52 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[/dev]]></category>
		<category><![CDATA[/dev/eth0]]></category>
		<category><![CDATA[/sys/class/net]]></category>
		<category><![CDATA[debian]]></category>
		<category><![CDATA[eth0]]></category>
		<category><![CDATA[eth1]]></category>
		<category><![CDATA[gentoo]]></category>
		<category><![CDATA[suse]]></category>
		<category><![CDATA[ubuntu]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=223</guid>
		<description><![CDATA[В Ubuntu, а значит и в Debian (а на самом деле много где ещё, например в Gentoo) файла /dev/eth0 нету. Потому как сетевая карта устройство не символьное, но и не блочное. Сетевые устройства хранятся вот здесь: /sys/class/net Имена сетевых интерфейсов в Linux компьютерах в последнее время стали привязываться к конкретным устройствам.  Так, если вы вытащите [...]]]></description>
			<content:encoded><![CDATA[<p>В Ubuntu, а значит и в Debian (а на самом деле много где ещё, например в Gentoo) файла <em>/dev/eth0</em> нету. Потому как сетевая карта устройство не символьное, но и не блочное. Сетевые устройства хранятся вот здесь: <em>/sys/class/net</em></p>
<p>Имена сетевых интерфейсов в Linux компьютерах в последнее время стали привязываться к конкретным устройствам.  Так, если вы вытащите сетевую карту из своего компьютера и вставите в него другую, интерфейс <em>eth0 </em>у вас пропадёт, а новая карточка будет называется <em>eth1</em>. При попытке сделать <em>ifconfig eth0 up </em>система будет говорить, что, такого устройства не существует.</p>
<p>В моём случае проблема получилась при клонирования виртуальной машины в VMWare ESXi. Дабы не случилось конфликта MAC адрес на клонированной машине отливался от MAC адреса в оригинальной VM.</p>
<p>Поскольку вся конфигурация у вас скорее всего прописана для интерфейса  eth0, можно переписать конфигурацию. а можно переименовать интерфейс.</p>
<p>Все неприятности создаёт udev, который по умолчанию привязывает имена сетевых  устройств к их MAC адресам. Например, в Debian Etch это находится в  файле</p>
<p><em>/etc/udev/rules.d/z25_persistent-net.rules</em></p>
<p>Для Ubuntu:</p>
<p><em><em>/etc/udev/rules.d/</em>70-persistent-net.rules</em></p>
<p>Для open suse:</p>
<p><em><em><em>/etc/udev/rules.d/</em></em>30-network.rules</em></p>
<p>пример файла:<br />
SUBSYSTEM==&raquo;net&raquo;, ACTION==&raquo;add&raquo;, DRIVERS==&raquo;?*&raquo;,  ATTR{address}==&raquo;XX:XX:XX:XX:XX:XX&raquo;, ATTR{type}==&raquo;1&#8243;, KERNEL==&raquo;eth*&raquo;,  NAME=&raquo;eth0&#8243;</p>
<p>Достаточно отредактировать параметр <strong>NAME=</strong> для вашей новой сетевой карты. Можно кстати задать любое имя отличное от <em>eth*</em></p>
<p>Некоторые дистрибы в добавок к <em>persistent-net.rules</em> содержат и другие .<em>rules</em>, которые переписывают файл <em>persistent-net.</em> При исправлении файла persistent.rules стоит обратить на это внимание, иначе могут появиться несколько правил именования, или ваши изменения будут перезаписаны.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/rename-linux-network-interfaces.xhtml/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Как правильно делать Migration на Parallels Virtuozzo Containers 4.0 под Linux</title>
		<link>http://www.filosof.name/articles/migration-on-virtuozzo-containers-4-0-for-linux.xhtml</link>
		<comments>http://www.filosof.name/articles/migration-on-virtuozzo-containers-4-0-for-linux.xhtml#comments</comments>
		<pubDate>Thu, 28 Jan 2010 12:11:19 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Виртуализация]]></category>
		<category><![CDATA[clone]]></category>
		<category><![CDATA[EZ Templates]]></category>
		<category><![CDATA[migration]]></category>
		<category><![CDATA[Parallels Virtuozzo Containers]]></category>
		<category><![CDATA[virtuozzo]]></category>
		<category><![CDATA[vz]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=232</guid>
		<description><![CDATA[Обоснованно на личном опыте. Первое правило хорошего админа &#8211; делаем Backup. Рекомендую. Обновить virtuozzo на обеих серверах. Обязательно! Обновить Контейнер и Template для него. Чтобы не было мучительно больно делаем Clone для Контейнера (необходимо свободное место на диске исходного сервера). Делаем Migration для клона и проверяем всё ли нормально заработало. И только потом делаем Migration [...]]]></description>
			<content:encoded><![CDATA[<p><em>Обоснованно на личном опыте.</em></p>
<ol>
<li> Первое правило хорошего админа &#8211; делаем <strong>Backup</strong>.</li>
<li>Рекомендую. Обновить <strong>virtuozzo </strong>на обеих серверах.</li>
<li>Обязательно! Обновить Контейнер и <strong>Template </strong>для него.</li>
<li>Чтобы не было мучительно больно делаем <strong>Clone</strong> для Контейнера (необходимо свободное место на диске исходного сервера).</li>
<li> Делаем Migration для клона и проверяем всё ли нормально заработало.</li>
<li>И только потом делаем <strong>Migration </strong>для самого контейнера.</li>
</ol>
<p>Так бывает, что некоторые системные файл в контейнере становятся недоступными. Нету этих файлов и в бакапах. Зато есть в <strong>Template</strong>.</p>
<p>Новый формат шаблонов под <strong>Linux </strong>который появился в четвёртой версии Виртуозы: <strong>EZ Templates</strong> (<a href="http://download.swsoft.com/virtuozzo/virtuozzo4.0/docs/lin/VzLinuxTmplMgmt/index.htm">Дока</a>) подразумевает, что common пакеты будут представлены во всех производных контейнерах в виде ссылки на файлы из Шаблона.</p>
<p>Файлы эти хранятся в виде кеша в папке <span class="code">/vz/template/cache/</span></p>
<p>Только вот <strong>Migration</strong> необходимые файлы из Шаблона не переместит. Как пишут в форуме на <a href="http://forum.parallels.com/" target="_blank">http://forum.parallels.com/</a> это какой-то неведомый баг в самом <strong>Migration</strong> который тянется ещё из бох знает какой версии и так быть не должно. Но оно так.</p>
<p>Как результат наша перемещённая WM наполнена битыми ссылками и кучей нерабочих сервисов. Не помогает ни обновление самого контейнера, ни обновление Шаблонов. Не получилось у меня починить такую VM и другими способами. Дело в том, что такие &laquo;волшебные файлы&raquo; удалить не получиться.</p>
<p>Немного из результата выполнения команды <strong>ls -la /etc/apache2/mods-available/</strong><br />
<code>.<br />
.<br />
ls: cannot access /etc/apache2/mods-available/negotiation.load: No such file or directory<br />
ls: cannot access /etc/apache2/mods-available/dir.load: No such file or director<br />
total 32<br />
drwxr-xr-x 2 root root 4096 2009-11-14 13:56 .<br />
drwxr-xr-x 7 root root 1404 2010-01-28 14:13 ..<br />
.<br />
.<br />
?????????? ? ?    ?       ?                ? deflate.conf<br />
?????????? ? ?    ?       ?                ? deflate.load<br />
-rw-r--r-- 1 root root  122 2008-10-01 18:32 dir.conf<br />
?????????? ? ?    ?       ?                ? dir.load<br />
-rw-r--r-- 1 root root  604 2008-10-01 18:32 disk_cache.conf</code></p>
<h2>Решение проблемы с рассинхронизации шаблонов</h2>
<p>Перед перемещением контейнера (можно и после но время простоя увеличиться) надо синхронизировать Шаблоны контейнеров.<br />
На стороне виртуозы с которой переносим контейнер, выполняем:</p>
<p><code># rsync -avz -e ssh /vz/template/debian DESTANETION_IP:/vz/template</code></p>
<ul>
<li><em>пути заменить на свои</em></li>
<li><em>DESTANETION_IP &#8211; заменить на адрес второго сервера</em></li>
</ul>
<p>На второй виртуозе выполняем:<br />
<code># vzpkg update cache debian-4.0-x86_64</code><br />
<em>debian-4.0-x86_64 заменить на имя вашего шаблона.</em></p>
<p>Сначала проверяем на клоне.<br />
Потом перемещаем боевой сервер.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/migration-on-virtuozzo-containers-4-0-for-linux.xhtml/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>&#8230;и другиее проблемы с Qmail в Plesk</title>
		<link>http://www.filosof.name/articles/%d0%b8-%d0%b4%d1%80%d1%83%d0%b3%d0%b8%d0%b5%d0%b5-%d0%bf%d1%80%d0%be%d0%b1%d0%bb%d0%b5%d0%bc%d1%8b-%d1%81-qmail-%d0%b2-plesk.xhtml</link>
		<comments>http://www.filosof.name/articles/%d0%b8-%d0%b4%d1%80%d1%83%d0%b3%d0%b8%d0%b5%d0%b5-%d0%bf%d1%80%d0%be%d0%b1%d0%bb%d0%b5%d0%bc%d1%8b-%d1%81-qmail-%d0%b2-plesk.xhtml#comments</comments>
		<pubDate>Tue, 22 Sep 2009 15:48:35 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[hosting]]></category>
		<category><![CDATA[mail]]></category>
		<category><![CDATA[mx]]></category>
		<category><![CDATA[parallels]]></category>
		<category><![CDATA[plesk]]></category>
		<category><![CDATA[qmail]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=171</guid>
		<description><![CDATA[Sorry. Although I'm listed as a best-preference MX or A for that host, it isn't in my control/locals file, so I don't treat it as local. (#5.4.6) На самом деле в моём случае произошло отключение домена за неуплату. Потребовалось просто реактивировать домен через панельку. Но причин может быть множество. Очень хорошая статья с обзором всех [...]]]></description>
			<content:encoded><![CDATA[<p><code style="color: red;">Sorry. Although I'm listed as a best-preference MX or A for that host,<br />
it isn't in my control/locals file, so I don't treat it as local. (#5.4.6)</code></p>
<p>На самом деле в моём случае произошло отключение домена за неуплату. Потребовалось просто реактивировать домен через панельку. Но причин может быть множество. Очень хорошая статья с обзором всех возможных вариантов в виде KB для плеска (правжа на английском):</p>
<p><a href="http://kb.parallels.com/en/1372">I&#8217;m sending mail but I receive a bounce message with an error.</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/%d0%b8-%d0%b4%d1%80%d1%83%d0%b3%d0%b8%d0%b5%d0%b5-%d0%bf%d1%80%d0%be%d0%b1%d0%bb%d0%b5%d0%bc%d1%8b-%d1%81-qmail-%d0%b2-plesk.xhtml/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Проблема множества одновременных соединений (С10K Problem)</title>
		<link>http://www.filosof.name/articles/c10k-unix-socket.xhtml</link>
		<comments>http://www.filosof.name/articles/c10k-unix-socket.xhtml#comments</comments>
		<pubDate>Tue, 08 Sep 2009 06:58:51 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[c10k]]></category>
		<category><![CDATA[limits.conf]]></category>
		<category><![CDATA[tcp]]></category>
		<category><![CDATA[unix soket]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=92</guid>
		<description><![CDATA[Linux 2.6 Как известно, по умолчанию tcp/ip в Linux 2.6 настроен на довольно высокую пропускную нагрузку. Если предельное количество соединений для службы устанавливаться в раёне одной тысячи, а ресурсов системы более чем предостаточно поискать причину можно вот в какой месте: Рассмотрим конкретный пример. Служба состоит из двух частей front-end и back-end Front часть устанавливает соединение [...]]]></description>
			<content:encoded><![CDATA[<h2>Linux 2.6</h2>
<p>Как известно, по умолчанию tcp/ip в Linux 2.6 настроен на довольно высокую пропускную нагрузку.<br />
Если предельное количество соединений для службы устанавливаться в раёне одной тысячи, а ресурсов системы более чем предостаточно поискать причину можно вот в какой месте:</p>
<h2>Рассмотрим  конкретный пример.</h2>
<p>Служба состоит из двух частей <strong>front-end</strong> и <strong>back-end</strong><br />
<strong>Front </strong>часть устанавливает соединение в любом случае, но после приблизительно 1000 активных подключений соединения эти не доходят до <strong>back </strong>части.<br />
Дело всё в том, что по tcp обещаться только <strong>front-end</strong>, а связка <strong>front-back</strong> работала на UNIX сокетах. Причём каждое подключение порождает открытие дополнительного UNIX сокета.<br />
Кто знаком с UNIX сокетами знает, что каждый такой сокет требует создание отдельного дискриптора файла. А в linux есть явное ограничение открытых файлов для процесса. По умолчанию это 1024.</p>
<p>Проверить можно так:</p>
<div class="code">
<p># количество открытых Unix сокетов для демона back<br />
$  netstat -ux -p|grep back|wc -l</p>
<p># количество открытых Unix сокетов в системе<br />
$  netstat -ux -p|wc -l</p>
<p># количество открытых tpc сокетов для демона front<br />
$  netstat -tnp|grep front|wc -l</p>
<p># количество открытых tpc сокетов в системе<br />
$  netstat -tnp|wc -l</p></div>
<p>Везде нужны права root<br />
Снять ограничение можно здесь:</p>
<h2>/etc/security/limits.conf</h2>
<pre><code>demonusername            soft    nofile   2048
demonusername            hard    nofile   2048</code></pre>
<ul>
<li><strong>demonusername </strong>- имя пользователя с правами которого запускаться демон, использующий Unix сокеты. Можно устанавливать огриначение для группы (<strong>@demonusername</strong>) или для всех (<strong>*</strong>)</li>
<li>Параметры <strong>soft </strong>и <strong>hard </strong>используються для установки мягкого и жесткого лимита соответственно. <strong>soft </strong>может быть изменен в самой программе. <strong>hard</strong> может быть изменен только суперпользователем.<br />
<span style="color: #ff0000;">ВНИМАНИЕ!</span> Необходима установка и <strong>soft </strong>и <strong>hard </strong>ограничения.</li>
<li><strong>2048</strong> &#8211; собственно ограничение.<br />
<blockquote><p>Не изменяйте лимит для всей системы и не выставляйте слишком большого числа. Все эти лимиты введены не просто так. В случае взлома, атаки или просто сбоя это может привести к негативным результатам &#8211; например потере контроля за машиной.</p></blockquote>
</li>
</ul>
<p>Далее необходим ребут, чтобы преинициализировать ядро.</p>
<p>Ссылки на полезные статьи:<br />
<a href="http://www.kegel.com/c10k.html">http://www.kegel.com/c10k.html</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/c10k-unix-socket.xhtml/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Virtuozzo не обновляет ключи</title>
		<link>http://www.filosof.name/articles/virtuozzo-licensing-proble.xhtml</link>
		<comments>http://www.filosof.name/articles/virtuozzo-licensing-proble.xhtml#comments</comments>
		<pubDate>Tue, 01 Sep 2009 13:51:38 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[DNS]]></category>
		<category><![CDATA[virtuozzo]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=64</guid>
		<description><![CDATA[Началось всё с того, что однажды перестала обновляться лицензия програмного продукта: Parallels Virtuozzo Containers 4.0 При попытке переустановить лицензию выскочила следующая ошибка: KA server is not available: activatefailed: Can't connect to server ka.swsoft.com:5224 Проблема скажем с обновлениями может иметь аналогичную причину. В этом случае правильнее всего было проверить настройки DNS на хост машине. # nslookup [...]]]></description>
			<content:encoded><![CDATA[<p>Началось всё с того, что однажды перестала обновляться лицензия програмного продукта: <strong>Parallels Virtuozzo Containers 4.0</strong></p>
<p>При попытке переустановить лицензию выскочила следующая ошибка:<br />
<code><span style="color: #ff0000;">KA server is not available: activatefailed: Can't connect to server ka.swsoft.com:5224</span></code></p>
<p>Проблема скажем с обновлениями может иметь аналогичную причину.</p>
<p>В этом случае правильнее всего было проверить настройки DNS на хост машине.</p>
<div class="console"># nslookup ka.swsoft.com</p>
<pre>Server:         81.200.0.1</pre>
<pre>Address:        81.200.0.1#53</pre>
<pre> </pre>
<pre>Non-authoritative answer:</pre>
<pre>*** Can't find ka.swsoft.com: No answer</pre>
</div>
<p>Получаем новые DNS у провайдера (в моём случае они просто работали с ошибками &#8211; пришлось искать другие).</p>
<p>Обновляем <strong>/etc/resolv.conf</strong>.<br />
Перезагружается потому, что демон лицензий висит в отдельном контейнере и изменения настроек не заметит.<br />
Всё работает.</p>
<blockquote><p>Information:The license has been installed successfully.</p></blockquote>
<p>По теме:<br />
<a href="http://www.parallels.com/products/virtuozzo/">http://www.parallels.com/products/virtuozzo/</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/virtuozzo-licensing-proble.xhtml/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>FakeRAID, ещё одна байка с плохим концом</title>
		<link>http://www.filosof.name/articles/fakeraid-bad-story.xhtml</link>
		<comments>http://www.filosof.name/articles/fakeraid-bad-story.xhtml#comments</comments>
		<pubDate>Mon, 24 Aug 2009 18:51:33 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[dmraid]]></category>
		<category><![CDATA[raid]]></category>
		<category><![CDATA[suse]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=48</guid>
		<description><![CDATA[Конфигурация. Сервер: Серверы HP ProLiant Контролер: Встроенный ICH9 Дисковая подсистема: 2 SATA диска в 250 Gb (RAID 1 mirror) Операционная система: SUSE Фактическая реализация raid на уровне ОС: DMraid Хронология событий Умирает второй диск. SUSE начинает ругаться многочисленными ошибками в MFT и требует запустить fsck Aug 23 06:12:27 xxx kernel: EXT3-fs error (device sda1): ext3_lookup: [...]]]></description>
			<content:encoded><![CDATA[<h2>Конфигурация.</h2>
<p>Сервер: <strong>Серверы HP ProLiant</strong><br />
Контролер: <strong>Встроенный ICH9</strong><br />
Дисковая подсистема:<strong> 2 SATA диска в 250 Gb (RAID 1 mirror)</strong><br />
Операционная система: <strong>SUSE</strong><br />
Фактическая реализация raid на уровне ОС: <strong>DMraid</strong></p>
<h2>Хронология событий</h2>
<p>Умирает второй диск.<br />
SUSE начинает ругаться многочисленными ошибками в <strong>MFT </strong>и требует запустить fsck</p>
<p><code>Aug 23 06:12:27 xxx kernel: EXT3-fs error (device sda1): ext3_lookup: unlinked inode 2465708 in dir #2301537<br />
Aug 23 06:12:27 xxx kernel: EXT3-fs error (device sda1): ext3_lookup: unlinked inode 2465707 in dir #2301550<br />
Aug 23 06:12:28 xxx kernel: EXT3-fs error (device sda1): ext3_lookup: unlinked inode 2465723 in dir #2301550<br />
Aug 23 06:12:28 xxx kernel: EXT3-fs error (device sda1): ext3_lookup: unlinked inode 2465819 in dir #2301555<br />
Aug 23 06:12:28 xxx kernel: EXT3-fs error (device sda1): ext3_lookup: unlinked inode 2466064 in dir #2465286</code></p>
<p>По глупости запускаеться <strong>fsck</strong>.<br />
на выходе получаем множество жизненоважных файлов с нулевым размером.<br />
(Напомню файлы с нулевым размером восстанавливать кране тяжко и совсем не быстро)</p>
<p>Результат:<br />
1) Критически важное приложение<br />
2) 1 мёртвый диск<br />
3) второй диск с неработающей системой и битыми данными</p>
<p>Хорошё если есть рабочие бакапы.<br />
Купить новый диск, востановились архив &#8211; два часа простоя.<br />
Вот такая вот история.</p>
<h2>Как нужно было делать с самог начала</h2>
<p>Будет такая штука <a href="http://www.adaptec.com/en-US/products/Controllers/Hardware/sas/entry/SAS-2405/">Adaptec RAID 2405</a><br />
И 3 диска: Два в зеркало и однин в <strong>Hot spare</strong>, чтобы не пришлось бегать в магазин)</p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/fakeraid-bad-story.xhtml/feed</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Software RAID под Ubuntu 9.04</title>
		<link>http://www.filosof.name/articles/software-raid-ubuntu-904.xhtml</link>
		<comments>http://www.filosof.name/articles/software-raid-ubuntu-904.xhtml#comments</comments>
		<pubDate>Sat, 30 May 2009 16:19:07 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[dmraid]]></category>
		<category><![CDATA[grub]]></category>
		<category><![CDATA[mdadm]]></category>
		<category><![CDATA[ubuntu]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=24</guid>
		<description><![CDATA[Не так давно появилась новая версия не безызвестного дистрибутива Ubuntu 9.04, а с ним и новые проблемы. Топик касается установки linux на все виды софтового рейда(DM-RAID/fakeRAID) и последующей загрузки с этих разделов. Проблема точно существует для RAID, построенных на dmraid и mdadm. Суть проблемы: После установки, во время загрузки выскакивает сообщение приблизительного такого содержания: no [...]]]></description>
			<content:encoded><![CDATA[<p>Не так давно появилась новая версия не безызвестного дистрибутива <strong>Ubuntu 9.04</strong>, а с ним и новые проблемы.</p>
<p>Топик касается установки linux на все виды софтового рейда(DM-RAID/fakeRAID) и последующей загрузки с этих разделов.<br />
Проблема точно существует для RAID, построенных на <strong>dmraid</strong> и <strong>mdadm</strong>.<br />
<span id="more-24"></span></p>
<h3>Суть проблемы:</h3>
<p>После установки, во время загрузки выскакивает сообщение приблизительного такого содержания:<br />
<code>no block devices found<br />
no block devices found<br />
ERROR: either the required RAID set was not found or more options required<br />
no raid sets and with names: "no block devices found"<br />
Gave up waiting for root device. Common problems:<br />
- Boot args (cat /proc/cmdline)<br />
- Check rootdelay= (did the system wait long enough?)<br />
- Check root= (did the system wait for the right device?)<br />
- Missing modules (cat /proc/modules; ls /dev)<br />
ALERT! /dev/mapper/ddf1_ISISTIGER does not exist. Dropping to a shell!</code><br />
И выбрасывает в консоль. Затем достаточно набрать <strong>exit</strong>, чтобы продолжить загрузку.</p>
<p>Аналогично и для <strong>mdadm</strong></p>
<h3>Почему так получаеться:</h3>
<p>RAID диск с root каталогом не успевает инициализироваться за отпущенное время.</p>
<h3>Как починить:</h3>
<p>Надо добавить параметр <strong>rootdelay</strong> к строке инициализации ядра.<br />
Этот параметр заставить загрузчик подождать пока рейд инициализируется.</p>
<h4>Для этого:</h4>
<ol>
<li>октрываем файл &laquo;/boot/grub/menu.lst&raquo;;</li>
<li>находим раздел инициализирующий нашу загрузку:<br />
<code>title           Ubuntu 9.04, kernel 2.6.28-11-generic<br />
root            (hd0,0)<br />
kernel          /vmlinuz-2.6.28-11-generic root=/dev/md3 ro splash<br />
initrd          /initrd.img-2.6.28-11-generic</code></li>
<li>Добавляем в конец rootdelay (в моём случае 40 секунд было вполне достаточно)<br />
<code>title           Ubuntu 9.04, kernel 2.6.28-11-generic<br />
root            (hd0,0)<br />
kernel          /vmlinuz-2.6.28-11-generic root=/dev/md3 ro splash rootdelay=40<br />
initrd          /initrd.img-2.6.28-11-generic</code></li>
<li>Сохраняемся, перезапускаеся.</li>
</ol>
<h3>Литература:</h3>
<p>Ubuntu Fake Raid Howto: <a title="Ubuntu Fake Raid Howto" href="https://help.ubuntu.com/community/FakeRaidHowto" target="_blank">https://help.ubuntu.com/community/FakeRaidHowto</a><br />
Обсуждение лекарства: <a title="http://ubuntuforums.org/archive/index.php/t-985348.html" href="http://ubuntuforums.org/archive/index.php/t-985348.html">http://ubuntuforums.org/archive/index.php/t-985348.html</a><br />
Описание траблы: <a title="http://ubuntuforums.org/archive/index.php/t-985348.html" href="http://ubuntuforums.org/archive/index.php/t-985348.html">https://answers.launchpad.net/ubuntu/+source/ubiquity/+question/71192</a></p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/software-raid-ubuntu-904.xhtml/feed</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Подсчёт колличества вложенных папок и файлов для Linux</title>
		<link>http://www.filosof.name/articles/nodes-v01.xhtml</link>
		<comments>http://www.filosof.name/articles/nodes-v01.xhtml#comments</comments>
		<pubDate>Wed, 25 Mar 2009 13:50:47 +0000</pubDate>
		<dc:creator>Aleksey Parshukov</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[nodes]]></category>

		<guid isPermaLink="false">http://www.filosof.name/?p=21</guid>
		<description><![CDATA[Написал маленький скрипт для bash который считает колличество вложенных папок и файлов, иначе говоря nodes файловой файловой системы nodes.sh #!/bin/bash for dir in `find $1 -maxdepth 1 -type d`; do printf "%-8s%s\n" $[ `find $dir \! -name "." &#124; wc -l` - 1 ] $dir; done]]></description>
			<content:encoded><![CDATA[<p>Написал маленький скрипт для bash который считает колличество вложенных папок и файлов, иначе говоря nodes файловой файловой системы</p>
<p><strong>nodes.sh</strong><br />
<code>#!/bin/bash<br />
for dir in `find $1 -maxdepth 1 -type d`;<br />
do<br />
printf "%-8s%s\n" $[ `find $dir \! -name "." | wc -l` - 1 ] $dir;<br />
done</code></p>
]]></content:encoded>
			<wfw:commentRss>http://www.filosof.name/articles/nodes-v01.xhtml/feed</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
	</channel>
</rss>

