Содержание

,

Инвентаризация: Обновление

Для чистой установки есть отдельная инструкция.

Перед обновлением

Если мы хотим, чтобы обновления были обратимы то

Смотрим на каком коммите мы находимся:

git log -1

и запоминаем (лучше в файл) хэш текущего коммита (например c729a2b43520275f1abc8c25bd9770f5d6c43519)

Если страшно, то можно сделать резервную копию

Обновление файловой структуры

просто скачиваем свежую версию при помощи git и обновляем структуру БД применяя новые миграции:

git pull

После этого обновляем зависимости

composer update

С этого места система в общем случае неконсистентна, поэтому быстро обновляем структуру БД:

./yii migrate

Собственно все. Система снова консистентна и находится в последней версии.

Если чтото пошло не так

Ну или просто раньше было лучше, то в обратном порядке делаем

Откат БД

Нужно делать, только если при обновлении БД были применены какие-то миграции.
Итак, нужно отменить последние миграции. Может быть вы помните сколько было применено, но на всякий случай смотрим историю миграций:

./yii migrate/history

считаем сколько миграций было применено при последнем обновлении (по дате применения). Пример:

./yii migrate
Yii Migration Tool (based on Yii v2.0.31)
 
Total 1 new migration to be applied:
        m191219_100002_fix_contracts_in_materials_id
 
Apply the above migration? (yes|no) [no]:y
*** applying m191219_100002_fix_contracts_in_materials_id
    > alter column id in table contracts_in_materials to integer NOT NULL AUTO_INCREMENT ... done (time: 0.010s)
*** applied m191219_100002_fix_contracts_in_materials_id (time: 0.025s)
 
 
1 migration was applied.
 
Migrated up successfully.
./yii migrate/history
Yii Migration Tool (based on Yii v2.0.31)
 
Showing the last 10 applied migrations:
        (2020-01-12 18:54:05) m191219_100002_fix_contracts_in_materials_id
        (2020-01-12 14:41:12) m191219_100001_fix_materials_id
        (2020-01-12 14:41:12) m191219_100000_add_users_employ_date
        (2020-01-12 14:41:11) m191208_173041_fix_users_id
        (2020-01-12 14:41:11) m191208_173041_fix_many_2_many
        (2020-01-12 14:41:11) m191208_164401_add_default_ip_values_in_comps
        (2020-01-12 14:41:11) m191204_062411_decimal_prices
        (2020-01-12 14:41:10) m191120_095815_add_cost_column_to_org_phones_table
        (2020-01-12 14:41:10) m191120_062411_float_prices
        (2020-01-12 14:41:10) m191119_172409_add_charge_column_to_contracts_table

В примере мы применяем 1 миграцию и в истории видим что дата применения миграции m191219_100002_fix_contracts_in_materials_id вот только-что, а остальные применены давно.
собственно нам надо отменить одну:

./yii migrate/down 1

с этого момента мы снова не консистентны.

Откат файлов

делаем git checkout на старый коммит:

git checkout c729a2b43520275f1abc8c25bd9770f5d6c43519

после чего git правда скажет, что мы отцепились от ветки HEAD.
чтобы

вернуться на HEAD

надо сделать

git pull origin/HEAD
./yii migrate

т.е. обновиться с явным указанием что `до origin/HEAD`