Loading...
 
Skip to main content

History: Automatic updates

Source of version: 39 (current)

Copy to clipboard
            {syntax type="markdown"  editor="wysiwyg"} # {{page}}

This is the recipe for 1-click updates/upgrades starting in ((Tiki25)).

- Updates are in the same branch: 24.1 -> 24.2
- Upgrades are different branches: 21.3 -> 22.0 or 21.3 -> 24.1

## Context

1-click updates/upgrades is a highly-requested capability which is tricky to do right. Risks include:

- broken updates/upgrades
- time-outs
- browser disconnection (user closes browser during an upgrade or Internet access is lost)
- loss of local modications
- lower security on file permissions
- issues if self-update conflicts with external installer tool
- The upgrade succeeded but the user wants to restore previous version (regression bug, change of behavior, etc.)

## Requirements

- Command line access
- Cron jobs
- Tiki Manager dependencies, or the capability to install them. See the Tiki Manager section of ((Check|Tiki Check)) 
    - rsync
    - git
    - etc.

## High-level

Once set up, Tiki will update Tiki Manager, and Tiki Manager will update/upgrade Tiki. Steps:

1. Install Tiki from Git, either 
    - manually or
    - with an external ((Manager|Tiki Manager)) (which you don't need to keep after) or
    - with [https://gitlab.com/wikisuite/virtualmin-tikimanager|virtualmin-tikimanager]
2. Set up the cron job for ((Scheduler|Tiki Scheduler)) (which will be used so operations are background processes)
3. Install the ((Tiki Manager Package))
4. Use Tiki Manager to update/upgrade Tiki on demand (web or command line) or update automatically (via a cron job)

## Benefits

While tools have been available for years for updates/upgrades, they required using the command line. Starting in Tiki25, the command line will only be required for the initial setup.

### Code directly from Git sources

- Can get any revision, and not just released versions
- Can efficiently maintain local modifications 
    - Before updates/upgrades, there is a check to detect conflicts
- Can use your own Git branch
- Can use merge requests / branches
- If a file is removed from the official source code, it will be removed. If you install over an older via a zip, you will have leftover files which can cause issues.

### Pick your preferred lifecycle

- Pick any version: Bleeding edge, stable, Long Term Versions (LTS), etc. See: ((tw:Versions))

### Sensible file permissions

Since Tiki Manager is not ran by the web user (like Apache or www), it can set safer file permissions

### Background process

Since Tiki Manager is not ran by the web user (like Apache or www), it is not prone to time-out errors

### Testing on clones

- Thanks to Tiki Manager, you can clone, clone-and-update or clone-and-upgrade to have a test environment. Within Virtualmin, this is even easier with the GUI to create a web space with a database, and clone from one to another, as seen here: https://wikisuite.org/Virtualmin-Tiki-Manager

### A Tiki instance can be managed by more than one Tiki Manager

- So for example, a hosting company could handle updates for security issues via a remote Tiki Manager, while the site manager uses the local Tiki Manager for other updates/upgrades like testing new features.

### Tons of other features

- Please see ((Manager|Tiki Manager))

## Before Tiki25 via command line

### Tiki Manager

Recent versions of ((Manager|Tiki Manager)) use Git, but previously, it was SVN

- ((Manager|#instance:update|instance:update))
- ((Manager|#instance:upgrade|instance:upgrade))
- ((Manager|#manager:setup-update|manager:setup-update))

### svnup.php

[https://gitlab.com/tikiwiki/tiki/-/blob/master/doc/devtools/svnup.php|svnup.php] which is bundled starting in ((Tiki17))

{CODE(caption="An example of this script on a daily cron job")}
0 0 * * * cd /var/www/html/;  php doc/devtools/svnup.php
{CODE}