##// END OF EJS Templates
docs: update i18n doc after TG migration changed lang to i18n.lang and test.ini is generated...
docs: update i18n doc after TG migration changed lang to i18n.lang and test.ini is generated These descriptions are not elegant, but now we make them less wrong.

File last commit:

r7300:415cc651 default
r7311:451b3f9d default
Show More
upgrade.rst
215 lines | 6.6 KiB | text/x-rst | RstLexer
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917 .. _upgrade:
===================
Upgrading Kallithea
===================
This describes the process for upgrading Kallithea, independently of the
Kallithea installation method.
Søren Løvborg
db: drop RhodeCode compatibility (database rebranding etc.)...
r5976 .. note::
If you are upgrading from a RhodeCode installation, you must first
install Kallithea 0.3.2 and follow the instructions in the 0.3.2
README to perform a one-time conversion of the database from
RhodeCode to Kallithea, before upgrading to the latest version
of Kallithea.
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917
1. Stop the Kallithea web application
-------------------------------------
This step depends entirely on the web server software used to serve
Kallithea, but in any case, Kallithea should not be running during
the upgrade.
.. note::
If you're using Celery, make sure you stop all instances during the
upgrade.
2. Create a backup of both database and configuration
-----------------------------------------------------
You are of course strongly recommended to make backups regularly, but it
is *especially* important to make a full database and configuration
backup before performing a Kallithea upgrade.
Back up your configuration
^^^^^^^^^^^^^^^^^^^^^^^^^^
Make a copy of your Kallithea configuration (``.ini``) file.
If you are using :ref:`rcextensions <customization>`, you should also
make a copy of the entire ``rcextensions`` directory.
Back up your database
^^^^^^^^^^^^^^^^^^^^^
If using SQLite, simply make a copy of the Kallithea database (``.db``)
file.
If using PostgreSQL, please consult the documentation for the ``pg_dump``
utility.
If using MySQL, please consult the documentation for the ``mysqldump``
utility.
Thomas De Schampheleire
Turbogears2 migration: use sqlalchemy.url iso sqlalchemy.db1.url...
r6177 Look for ``sqlalchemy.url`` in your configuration file to determine
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917 database type, settings, location, etc.
3. Activate the Kallithea virtual environment (if any)
------------------------------------------------------
Verify that you are using the Python environment that you originally
installed Kallithea in by running::
pip freeze
This will list all packages installed in the current environment. If
Kallithea isn't listed, activate the correct virtual environment.
See the appropriate installation page for details.
4. Install new version of Kallithea
-----------------------------------
Please refer to the instructions for the installation method you
originally used to install Kallithea.
If you originally installed using pip, it is as simple as::
pip install --upgrade kallithea
If you originally installed from version control, it is as simple as::
cd my-kallithea-clone
hg pull -u
Thomas De Schampheleire
docs: recommend --upgrade for all pip installations in a virtualenv...
r6703 pip install --upgrade -e .
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917
domruf
less: don't distribute the generated style.css file - for now, it must be built with npm after installing Kallithea...
r6980 Temporarily, in the current version, an extra step is required to build
front-end files:
Find the right ``kallithea/public/less`` path with::
python -c "import os, kallithea; print os.path.join(os.path.dirname(os.path.abspath(kallithea.__file__)), 'public', 'less')"
Then run::
domruf
move package.json to root directory...
r7026 npm install
npm run less
domruf
less: don't distribute the generated style.css file - for now, it must be built with npm after installing Kallithea...
r6980
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917
5. Upgrade your configuration
-----------------------------
Mads Kiilerich
gearbox: make a make-config sub-command available again...
r6510 Run the following command to create a new configuration (``.ini``) file::
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917
Mads Kiilerich
gearbox: make a make-config sub-command available again...
r6510 gearbox make-config new.ini
Then compare it with your old config file and see what changed.
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917
.. note::
Please always make sure your ``.ini`` files are up to date. Errors
can often be caused by missing parameters added in new versions.
Søren Løvborg
docs: document how to use Alembic for database migrations
r5986 .. _upgrade_db:
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917
6. Upgrade your database
------------------------
Søren Løvborg
docs: document how to use Alembic for database migrations
r5986 .. note::
If you are *downgrading* Kallithea, you should perform the database
migration step *before* installing the older version. (That is,
always perform migrations using the most recent of the two versions
you're migrating between.)
First, run the following command to see your current database version::
alembic -c my.ini current
Typical output will be something like "9358dc3d6828 (head)", which is
the current Alembic database "revision ID". Write down the entire output
for troubleshooting purposes.
The output will be empty if you're upgrading from Kallithea 0.3.x or
older. That's expected. If you get an error that the config file was not
found or has no ``[alembic]`` section, see the next section.
Next, if you are performing an *upgrade*: Run the following command to
upgrade your database to the current Kallithea version::
alembic -c my.ini upgrade head
If you are performing a *downgrade*: Run the following command to
downgrade your database to the given version::
alembic -c my.ini downgrade 0.4
Alembic will show the necessary migrations (if any) as it executes them.
If no "ERROR" is displayed, the command was successful.
Should an error occur, the database may be "stranded" half-way
through the migration, and you should restore it from backup.
Enabling old Kallithea config files for Alembic use
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
Kallithea configuration files created before the introduction of Alembic
(i.e. predating Kallithea 0.4) need to be updated for use with Alembic.
Without this, Alembic will fail with an error like this::
FAILED: No config file 'my.ini' found, or file has no '[alembic]' section
If Alembic complains specifically about a missing ``alembic.ini``, it is
likely because you did not specify a config file using the ``-c`` option.
On the other hand, if the mentioned config file actually exists, you
need to append the following lines to it::
[alembic]
script_location = kallithea:alembic
Your config file should now work with Alembic.
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917
Thomas De Schampheleire
docs: upgrade: add section on updating git hooks...
r7300 7. Update Git repository hooks
------------------------------
It is possible that an upgrade involves changes to the Git hooks installed by
Kallithea. As these hooks are created inside the repositories on the server
filesystem, they are not updated automatically when upgrading Kallithea itself.
To update the hooks of your Git repositories:
* Go to *Admin > Settings > Remap and Rescan*
* Select the checkbox *Install Git hooks*
* Click the button *Rescan repositories*
.. note::
Kallithea does not use hooks on Mercurial repositories. This step is thus
not necessary if you only have Mercurial repositories.
8. Rebuild the Whoosh full-text index
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917 -------------------------------------
It is recommended that you rebuild the Whoosh index after upgrading since
new Whoosh versions can introduce incompatible index changes.
Thomas De Schampheleire
docs: upgrade: add section on updating git hooks...
r7300 9. Start the Kallithea web application
Søren Løvborg
docs: restructure Kallithea upgrade instructions...
r5917 --------------------------------------
This step once again depends entirely on the web server software used to
serve Kallithea.
Before starting the new version of Kallithea, you may find it helpful to
clear out your log file so that new errors are readily apparent.
.. note::
If you're using Celery, make sure you restart all instances of it after
upgrade.
.. _virtualenv: http://pypi.python.org/pypi/virtualenv