Уважаемые пользователи!
C 7 ноября 2020 года phpBB Group прекратила выпуск обновлений и завершила дальнейшее развитие phpBB версии 3.2.
С 1 августа 2024 года phpBB Group прекращает поддержку phpBB 3.2 на официальном сайте.
Сайт официальной русской поддержки phpBB Guru продолжит поддержку phpBB 3.2 до 31 декабря 2024 года.
С учетом этого, настоятельно рекомендуется обновить конференции до версии 3.3.

[FAQ] Как сконвертировать phpBB 3.0.х в phpBB 3.1.х

Проблемы с установкой или работой phpBB 3.1.x? Получите помощь здесь!
С 1 июля 2018 года phpBB Group прекращает поддержку phpBB версии 3.1.
Сайт официальной русской поддержки phpBB Guru продолжит поддержку phpBB 3.1 до 1 января 2019 года.
Подробнее: Окончание поддержки phpBB 3.1.
Правила форума
Местная Конституция | Шаблон запроса | Документация (phpBB3) | Мини [FAQ] по phpBB3.1.x | FAQ-3 (phpbb3) | Как задавать вопросы | Как устанавливать расширения

Ваш вопрос может быть удален без объяснения причин, если на него есть ответы по приведённым ссылкам (а вы рискуете получить предупреждение ;) ).
Аватара пользователя
rxu
phpBB Guru
phpBB Guru
Сообщения: 16372
Стаж: 17 лет 11 месяцев
Откуда: Красноярск
Благодарил (а): 521 раз
Поблагодарили: 1745 раз

[FAQ] Как сконвертировать phpBB 3.0.х в phpBB 3.1.х

Сообщение rxu »

Перед принятием решения обязательно прочтите Мини [FAQ] по phpBB 3.1.x
  • Проверить свой сервер на соответствие: phpBB 3.1.x - системные требования.
  • Сделать бэкап ВСЕГО - и файлов, и базы данных, чтобы потом не было мучительно больно за бесцельно прожитые годы.
  • Переключить всех пользователей, включая себя, на стиль prosilver (phpBB 3.1.х должен делать это сам, но всё равно не повредит).
  • Удалить AutoMOD, если он был установлен, а также все "неродные" модули администраторского, модераторского, личного разделов, если таковые были установлены вместе с какими-либо модами. Удалить все "неродные" таблицы, "неродные" колонки из стандартных таблиц, права доступа если таковые были установлены вместе с какими-либо модами (кроме тех, для которых есть портированные расширения). Если это затруднительно сделать вручную, воспользуйтесь инструментом Support ToolKit (STK).
  • Удалить файлы phpBB 3.0, КРОМЕ:
    • config.php
    • папки /images
    • папки /files
    • папки /store
  • Скопировать все файлы phpBB 3.1 в папку, где находится phpBB 3.0 (кроме config.php)
  • Убедиться в наличии прав доступа к папкам store/, cache/, files/ и images/avatars/upload/ - 777, к файлу config.php - не ниже 666, и выставить таковые при необходимости.
  • Ввести в адресной строке и запустить /install/database_update.php (после имени домена и пути к форумам).
  • Удалить (или переименовать) папку /install, изменить права доступа к файлу config.php на 644.
  • Готово!
Замечание №1: все моды на новой конференции будут потеряны.
Замечание №2: стили для phpBB 3.0 несовместимы со стилями для phpBB 3.1. Если используется уникальный дизайн, его придется обновить или переписать для соответствия phpBB 3.1, иначе он будет потерян.


Перед обновлением обязательно сделать резервные копии всех файлов и базы данных.

Скачать русский пакет phpBB 3.1 можно в нашем разделе базовых пакетов на сайте.
========================
Команда для обновления базы данных с консоли которую надо выполнить из корневой директории конференции.

Код: Выделить всё

php ./bin/phpbbcli.php db:migrate --safe-mode
======================
Скрипт для установки всем пользователем стиля prosilver по умолчанию
Создайте файл fix.php в корневой директории форума, скопируйте туда код и запустите скрипт http://forum.ru/fix.php

Код: Выделить всё

<?php
define('IN_PHPBB', true);
$phpbb_root_path = (defined('PHPBB_ROOT_PATH')) ? PHPBB_ROOT_PATH : './';
$phpEx = substr(strrchr(__FILE__, '.'), 1);
include($phpbb_root_path . 'common.' . $phpEx);

// Default style ID
$sql = 'SELECT config_value FROM ' . CONFIG_TABLE . " WHERE config_name = 'default_style'";
$result = $db->sql_query($sql);
$default_style_id = (int) $db->sql_fetchfield('config_value');
$db->sql_freeresult($result);

// Default style name
$sql = 'SELECT style_name FROM ' . STYLES_TABLE . ' WHERE style_id = ' . $default_style_id;
$result = $db->sql_query($sql);
$default_style_name = $db->sql_fetchfield('style_name');
$db->sql_freeresult($result);

// Active styles
$sql = 'SELECT style_id, style_name, style_active FROM ' . STYLES_TABLE;
$result = $db->sql_query($sql);
while ($row = $db->sql_fetchrow($result))
{
    $styles_list[] = $row;
}
$db->sql_freeresult($result);


echo 'Default style: ' . $default_style_name . ' (' . $default_style_id . ')<br />';

$exists = file_exists('./styles/' . $default_style_name . '/style.cfg');

if ($exists)
{
    echo 'Default style exists, no work to be done.';
    exit;
}

if (!file_exists('./styles/prosilver/style.cfg'))
{
    echo 'Prosilver does not exist. Please upload a copy of prosilver from the <a href="https://www.phpbb.com/downloads/">3.1.0 Full Package</a>.';
    exit;
}

$prosilver = array();
foreach ($styles_list as $style)
{
    if ($style['style_name'] == 'prosilver')
    {
        $prosilver = $style;
        break;
    }
}

// Install style if it doesn't exist
if (!sizeof($prosilver))
{
    $sql_ary = array(
        'style_name'        => 'prosilver',
        'style_copyright'    => '&copy; phpBB Group',
        'style_active'        => 1,
        'style_path'        => 'prosilver',
        'bbcode_bitfield'    => 'lNg=',
        'style_parent_id'    => '0',
        'style_parent_tree'    => '',
    );

    $sql = 'INSERT INTO ' . STYLES_TABLE . '
        ' . $db->sql_build_array('INSERT', $sql_ary);
    $db->sql_query($sql);

    $id = $db->sql_nextid();
    $prosilver = array(
        'style_name'    => 'prosilver',
        'style_id'        => $id,
        'style_active'    => 1,
    );

    echo 'Installed prosilver (' . $id . ').<br />';
}
else
{
    // Activate prosilver
    $sql = 'UPDATE ' . STYLES_TABLE . " SET style_active = 1 WHERE style_name = 'prosilver'";
    $db->sql_query($sql);
}

// Set it as the default style
$sql = 'UPDATE ' . CONFIG_TABLE . ' SET config_value = ' . $prosilver['style_id'] . " WHERE config_name = 'default_style'";
$db->sql_query($sql);
$cache->purge();
echo 'Set prosilver as the default style.<br />';

// Set all users' styles to prosilver
$sql = 'UPDATE ' . USERS_TABLE . ' SET user_style = ' . $prosilver['style_id'];
$db->sql_query($sql);
echo 'Updated user styles to prosilver.<br />';
echo 'Done.';
?>
==================================
Файл config.php от версии phpbb 3.1.x

Код: Выделить всё

<?php
// phpBB 3.1.x auto-generated configuration file
// Do not change anything in this file!
$dbms = 'phpbb\\db\\driver\\mysqli';
$dbhost = '';
$dbport = '';
$dbname = '';
$dbuser = '';
$dbpasswd = '';
$table_prefix = 'phpbb_';
$phpbb_adm_relative_path = 'adm/';
$acm_type = 'phpbb\\cache\\driver\\file';

@define('PHPBB_INSTALLED', true);
//@define('DEBUG', true);
//@define('PHPBB_DISPLAY_LOAD_TIME', true);
$dbname = 'имя_базы_данных';
$dbuser = 'пользователь_базы_данных';
$dbpasswd = 'пароль_базы_данных';
============
Последний раз редактировалось владимир1983 01.01.2017 15:00, всего редактировалось 28 раз.
Причина: Добавил команду для обновление БД через консоль
Изображение
Аватара пользователя
petsinform
phpBB 2.0.0
Сообщения: 206
Стаж: 12 лет 1 месяц
Благодарил (а): 2 раза

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение petsinform »

rxu писал(а):Это надо смотреть в логах ошибок серверов (Апача и MySQL).
Да, пожалуй эта конвертация пока не для банального пользователя.
Спасибо за ответ. Буду ждать пока кто-нибудь более грамотный не разрулит.
Аватара пользователя
rxu
phpBB Guru
phpBB Guru
Сообщения: 16372
Стаж: 17 лет 11 месяцев
Откуда: Красноярск
Благодарил (а): 521 раз
Поблагодарили: 1745 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение rxu »

petsinform писал(а):Буду ждать пока кто-нибудь более грамотный не разрулит.
Маловероятно. Данная проблема возникала только у 3-х пользователей, насколько я видел. И пока в причинах не разобрались.
Нужны подробности. Неясны условия для того, чтобы воспроизвести проблему.
По какой-то причине в ходе конвертации не изменяется тип поля 'user_avatar_type' с int(2) на varchar(255), хотя запрос такой должен выполняться.
Почему не изменяется (т.е. запрос не выполняется) - вот в чем вопрос.
Можете попробовать на тестовой конвертируемой базе данных выполнить запрос напрямую?
Вот такой (префикс поменять на актуальный):

Код: Выделить всё

'ALTER TABLE phpbb_users CHANGE user_avatar_type user_avatar_type varchar(255) DEFAULT '' NOT NULL;
Изображение
Аватара пользователя
petsinform
phpBB 2.0.0
Сообщения: 206
Стаж: 12 лет 1 месяц
Благодарил (а): 2 раза

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение petsinform »

rxu писал(а):Можете попробовать на тестовой конвертируемой базе данных выполнить запрос напрямую?
Вот такой (префикс поменять на актуальный):
Код: Выделить всё
'ALTER TABLE phpbb_users CHANGE user_avatar_type user_avatar_type varchar(255) DEFAULT '' NOT NULL;
Для меня это как то - темный лес. Может ближе к финалу будет нормальная конвертация. Да и без расширений phpBB Gallery, ссылки в новом окне, phpBB Arcade, phpBB geo topics mod 1.4.3, Благодарность за сообщения, Mutiple File Upload, highslide, AutoMOD, Antibot 100500 получается не очень функционально.
Еще все-таки не видит новый форум стиль ca_gen2. владимир1983 мне его помогал настраивать под эти моды (отдельное спасибо ему).
Аватара пользователя
rxu
phpBB Guru
phpBB Guru
Сообщения: 16372
Стаж: 17 лет 11 месяцев
Откуда: Красноярск
Благодарил (а): 521 раз
Поблагодарили: 1745 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение rxu »

petsinform писал(а):Благодарность за сообщения
Это уже почти портировано.
petsinform писал(а):Mutiple File Upload
С PLupload в этом моде смысла не особо много.
petsinform писал(а):AutoMOD
Тем более это чудо - в 3.1 его не будет, т.к. процесс установки расширений совсем другой.
petsinform писал(а):Antibot 100500
Этот портируется элементарно.
petsinform писал(а):Может ближе к финалу будет нормальная конвертация
Процесс обновления БД вряд ли как-то изменится. Надо выяснять причину данного конкретного бага.
Но всё равно спасибо за попытку.
Изображение
Аватара пользователя
petsinform
phpBB 2.0.0
Сообщения: 206
Стаж: 12 лет 1 месяц
Благодарил (а): 2 раза

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение petsinform »

А со стилями которые уже стоят для дилетантов чего-нибудь будет? Как-то не хочется менять стиль форума. И будет ли phpBB Gallery, ссылки в новом окне, phpBB Arcade, phpBB geo topics, Благодарность за сообщения, highslide?

P.S. Может все-таки дать доступ к тестовому форуму - Вы лучше увидите, да и у других будет меньше вопросов?
Аватара пользователя
rxu
phpBB Guru
phpBB Guru
Сообщения: 16372
Стаж: 17 лет 11 месяцев
Откуда: Красноярск
Благодарил (а): 521 раз
Поблагодарили: 1745 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение rxu »

Со стилями сложнее. Их надо будет либо обновлять вручную, либо дожидаться, пока авторы их не обновят до phpBB 3.1.
Изображение
Аватара пользователя
petsinform
phpBB 2.0.0
Сообщения: 206
Стаж: 12 лет 1 месяц
Благодарил (а): 2 раза

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение petsinform »

rxu писал(а):Со стилями сложнее. Их надо будет либо обновлять вручную, либо дожидаться, пока авторы их не обновят до phpBB 3.1.
Да! Грустно получается :-( Видать не судьба. А 3.0.12 поддерживаться уже вообще не будет?
Аватара пользователя
rxu
phpBB Guru
phpBB Guru
Сообщения: 16372
Стаж: 17 лет 11 месяцев
Откуда: Красноярск
Благодарил (а): 521 раз
Поблагодарили: 1745 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение rxu »

будет какое-то время, но не очень долго. Полгода-год, скорее всего. Хотя, предсказать невозможно, т.к. всё зависит от срока выхода 3.2. Одновременно будут поддерживаться только две ветки.
Изображение
[PHP]Apple
phpBB 1.4.0
Сообщения: 33
Стаж: 9 лет 6 месяцев
Благодарил (а): 1 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение [PHP]Apple »

Стиль который стоял на 3.0 не будет работать на 3.1?
Аватара пользователя
Татьяна5
Поддержка
Поддержка
Сообщения: 12449
Стаж: 12 лет 8 месяцев
Благодарил (а): 166 раз
Поблагодарили: 2479 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение Татьяна5 »

Не будет
Аватара пользователя
angst66
phpBB 3.0.0 RC1
Сообщения: 1471
Стаж: 12 лет 3 месяца
Благодарил (а): 48 раз
Поблагодарили: 71 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение angst66 »

Сконвертировал базу, удалил папку инстайл. Нажимаю "Войдите на конференцию", получаю ошибку

Код: Выделить всё

SQL ERROR [ mysql4 ]

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE user_id = 1' at line 3 [1064]

SQL

UPDATE phpbb_users SET user_style = WHERE user_id = 1

BACKTRACE

FILE: (not given by php)
LINE: (not given by php)
CALL: msg_handler()

FILE: [ROOT]/phpbb/db/driver/driver.php
LINE: 803
CALL: trigger_error()

FILE: [ROOT]/phpbb/db/driver/mysql.php
LINE: 184
CALL: phpbb\db\driver\driver->sql_error()

FILE: [ROOT]/phpbb/user.php
LINE: 215
CALL: phpbb\db\driver\mysql->sql_query()

FILE: [ROOT]/ucp.php
LINE: 32
CALL: phpbb\user->setup()
Аватара пользователя
rxu
phpBB Guru
phpBB Guru
Сообщения: 16372
Стаж: 17 лет 11 месяцев
Откуда: Красноярск
Благодарил (а): 521 раз
Поблагодарили: 1745 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение rxu »

angst66
А стиль был какой, нестандартный?
Изображение
Аватара пользователя
angst66
phpBB 3.0.0 RC1
Сообщения: 1471
Стаж: 12 лет 3 месяца
Благодарил (а): 48 раз
Поблагодарили: 71 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение angst66 »

В базе стиль был нестандартный.
Аватара пользователя
владимир1983
phpBB 3.2.6
Сообщения: 5954
Стаж: 14 лет
Откуда: Сергиев Посад
Благодарил (а): 306 раз
Поблагодарили: 296 раз

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение владимир1983 »

Перед конвертацией надо было перейти на стандартный prosilver, и установить его по умолчанию для всех пользователей. Теперь либо в бд залезать и руками значения править, или повторно сделать обновления но уже с установленным prosilver.
За ваши деньги решу ваши проблемы. Стучи в ЛС.
Нет человека - нет проблемы. (c)
alex88_9
phpBB 1.4.4
Сообщения: 133
Стаж: 11 лет 10 месяцев

Re: Как сконвертировать phpBB 3.0 в phpBB 3.1

Сообщение alex88_9 »

rxu писал(а):Замечание: все моды на новой конференции будут потеряны.
То есть десятки модов, которые были установлены на форуме будут потеряны?
Перенесено из форума FAQ в форум Поддержка phpBB 3.1.x 01.01.2019 7:53 модератором rxu

Вернуться в «Поддержка phpBB 3.1.x»