<?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>Техно-логи &#187; drupal</title>
	<atom:link href="http://www.kurdyukov.com/tag/drupal/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.kurdyukov.com</link>
	<description>Заметки о разработке и прочей жизни</description>
	<lastBuildDate>Sat, 04 Feb 2012 01:34:55 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=</generator>
		<item>
		<title>Перенос Drupal</title>
		<link>http://www.kurdyukov.com/2009/04/16/drupal-migration/</link>
		<comments>http://www.kurdyukov.com/2009/04/16/drupal-migration/#comments</comments>
		<pubDate>Thu, 16 Apr 2009 15:36:32 +0000</pubDate>
		<dc:creator>alik</dc:creator>
				<category><![CDATA[Development]]></category>
		<category><![CDATA[drupal]]></category>
		<category><![CDATA[postgresql]]></category>

		<guid isPermaLink="false">http://www.kurdyukov.com/?p=43</guid>
		<description><![CDATA[Так получилось, что я в некоторый момент начал хостить на своем сервере веб-сайт своих друзей. Друзья &#8211; люди совершенно некомпьютерные, а сайт поддерживать хотят. Поэтому на сайт был установлен CMS Drupal. В качестве БД был выбран PostgreSQL, поскольку он мне просто больше нравится. И все было бы хорошо, если бы не пришла пора менять хостинг. [...]]]></description>
			<content:encoded><![CDATA[<p>Так получилось, что я в некоторый момент начал хостить на своем сервере веб-сайт своих друзей. Друзья &#8211; люди совершенно некомпьютерные, а сайт поддерживать хотят. Поэтому на сайт был установлен CMS Drupal. В качестве БД был выбран PostgreSQL, поскольку он мне просто больше нравится. И все было бы хорошо, если бы не пришла пора менять хостинг.<br />
<span id="more-43"></span><br />
В начале выяснилось, что на новом хостинге пользователь не может создавать объекты внутри схемы &laquo;public&raquo;.</p>
<p>Про схемы надо рассказать отдельно. Когда-то давно PostgreSQL старался походить на Oracle во многих отношениях, в том числе в структуре объектов БД. Так в PostgreSQL появились схемы (schema). Для PostgreSQL схема &#8211; это именованный контейнер для объектов базы (таблицы, индексы, сиквенсы и т.п.). Для определения порядка использования схем в базе существует текстовый параметр search_path. По умолчанию сначала в качестве схемы используется имя пользователя, потом константа public.</p>
<p>К сожалению, на хостинге имя логина к БД содержало символ &laquo;-&raquo;, который запрещен в идентификаторах объектов БД. Пришлось создать схему с другим названием и переместить все объекты туда. В процессе переноса выяснилось, что команда ALTER SOMETHING name SET SCHEMA &#8216;something&#8217; поддерживается только с версии 8.3 базы. Хорошо хоть так, иначе бы пришлось какие-то скрипты нетривиальные писать. Перенеслось, с горем пополам.</p>
<p>Далее выяснилось, что drupal по умолчанию не дружит со схемами в PostgreSQL. По мотивам интернета был написан патч, который позволяет drupal 6.9  задружиться с PostreSQL. Вот патч:</p>

<div class="wp_codebox_msgheader"><span class="right"><sup><a href="http://www.ericbess.com/ericblog/2008/03/03/wp-codebox/#examples" target="_blank" title="WP-CodeBox HowTo?"><span style="color: #99cc00">?</span></a></sup></span><span class="left2">Download <a href="http://www.kurdyukov.com/wp-content/plugins/wp-codebox/wp-codebox.php?p=43&amp;download=pgsql.patch">pgsql.patch</a></span><div class="codebox_clear"></div></div><div class="wp_codebox"><table><tr id="p432"><td class="code" id="p43code2"><pre class="php" style="font-family:monospace;"><span style="color: #339933;">***</span> database<span style="color: #339933;">.</span>pgsql<span style="color: #339933;">.</span>inc<span style="color: #339933;">.</span>orig     Thu Apr  <span style="color: #cc66cc;">9</span> <span style="color: #208080;">04</span><span style="color: #339933;">:</span><span style="color: #cc66cc;">25</span><span style="color: #339933;">:</span><span style="color: #cc66cc;">13</span> <span style="color: #cc66cc;">2009</span>
<span style="color: #339933;">---</span> database<span style="color: #339933;">.</span>pgsql<span style="color: #339933;">.</span>inc  Thu Apr  <span style="color: #cc66cc;">9</span> <span style="color: #208080;">06</span><span style="color: #339933;">:</span><span style="color: #cc66cc;">48</span><span style="color: #339933;">:</span><span style="color: #cc66cc;">22</span> <span style="color: #cc66cc;">2009</span>
<span style="color: #339933;">***************</span>
<span style="color: #339933;">***</span> <span style="color: #cc66cc;">51</span><span style="color: #339933;">,</span><span style="color: #cc66cc;">56</span> <span style="color: #339933;">****</span>
<span style="color: #339933;">---</span> <span style="color: #cc66cc;">51</span><span style="color: #339933;">,</span><span style="color: #cc66cc;">57</span> <span style="color: #339933;">----</span>
    <span style="color: #009900;">&#125;</span>
&nbsp;
    <span style="color: #000088;">$url</span> <span style="color: #339933;">=</span> <a href="http://www.php.net/parse_url"><span style="color: #990000;">parse_url</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #339933;">+</span>   <span style="color: #000088;">$db_and_schema</span> <span style="color: #339933;">=</span> <a href="http://www.php.net/explode"><span style="color: #990000;">explode</span></a><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;.&quot;</span><span style="color: #339933;">,</span> <span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'path'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #000088;">$conn_string</span> <span style="color: #339933;">=</span> <span style="color: #0000ff;">''</span><span style="color: #339933;">;</span>
&nbsp;
    <span style="color: #666666; font-style: italic;">// Decode url-encoded information in the db connection string</span>
<span style="color: #339933;">***************</span>
<span style="color: #339933;">***</span> <span style="color: #cc66cc;">63</span><span style="color: #339933;">,</span><span style="color: #cc66cc;">70</span> <span style="color: #339933;">****</span>
    <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/isset"><span style="color: #990000;">isset</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'host'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
      <span style="color: #000088;">$conn_string</span> <span style="color: #339933;">.=</span> <span style="color: #0000ff;">' host='</span><span style="color: #339933;">.</span> <a href="http://www.php.net/urldecode"><span style="color: #990000;">urldecode</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'host'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #339933;">!</span>   <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/isset"><span style="color: #990000;">isset</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'path'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #339933;">!</span>     <span style="color: #000088;">$conn_string</span> <span style="color: #339933;">.=</span> <span style="color: #0000ff;">' dbname='</span><span style="color: #339933;">.</span> <a href="http://www.php.net/substr"><span style="color: #990000;">substr</span></a><span style="color: #009900;">&#40;</span><a href="http://www.php.net/urldecode"><span style="color: #990000;">urldecode</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'path'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #cc66cc;">1</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
    <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/isset"><span style="color: #990000;">isset</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'port'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
      <span style="color: #000088;">$conn_string</span> <span style="color: #339933;">.=</span> <span style="color: #0000ff;">' port='</span><span style="color: #339933;">.</span> <a href="http://www.php.net/urldecode"><span style="color: #990000;">urldecode</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'port'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #339933;">---</span> <span style="color: #cc66cc;">64</span><span style="color: #339933;">,</span><span style="color: #cc66cc;">71</span> <span style="color: #339933;">----</span>
    <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/isset"><span style="color: #990000;">isset</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'host'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
      <span style="color: #000088;">$conn_string</span> <span style="color: #339933;">.=</span> <span style="color: #0000ff;">' host='</span><span style="color: #339933;">.</span> <a href="http://www.php.net/urldecode"><span style="color: #990000;">urldecode</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'host'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
<span style="color: #339933;">!</span>   <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/isset"><span style="color: #990000;">isset</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$db_and_schema</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'0'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
<span style="color: #339933;">!</span>     <span style="color: #000088;">$conn_string</span> <span style="color: #339933;">.=</span> <span style="color: #0000ff;">' dbname='</span><span style="color: #339933;">.</span> <a href="http://www.php.net/substr"><span style="color: #990000;">substr</span></a><span style="color: #009900;">&#40;</span><a href="http://www.php.net/urldecode"><span style="color: #990000;">urldecode</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$db_and_schema</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'0'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">,</span> <span style="color: #cc66cc;">1</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #009900;">&#125;</span>
    <span style="color: #b1b100;">if</span> <span style="color: #009900;">&#40;</span><a href="http://www.php.net/isset"><span style="color: #990000;">isset</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'port'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <span style="color: #009900;">&#123;</span>
      <span style="color: #000088;">$conn_string</span> <span style="color: #339933;">.=</span> <span style="color: #0000ff;">' port='</span><span style="color: #339933;">.</span> <a href="http://www.php.net/urldecode"><span style="color: #990000;">urldecode</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$url</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'port'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #339933;">***************</span>
<span style="color: #339933;">***</span> <span style="color: #cc66cc;">85</span><span style="color: #339933;">,</span><span style="color: #cc66cc;">90</span> <span style="color: #339933;">****</span>
<span style="color: #339933;">---</span> <span style="color: #cc66cc;">86</span><span style="color: #339933;">,</span><span style="color: #cc66cc;">94</span> <span style="color: #339933;">----</span>
    <span style="color: #666666; font-style: italic;">// Restore error tracking setting</span>
    <a href="http://www.php.net/ini_set"><span style="color: #990000;">ini_set</span></a><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">'track_errors'</span><span style="color: #339933;">,</span> <span style="color: #000088;">$track_errors_previous</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
&nbsp;
<span style="color: #339933;">+</span>   <span style="color: #666666; font-style: italic;">// set schema</span>
<span style="color: #339933;">+</span>   <span style="color: #b1b100;">if</span><span style="color: #009900;">&#40;</span><span style="color: #339933;">!</span><a href="http://www.php.net/empty"><span style="color: #990000;">empty</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$db_and_schema</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'1'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #009900;">&#41;</span> <a href="http://www.php.net/pg_query"><span style="color: #990000;">pg_query</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$connection</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">'SET search_path TO '</span><span style="color: #339933;">.</span><span style="color: #000088;">$db_and_schema</span><span style="color: #009900;">&#91;</span><span style="color: #0000ff;">'1'</span><span style="color: #009900;">&#93;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
<span style="color: #339933;">+</span>
    <a href="http://www.php.net/pg_query"><span style="color: #990000;">pg_query</span></a><span style="color: #009900;">&#40;</span><span style="color: #000088;">$connection</span><span style="color: #339933;">,</span> <span style="color: #0000ff;">&quot;set client_encoding=<span style="color: #000099; font-weight: bold;">\&quot;</span>UTF8<span style="color: #000099; font-weight: bold;">\&quot;</span>&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span>
    <span style="color: #b1b100;">return</span> <span style="color: #000088;">$connection</span><span style="color: #339933;">;</span>
  <span style="color: #009900;">&#125;</span></pre></td></tr></table></div>

<p>После патча можно указывать в settings.php название базы в виде &laquo;<имя базы>.<имя схемы>&laquo;.</p>
<p>Таким образом, миграция со всеми исследованиями заняла примерно 3 вечера. Получилось немало. Надеюсь, что этот пост поможет кому-то быстрее провести аналогичную миграцию.</p>
]]></content:encoded>
			<wfw:commentRss>http://www.kurdyukov.com/2009/04/16/drupal-migration/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

