Upgrade from Archivematica 1.9.x to 1.10.0¶
On this page:
- Upgrade Ubuntu package install
- Upgrade CentOS/Red Hat package install
- Upgrade in indexless mode
- Upgrade with output capturing disabled
Note
While it is possible to upgrade a GitHub-based source install using ansible, these instructions do not cover that scenario.
Create a backup¶
Before starting any upgrade procedure on a production system, we strongly recommend backing up your system. If you are using a virtual machine, take a snapshot of it before making any changes. Alternatively, back up the file systems being used by your system. Exact procedures for updating will depend on your local installation. At a minimum you should make backups of:
- The Storage Service SQLite (or MySQL) database
- The dashboard MySQL database
This is a simple example of backing up these two databases:
sudo cp /var/archivematica/storage-service/storage.db ~/storage_db_backup.db
mysqldump -u root -p MCP > ~/am_backup.sql
If you do not have a password set for the root user in MySQL, you can take out the ‘-p’ portion of that command. If there is a problem during the upgrade process, you can restore your MySQL database from this backup and try the upgrade again.
If you’re upgrading from Archivematica 1.8 or lower to the 1.9 version or higher, the Elasticsearch version support changed from 1.x to 6.x and it’s also recommended to create a backup of your Elasticsearch data, especially if you don’t have access to the AIP storage locations in the local filesystem.
You can follow these steps in order to create a backup of Elasticsearch:
# Remove and recreate the folder that stores the backup
sudo rm -rf /var/lib/elasticsearch/backup-repo/
sudo mkdir -p /var/lib/elasticsearch/backup-repo/
sudo chown elasticsearch:elasticsearch /var/lib/elasticsearch/backup-repo/
# Allow elasticsearch to write files to the backup
echo 'path.repo: ["/var/lib/elasticsearch/backup-repo"]' |sudo tee -a /etc/elasticsearch/elasticsearch.yml
# Restart ElasticSearch and wait for it to start
sudo service elasticsearch restart
sleep 60s
# Configure the ES backup
curl -XPUT "localhost:9200/_snapshot/backup-repo" -H 'Content-Type: application/json' -d \
'{
"type": "fs",
"settings": {
"location": "./",
"compress": true
}
}'
# Take the actual backup, and copy it to a safe place
curl -X PUT "localhost:9200/_snapshot/backup-repo/am_indexes_backup?wait_for_completion=true"
cp /var/lib/elasticsearch/backup-repo elasticsearch-backup -rf
For more info, refer to the ElasticSearch 6.8 docs.
Upgrade on Ubuntu packages¶
Update the operating system.
sudo apt-get update && sudo apt-get upgrade
Update package sources.
In Ubuntu 16.04:
wget -qO - https://artifacts.elastic.co/GPG-KEY-elasticsearch | sudo apt-key add - echo "deb https://artifacts.elastic.co/packages/6.x/apt stable main" | sudo tee -a /etc/apt/sources.list.d/elastic-6.x.list echo 'deb [arch=amd64] http://packages.archivematica.org/1.10.x/ubuntu xenial main' >> /etc/apt/sources.list echo 'deb [arch=amd64] http://packages.archivematica.org/1.10.x/ubuntu-externals xenial main' >> /etc/apt/sources.list
Optionally you can remove the lines referencing packages.archivematica.org/1.9.x from /etc/apt/sources.list.
In Ubuntu 18.04:
echo 'deb [arch=amd64] http://packages.archivematica.org/1.10.x/ubuntu bionic main' >> /etc/apt/sources.list echo 'deb [arch=amd64] http://packages.archivematica.org/1.10.x/ubuntu-externals bionic main' >> /etc/apt/sources.list
Optionally you can remove the lines referencing packages.archivematica.org/1.9.x from /etc/apt/sources.list.
Update the Storage Service.
sudo apt-get update sudo apt-get install archivematica-storage-service
Update Archivematica. During the update process you may be asked about updating configuration files. Choose to accept the maintainers versions. You will also be asked about updating the database - say ‘ok’ to each of those steps. If you have set a password for the root MySQL database user, enter it when prompted.
sudo apt-get install archivematica-common sudo apt-get install archivematica-dashboard sudo apt-get install archivematica-mcp-server sudo apt-get install archivematica-mcp-client
Restart services.
sudo service archivematica-storage-service restart sudo service gearman-job-server restart sudo service archivematica-mcp-server restart sudo service archivematica-mcp-client restart sudo service archivematica-dashboard restart sudo service nginx restart
Depending on your browser settings, you may need to clear your browser cache to make the dashboard pages load properly. For example in Firefox or Chrome you should be able to clear the cache with control-shift-R or command-shift-F5.
Upgrade on CentOS/Red Hat packages¶
Upgrade the repositories for 1.10:
sudo sed -i 's/1.9.x/1.10.x/g' /etc/yum.repos.d/archivematica*
Remove the current installed version of ghostscript:
sudo rpm -e --nodeps ghostscript ghostscript-x11 \ ghostscript-core ghostscript-fonts
Upgrade Archivematica packages:
sudo yum update
Once the new packages are installed, upgrade the databases for both Archivematica and the Storage Service. This can be done with:
sudo -u archivematica bash -c " \ set -a -e -x source /etc/default/archivematica-dashboard || \ source /etc/sysconfig/archivematica-dashboard \ || (echo 'Environment file not found'; exit 1) cd /usr/share/archivematica/dashboard /usr/share/archivematica/virtualenvs/archivematica-dashboard/bin/python manage.py migrate --noinput "; sudo -u archivematica bash -c " \ set -a -e -x source /etc/default/archivematica-storage-service || \ source /etc/sysconfig/archivematica-storage-service \ || (echo 'Environment file not found'; exit 1) cd /usr/lib/archivematica/storage-service /usr/share/archivematica/virtualenvs/archivematica-storage-service/bin/python manage.py migrate ";
Restart the Archivematica related services, and continue using the system:
sudo systemctl restart archivematica-storage-service sudo systemctl restart archivematica-dashboard sudo systemctl restart archivematica-mcp-client sudo systemctl restart archivematica-mcp-server
Depending on your browser settings, you may need to clear your browser cache to make the dashboard pages load properly. For example in Firefox or Chrome you should be able to clear the cache with control-shift-R or command-shift-F5.
Upgrade on Vagrant / Ansible¶
This upgrade method will work with Vagrant machines, but also with cloud based virtual machines, or physical servers.
Connect to your Vagrant machine or server
vagrant ssh # Or ssh <your user>@<host>
Install Ansible
sudo pip install ansible
Checkout the deployment repo:
git clone https://github.com/artefactual/deploy-pub.git
Go into the appropiate playbook folder, and install the needed roles
Ubuntu 16.04 (Xenial):
cd deploy-pub/playbooks/archivematica-xenial ansible-galaxy install -f -p roles/ -r requirements.yml
Ubuntu 18.04 (Bionic):
cd deploy-pub/playbooks/archivematica-bionic ansible-galaxy install -f -p roles/ -r requirements.yml
Centos 7:
cd deploy-pub/playbooks/archivematica-centos7 ansible-galaxy install -f -p roles/ -r requirements.yml
All the following steps should be run from the respective playbook folder for your operating system.
Verify that the vars-singlenode.yml has the appropiate contents for Elasticsearch and Archivematica, or update it with your own
Create a hosts file.
echo 'am-local ansible_connection=local' > hosts
Upgrade Archivematica running
ansible-playbook -i hosts singlenode.yml --tags=elasticsearch,archivematica-src
Upgrade in indexless mode¶
As of Archivematica 1.7, Archivematica can be run in indexless mode; that is,
without Elasticsearch. Installing Archivematica without Elasticsearch, or with
limited Elasticsearch functionality, means reduced consumption of compute
resources and lower operational complexity. By setting the
archivematica_src_search_enabled
configuration attribute, administrators can
define how many things Elasticsearch is indexing, if any. This can impact
searching across several different dashboard pages.
Upgrade your existing Archivematica pipeline following the instructions above.
Modify the relevant systemd EnvironmentFile files by adding lines that set the relevant environment variables to
false
.If you are using Ubuntu, run the following commands.
sudo sh -c 'echo "ARCHIVEMATICA_DASHBOARD_DASHBOARD_SEARCH_ENABLED=false" >> /etc/default/archivematica-dashboard' sudo sh -c 'echo "ARCHIVEMATICA_MCPSERVER_MCPSERVER_SEARCH_ENABLED=false" >> /etc/default/archivematica-mcp-server' sudo sh -c 'echo "ARCHIVEMATICA_MCPCLIENT_MCPCLIENT_SEARCH_ENABLED=false" >> /etc/default/archivematica-mcp-client'
If you are using CentOS, run the following commands.
sudo sh -c 'echo "ARCHIVEMATICA_DASHBOARD_DASHBOARD_SEARCH_ENABLED=false" >> /etc/sysconfig/archivematica-dashboard' sudo sh -c 'echo "ARCHIVEMATICA_MCPSERVER_MCPSERVER_SEARCH_ENABLED=false" >> /etc/sysconfig/archivematica-mcp-server' sudo sh -c 'echo "ARCHIVEMATICA_MCPCLIENT_MCPCLIENT_SEARCH_ENABLED=false" >> /etc/sysconfig/archivematica-mcp-client'
Restart services.
If you are using Ubuntu, run the following commands.
sudo service archivematica-dashboard restart sudo service archivematica-mcp-client restart sudo service archivematica-mcp-server restart
If you are using CentOS, run the following commands.
sudo -u root systemctl restart archivematica-dashboard sudo -u root systemctl restart archivematica-mcp-client sudo -u root systemctl restart archivematica-mcp-server
If you had previously installed and started the Elasticsearch service, you can turn it off now.
sudo -u root systemctl stop elasticsearch sudo -u root systemctl disable elasticsearch
Upgrade with output capturing disabled¶
As of Archivematica 1.7.1, output capturing can be disabled at upgrade or at
any other time. This means the stdout and stderr from preservation tasks are
not captured, which can result in a performane improvement. See the
Task output capturing configuration <task-output-capturing-admin> page for
more details. In order to disable output capturing, set the
ARCHIVEMATICA_MCPCLIENT_MCPCLIENT_CAPTURE_CLIENT_SCRIPT_OUTPUT
environment
variable to false
and restart the MCP Client process(es). Consult the
installation instructions for your deployment method for more details on how to
set environment variables and restart Archivematica processes.