blob: 4256ad1bb7b36f215e232a47ad23b872753a37b3 [file] [log] [blame]
Upgrading to VCL 2.5
VCL 2.5 is the second release to include an upgrade script. All you need to
upgrade VCL is the script. It will download and validate the VCL software and
then upgrade your system. The script can be used to upgrade all three parts of
VCL (database, web portal, and management node) or to upgrade each part
individually.
Running the upgrade script with no arguments will step you through upgrading
all three parts of VCL.
./vcl-upgrade.sh
Alternatively, any combination of the three parts of VCL can be upgraded by
passing arguments to the script. If upgrading the management node part of VCL,
it will also prompt you to agree to the installation of various system level
requirements needed for the code to run. The database upgrade portion does not
have to be run on the actual database server. The following are the arguments
available:
vcl-upgrade.sh [-h|--help] [-d|--database] [-w|--web] [-m|--managementnode]
[--dbhost <hostname>] [--dbadminuser <username>]
[--dbadminpass <password>]
-d|--database - upgrade database components
--dbhost may optionally be specified if not localhost
-w|--web - upgrade web server components
-m|--managementnode - upgrade management node (vcld) components
--dbhost <hostname> - hostname of database server (default=localhost)
--dbname <name> - name of VCL database on database server (default=vcl)
--dbadminuser <username> - admin username for database; must have access
to modify database schema and dump data for backup (default=root)
--dbadminpass <password> - password for dbadminuser (default=[no password])
MANUAL UPGRADE INSTRUCTIONS
The recommended method of upgrading VCL is to use the upgrade script. See above
for additional information. If manual installation is required, instructions
are listed below.
1. Shutdown the httpd and vcld services
service httpd stop
service vcld stop
2. Create a backup of the VCL database. This will provide a restore point if
necessary.
mysqldump vcl > ~/vcl-pre2.5-upgrade.sql
3. Updates the database schema.
mysql vcl < /root/apache-VCL-2.5/mysql/update-vcl.sql
4. Possibly move old web code. If /var/www/html/vcl is a directory, rename it
to /var/www/html/vcl-2.4.2. These instructions assume that you installed the
VCL web code at /var/www/html/vcl. If you installed it elsewhere, replace
/var/www/html/vcl with your vcl web root.
mv /var/www/html/vcl /var/www/html/vcl-2.4.2
5. Disable access to the old web code
echo "Require all denied" > /var/www/html/vcl-2.4.2/.htaccess
6. Copy the new code in place
cp -ar /root/apache-VCL-2.5/web /var/www/html/vcl-2.5
ln -sfn /var/www/html/vcl-2.5 /var/www/html/vcl
7. Copy your 2.4.2 config files
cd /var/www/html/vcl-2.4.2/.ht-inc
cp conf.php secrets.php pubkey.pem keys.pem /var/www/html/vcl/.ht-inc
8. If you are using SELinux, set the correct context:
chcon -R -t httpd_sys_content_t /var/www/html/vcl-2.5
chcon -t httpd_sys_rw_content_t /var/www/html/vcl-2.5/.ht-inc/maintenance
chcon -t httpd_sys_rw_content_t /var/www/html/vcl-2.5/.ht-inc/cryptkey
9. Update conf.php: the following item needs to be removed from the conf.php
file:
(don't forget to edit conf.php in the *new* location)
vim /var/www/html/vcl/.ht-inc/conf.php
define("MAXVMLIMIT", "100");
10. Update secrets.php: $cryptkey in secrets.php needs to be generated using
openssl. Generate the value and set it in secrets.php:
openssl rand 32 | base64
vim /var/www/html/vcl/.ht-inc/secrets.php
$cryptkey = 'xxxxxxxxxxxxxxxxxxxxxxxxx'; # set this to output of
# "openssl rand 32 | base64"
11. Make the maintenance and cryptkey directories writable by the web server
user. Normally this is the apache user, if using a different user change
below command accordingly.
chown apache /var/www/html/vcl/.ht-inc/maintenance
chown apache /var/www/html/vcl/.ht-inc/cryptkey
12. Start httpd service
service httpd start
13. Check testsetup.php: Check that everything is correct by viewing the
testsetup.php script in your browser. This script is located in the same
directory as the index.php script. I.e.
https://your.site.url/vcl/testsetup.php
14. Copy old management node code:
If /usr/local/vcl is a directory, copy it to /usr/local/vcl-2.4.2, rename
/usr/local/vcl to /usr/local/vcl-2.5, and create a symlink.
If /usr/local/vcl is a symlink to vcl-2.4.2, copy /usr/local/vcl-2.4.2 to
/usr/local/vcl-2.5 and update the symlink.
(for directory)
cp -ar /usr/local/vcl /usr/local/vcl-2.4.2
mv /usr/local/vcl /usr/local/vcl-2.5
ln -s /usr/local/vcl-2.5 /usr/local/vcl
(for symlink)
cp -ar /usr/local/vcl-2.4.2 /usr/local/vcl-2.5
ln -sfn /usr/local/vcl-2.5 /usr/local/vcl
15. Copy the new management node code over the old code:
/bin/cp -ar /root/apache-VCL-2.5/managementnode/* /usr/local/vcl-2.5
16. Run install_perl_libs.pl to add any new perl library requirements:
/usr/local/vcl/bin/install_perl_libs.pl
17. Start vcld service
service vcld start
18. Make some test reservations and watch the vcld.log to verify everything is
working correctly.
tail -f /var/log/vcld.log