Difference between revisions of "Aegir"

From Things and Stuff Wiki
Jump to navigation Jump to search
 
(21 intermediate revisions by the same user not shown)
Line 6: Line 6:
  
 
== Overview ==
 
== Overview ==
[http://community.aegirproject.org/dashboard Aegir] is a Drupal Distro that uses the [Hostmaster http://drupal.org/project/hostmaster] front-end to control the [http://drupal.org/project/provision Provision] module with its Drush integration. Aegir uses Drupal multi-site features to share one Drupal codebase install as a Platform which multiple Sites can be hosted on.
+
[http://community.aegirproject.org/dashboard Aegir] is a Drupal Distro that uses the [http://drupal.org/project/hostmaster Hostmaster] front-end to control the [http://drupal.org/project/provision Provision] module with its Drush integration. Aegir uses Drupal multi-site features to share one Drupal codebase install as a Platform which multiple Sites can be hosted on.
  
 
If you want to create a site for a particular Distro, you install the Distro as a Platform then create a Site on that Platform. Sites and their content can be cloned on or migrated between Platforms or pushed to spoke servers. Module dependency is managed via those loaded in the Profile of the Distro with the .make.
 
If you want to create a site for a particular Distro, you install the Distro as a Platform then create a Site on that Platform. Sites and their content can be cloned on or migrated between Platforms or pushed to spoke servers. Module dependency is managed via those loaded in the Profile of the Distro with the .make.
 +
 +
Creating a Distro requires a [[Profiles|Profile]] and [[Drush#Make|Make]] files.
  
 
* [[Wikipedia:Aegir Hosting System]]
 
* [[Wikipedia:Aegir Hosting System]]
Line 16: Line 18:
 
* [http://linuxdev.dk/book/export/html/63 Drupal 7 and Aegir server setup]
 
* [http://linuxdev.dk/book/export/html/63 Drupal 7 and Aegir server setup]
  
== Development ==
+
#aegir on freenode
* http://drupal.org/project/aegir-up
 
** http://drupalcode.org/project/aegir-up.git/blob/refs/heads/7.x-2.x:/README.md
 
  
* http://community.aegirproject.org/discuss/my-aegir-development-environment
+
=== Deployment ===
 +
See [[BOA]] - 'Barracuda, Octopus, Aegir' bash install script.
  
* [https://vimeo.com/51966643 Drupal Camp Montreal 2012 - Fearless development with Drush, Vagrant and Aegir]
+
* [http://drupal.org/project/aegir-up Aegir-up] provides a collaborative, distributed development environment, that encourages the use of Drupal best-practices. It deploys the Aegir Hosting System in a local virtual environment for development and testing. It provides all the ease-of-use of Aegir, wrapped in the convenience of Vagrant-based virtual machines. Creating sites and platforms is a matter of a click or two, while rebuilding the entire environment is a matter of minutes.
 +
** http://drupalcode.org/project/aegir-up.git/blob/refs/heads/7.x-2.x:/README.md
  
==  Dev/production workflow ==
+
* [http://community.aegirproject.org/discuss/my-aegir-development-environment My Aegir Development Environment] - ergonlogic
* [http://greenbeedigital.com.au/content/drupal-deployments-workflows-version-control-drushmake-and-aegir Drupal deployments & workflows with version control, drush_make, and Aegir] (mig5, Oct 28 2009)
+
* Vimeo: [https://vimeo.com/51966643 Drupal Camp Montreal 2012 - Fearless development with Drush, Vagrant and Aegir]
* [http://lists.aegirproject.org/pipermail/aegir/2011-January/000026.html Using drush hosting-import to auto-create your platform node (and other entities)] (mig5, Jan 11 2011) - Updated workflow on Aegir mailing list
 
* [http://www.archive.org/details/drupalconchi_day2_from_zero_to_distribution_using_features From Zero to Distribution using Features, Profiler, and Drush Make] (dimitri, March 9, 2011)
 
  
The Profiler library is installed with the .make and simplifies the Install Profile system by using a .info file to specify modules to be initialised, including site sections/etc. from the Features module, plus configuration settings via the Strongarm module. Provision initialises a site on that platform and installs the platform+site in Aegir.  
+
* http://drupal.org/project/puppet-aegir
 
+
** https://github.com/Vertice/puppet-aegir
Features and theme are stored using Git, --working-copy can be used to build a dev site then content can be migrated from live for testing. Dev platform is perfected, then rebuilt as live without --working-copy.
+
* http://drupal.org/project/puppet-drush
 
+
* https://redmine.koumbit.net/projects/puppet-apt
todo; use hosting_site_git and working-copy patch
+
* https://labs.riseup.net/code/projects/shared-common
 
 
* http://community.aegirproject.org/discuss/environments-and-site-life-cycle
 
  
 
== Tasks ==
 
== Tasks ==
Line 62: Line 60:
 
  drush @hostmaster hosting-task @platform_"$PLATFORM_NAME" verify --force --verbose
 
  drush @hostmaster hosting-task @platform_"$PLATFORM_NAME" verify --force --verbose
 
  drush user-login
 
  drush user-login
 +
 +
In Hostmaster, make sure that all sites have an associated Client, otherwise the site will be listed as available for all Clients/Users you have added.
  
 
=== Importing ===
 
=== Importing ===
Line 79: Line 79:
 
=== Migrating and updating ===
 
=== Migrating and updating ===
 
* [http://community.aegirproject.org/node/23 Migrating/upgrading and renaming websites]
 
* [http://community.aegirproject.org/node/23 Migrating/upgrading and renaming websites]
 +
 
* [http://community.aegirproject.org/migration-tips Migration Tips]
 
* [http://community.aegirproject.org/migration-tips Migration Tips]
 
* [http://community.aegirproject.org/node/1381 The best recipes for disaster and how to avoid them]
 
* [http://community.aegirproject.org/node/1381 The best recipes for disaster and how to avoid them]
* http://community.aegirproject.org/node/243
+
* [http://community.aegirproject.org/node/243 One last question re: packages]
 +
 
 +
* [http://omega8.cc/migrate-sites-between-installation-profiles-111 Migrate sites between installation profiles]
 +
 
 +
In .info;
 +
“old_short_name = new_profile_name”
 +
 
 +
"Example: your site has been created with that old Commerce Dev platform when it was using ‘commercedev’ as a machine name for its installation profile, and you want to migrate it to newer Commerce 7.x Kickstart platform, but it is using ‘commerce_kickstart’ as a machine name for its installation profile. You only need to add one line in your commerce_kickstart.info file, with “old_short_name = commercedev” (without quotes), just below “name = Commerce Kickstart” line. Then re-verify the newer Commerce Kickstart platform in Aegir and Voilà! – now you can migrate your sites from the old Commerce Dev platform to the new Commerce Kickstart platform"
 +
 
 +
----
 +
 
 +
Aegir does not manage profiles..
 +
 
 +
the following is incomplete!!
 +
 
 +
Basic core and module upgrade;
 +
* Git commit theme and push to remote
 +
* Use profiler_builder to create new distro files (info/profile/make)
 +
* Edit files (todo/missing info)
 +
* Add new set of profile files to git repo
  
To upgrade core or modules, build a new platform with the upgrades, then migrate sites to the new platform. Clone and migrate to test before.
+
 
 +
build a new platform with the upgrades, then migrate sites to the new platform. Clone and migrate to test before.
  
 
Be careful about creating additions or changes in sites/*/modules, sites/*/themes, etc. Migrate tasks will fail due to path issues.
 
Be careful about creating additions or changes in sites/*/modules, sites/*/themes, etc. Migrate tasks will fail due to path issues.
Line 92: Line 113:
  
 
OK, so what is the correct workflow for sites upgrades in Aegir? It highly depends on how you manage your code, but some general rules are always valid and we will list them below:
 
OK, so what is the correct workflow for sites upgrades in Aegir? It highly depends on how you manage your code, but some general rules are always valid and we will list them below:
 +
  
 
# Create or choose new platform.
 
# Create or choose new platform.
Line 177: Line 199:
  
 
* http://drupal.org/project/provisionacl - Drush module, granular shell access for users
 
* http://drupal.org/project/provisionacl - Drush module, granular shell access for users
 +
 +
=== Managing workflow ===
 +
* http://drupal.org/project/hosting_queue_runner - tasks are run as soon as possible instead of waiting for a cron run. This makes Aegir appear much more responsive. [http://www.computerminds.co.uk/articles/aegir-tasks-daemon] - now in Aegir core
 +
 +
* https://github.com/computerminds/aegir_make_working_copy - provides git working copy option un hostmaster gui for dev sites. - '''broken''' [http://drupal.org/node/1260066]
 +
 +
* http://drupal.org/project/hosting_site_git - hostmaster+provision
 +
* http://drupal.org/project/provision_git - backend only
 +
 +
* https://drupal.org/project/hosting_platform_git
 +
* https://drupal.org/project/provision_platform_git
 +
 +
* http://drupal.org/project/kplatforms
 +
** http://drupalcode.org/project/kplatforms.git/tree/refs/heads/7.x-2.x
 +
 +
* [http://drupal.org/project/hosting_features Hosting Features] - provides a Task to Hostmaster that provides integration with a site's Features. It is currently in development but works for the most important task: Update & Commit Features
 +
 +
* [https://github.com/reload/aegir-project aegir-projec] - A project-abstraktion on top of platforms and sites
 +
 +
==== DevShop ====
 +
* http://drupal.org/project/devshop
 +
 +
* http://drupal.org/project/devshop_provision
 +
* http://drupal.org/project/devshop_hosting
  
 
=== Backups ===
 
=== Backups ===
Line 194: Line 240:
 
* http://drupalcode.org/project/hosting_remote_import.git/blob/refs/heads/6.x-1.x:/README.txt
 
* http://drupalcode.org/project/hosting_remote_import.git/blob/refs/heads/6.x-1.x:/README.txt
  
=== Managing workflow ===
+
== Docker ==
* http://drupal.org/project/hosting_queue_runner - tasks are run as soon as possible instead of waiting for a cron run. This makes Aegir appear much more responsive. [http://www.computerminds.co.uk/articles/aegir-tasks-daemon] - now in Aegir core
+
* https://github.com/DominicBoettger/docker-aegir-mariadb
 +
 
 +
== Services ==
 +
* https://aegir.koumbit.net/
 +
* http://www.koumbit.org/en/services/AegirVPS
 +
** http://www.koumbit.org/en/articles/aegirvps-new-drupal-hosting-solution
 +
 
 +
* http://omega8.cc
 +
 
 +
== BOA ==
 +
Barracuda Octopus Aegir
 +
 
 +
* https://github.com/omega8cc/boa - meta-installer for an easy Barracuda + Octopus + Aegir install and upgrade on the high performance LEMP stack.
 +
 
 +
* All libraries & tools required to install and run Nginx based Aegir system.
 +
* Latest release of MariaDB 5.5 or 10.0 database server with Chive manager.
 +
* Latest version of Nginx web server.
 +
* PHP-FPM 5.6, 5.5, 5.4, 5.3 - multi-install mode, configurable per Octopus.
 +
* PHP extensions: Zend OPcache, PHPRedis, UploadProgress, MailParse and ionCube.
 +
* Fast Redis Cache with DB auto-failover for all 6.x and 7.x platforms.
 +
* Fast Redis Lock support with DB auto-failover for all 6.x and 7.x platforms.
 +
* Fast proxy DNS server (pdnsd) with permanent caching.
 +
* Limited Shell, SFTP and FTPS separate accounts per Octopus instance.
 +
* Limited Shell, SFTP and FTPS accounts per Aegir Client with per site access.
 +
* Drush access on command line in all shell accounts.
 +
* Drush Make access on command line for main shell account only.
 +
* Support for New Relic monitoring with per Octopus instance license key.
 +
* Solr 4 cores can be added/updated/deleted via site level INI settings.
 +
* HTTPS access with self-signed certificate for all hosted sites.
 +
* Magic Speed Booster cache, working like a Boost + AuthCache, but per user.
 +
* Entry level XSS built-in protection on the Nginx level.
 +
* Firewall csf/lfd integrated with Nginx abuse guard.
 +
* PHP errors debugging, including WSOD, enabled on the fly on dev. aliases.
 +
* Boost, AdvAgg, Domain Access and Drupal for Facebook built-in support.
 +
* Built-in collection of useful modules available in all platforms.
 +
* Autonomous Maintenance & Auto-Healing scripts in /var/xdrago.
 +
* Every 10 seconds uptime/self-healing local monitoring.
 +
* Automated, rotated daily backups for all databases in /data/disk/arch/sql.
 +
 
 +
Optional:
 +
* Compass Tools.
 +
* SPDY Nginx support.
 +
* PFS (Perfect Forward Secrecy) support in Nginx.
 +
* HHVM support - see docs/HHVM.txt for details.
 +
* MultiCore Apache Solr 1.4.1 with Jetty 7 - see docs/SOLR.txt for details.
 +
* MultiCore Apache Solr 3.6.2 with Jetty 8 - see docs/SOLR.txt for details.
 +
* MultiCore Apache Solr 4.2.0 with Jetty 8 or Jetty 9 on Precise and Wheezy.
 +
* New Relic Apps Monitor with per Octopus license and per Site reporting.
 +
* Image Optimize toolkit binaries.
 +
* FFmpeg support.
 +
* Bind9 DNS server.
 +
* Webmin Control Panel.
 +
* SQL Buddy database manager.
 +
* Collectd server monitor.
 +
* LDAP Nginx support via third-party module (experimental).
 +
* MongoDB driver for PHP 5.3 (experimental).
 +
* GEOS extension for PHP 5.3 (experimental).
 +
 
 +
=== Documentation ====
 +
* http://bit.ly/boa-docs
 +
 
 +
* [https://github.com/omega8cc/boa/blob/master/docs/README.txt README]
 +
* [https://github.com/omega8cc/boa/blob/master/docs/INSTALL.txt INSTALL]
 +
 
 +
Aegir master install goes in /var/aegir. Not as tuned and featured as the Octopus Aegir install. Best practice is to use Octopus for production.
 +
 
 +
* [http://omega8.cc/updates Updates]
 +
* [http://bit.ly/newboa CHANGELOG]
 +
* [https://github.com/omega8cc/boa/blob/master/docs/UPGRADE.txt UPGRADE]
 +
 
 +
* [https://github.com/omega8cc/boa/blob/master/docs/REMOTE.txt REMOTE]
 +
* [https://github.com/omega8cc/boa/blob/master/docs/SSL.txt SSL]
 +
* [https://github.com/omega8cc/boa/blob/master/docs/SOLR.txt SOLR]
 +
 
 +
* [http://drupalcode.org/project/barracuda.git/blob/HEAD:/aegir/tools/BOND.sh.txt BOND.sh] - tuning script
 +
 
 +
* [http://omega8.cc/how-to-disable-all-caching-and-aggregation-115 How to disable all caching and aggregation?] - Using "dev.*" subdomain in site alias disabled hardcoded performance. Also for PHP errors and logging.
 +
 
 +
* [http://omega8.cc/are-there-any-specific-good-habits-to-learn-116 Are there any specific good habits to learn?]
 +
* [https://omega8.cc/your-drupal-site-upgrade-safe-workflow-298 Your Drupal Site Upgrade -- Safe Workflow]
 +
 
 +
* [http://omega8.cc/the-best-recipes-for-disaster-139 The best recipes for disaster]
 +
* [http://drupal.org/node/1326494 What are best practices for BOA file cleanup?]
 +
 
 +
* https://github.com/omega8cc/boa/blob/1c04aced13507cf7364166b690dad09afe2da919/CHANGELOG.txt#L2907 - Drush restrictions
 +
 
 +
* [http://drupal.org/node/1469382 Are bug fixes/patches applied to the current BOA stable release?]
 +
 
 +
 
 +
=== Configuration ===
 +
.barracuda.conf xtra shortcodes [https://groups.drupal.org/node/163784]
 +
PDS --- fast DNS cache server (pdnsd) (default)
 +
BND --- Bind9 DNS Server
 +
SLR --- MultiCore Apache Solr Tomcat
 +
CHV --- Chive DB Manager (default)
 +
BDD --- SQL Buddy DB Manager
 +
CGP --- Collectd Graph Panel
 +
WMN --- Webmin Control Panel
 +
CSF --- csf/lfd Firewall (default)
 +
FTP --- ??? (default)
 +
 
 +
Nginx configuration layout;
 +
/etc/nginx/nginx.conf                                                                                                                                               
 +
 
 +
<pre>user www-data;
 +
worker_processes  4; 
 +
pid /var/run/nginx.pid;
 +
 
 +
events {
 +
  multi_accept on;
 +
}
 +
 
 +
http {
 +
  default_type application/octet-stream;
 +
  gzip on;
 +
  gzip_disable "msie6";
 +
  keepalive_timeout 65;
 +
  sendfile on;
 +
  tcp_nodelay on;
 +
  tcp_nopush on;
 +
  types_hash_max_size 8192;
 +
  include /etc/nginx/mime.types;
 +
  include /etc/nginx/conf.d/*.conf;
 +
  include /etc/nginx/sites-enabled/*;
 +
}</pre>
 +
 
 +
* /etc/nginx/nginx.conf
 +
** /etc/nginx/conf.d/aegir.conf -> /var/aegir/config/nginx.conf -> /var/aegir/config/server_master/nginx.conf barracuda specific
 +
*** /var/aegir/config/server_master/nginx/pre.d/*;
 +
**** extra_ip.conf
 +
**** extra_ip_ssl.conf
 +
**** nginx_speed_purge.conf
 +
**** nginx_wild_ssl.conf
 +
*** /var/aegir/config/server_master/nginx/platform.d/*;
 +
**** /data/disk/o1/config/o1.nginx.conf - octopus specific
 +
***** /data/disk/o1/config/server_master/nginx/vhost.d/*; - o1 hosted Drupal sites
 +
*** /var/aegir/config/server_master/nginx/vhost.d/*; - master and admin tool sites
 +
**** chive.master.purple.thingsandstuff.org
 +
**** master.purple.thingsandstuff.org
 +
*** /var/aegir/config/server_master/nginx/post.d/*; - empty
 +
 
 +
=== Install and upgrade ===
 +
[http://drupalcode.org/project/octopus.git/tree/bec26254adc3ab3784c92e6ed888242dbe874d44:/aegir/tools/system xdrago] cron runs tool helper scripts
 +
 
 +
*  [http://drupalcode.org/project/octopus.git/blob/bec26254adc3ab3784c92e6ed888242dbe874d44:/aegir/tools/system/usage.sh usage.sh]
 +
 
 +
See also [http://drupalcode.org/project/barracuda.git/blob/HEAD:/docs/HINTS.txt HINTS.txt]
 +
 
 +
Do not use apt to upgrade. Upgrading got easier with BOA 2. See [http://drupalcode.org/project/barracuda.git/blob_plain/HEAD:/docs/UPGRADE.txt UPGRADE.txt] for full details.
  
* https://github.com/computerminds/aegir_make_working_copy - provides git working copy option un hostmaster gui for dev sites. - '''broken''' [http://drupal.org/node/1260066]
 
  
* http://drupal.org/project/hosting_site_git - hostmaster+provision
+
# Download and run BOA Meta Installer.
* http://drupal.org/project/provision_git - backend only
+
wget -q -U iCab http://files.aegir.cc/BOA.sh.txt
 +
bash BOA.sh.txt
  
* [http://drupal.org/project/hosting_features Hosting Features] - provides a Task to Hostmaster that provides integration with a site's Features. It is currently in development but works for the most important task: Update & Commit Features
+
Will honour settings in;
 +
/root/.barracuda.cnf
 +
/root/.o1.octopus.cnf
 +
/root/.o2.octopus.cnf
  
==== DevShop ====
+
# To upgrade system and Aegir Master Instance to Stable
* http://drupal.org/project/devshop
+
barracuda up-stable
 +
 +
To upgrade system and Aegir Master Instance to HEAD
 +
barracuda up-head
 +
 +
#To upgrade selected Aegir Satellite Instance to Stable
 +
octopus up-stable o1
 +
 +
# To upgrade *all* Aegir Satellite Instances to Stable
 +
octopus up-stable all
  
* http://drupal.org/project/devshop_provision
+
# To upgrade selected Aegir Satellite Instance to HEAD
* http://drupal.org/project/devshop_hosting
+
octopus up-head o1
 +
 +
# To upgrade *all* Aegir Satellite Instances to HEAD
 +
octopus up-head all
  
== Stack ==
+
See also [[Security#csf.2Flfd]]
Relating to installing Aegir on bare servers.
 
  
See: [[BOA]] - 'Barracuda, Octopus, Aegir' bash install script.
+
* https://github.com/omega8cc/boa/issues/500 - Lets Encrypt (free SSL)
  
Also;
 
* http://drupal.org/project/puppet-aegir
 
* http://drupal.org/project/puppet-drush
 
* https://redmine.koumbit.net/projects/puppet-apt
 
* https://labs.riseup.net/code/projects/shared-common
 
* https://github.com/Vertice/puppet-aegir
 
  
== Services ==
+
=== Caching ===
* https://aegir.koumbit.net/
+
* [http://redis.io/ Redis] is an open source, advanced key-value store. It is often referred to as a data structure server since keys can contain strings, hashes, lists, sets and sorted sets.
* http://www.koumbit.org/en/services/AegirVPS
 
** http://www.koumbit.org/en/articles/aegirvps-new-drupal-hosting-solution
 
  
* http://omega8.cc
+
New system uses only Redis cache and the same configuration for all Drupal 6 and Drupal 7 platforms. This new system doesn't require any extra module to be enabled in any site. Complete integration is already enabled by default for every platform/site installed by default and for every custom platform as before - the next day after first site on the custom platform has been created. You can disable this caching layer using the same modules/cache/NO.txt control file as before. While there is just one cache engine (Redis) used, there is also an automatic, instant failover to standard database caching, just in case Redis is not available for some reason. You can also disable Redis cache on the fly for debugging by adding ?noredis=1 to any URL.

Latest revision as of 21:27, 25 April 2020

two thirds-way through a big refactor. todo; move things from here to other places.

Aegir is a Drupal distribution for managing Drupal site provision and hosting.

Overview

Aegir is a Drupal Distro that uses the Hostmaster front-end to control the Provision module with its Drush integration. Aegir uses Drupal multi-site features to share one Drupal codebase install as a Platform which multiple Sites can be hosted on.

If you want to create a site for a particular Distro, you install the Distro as a Platform then create a Site on that Platform. Sites and their content can be cloned on or migrated between Platforms or pushed to spoke servers. Module dependency is managed via those loaded in the Profile of the Distro with the .make.

Creating a Distro requires a Profile and Make files.

#aegir on freenode

Deployment

See BOA - 'Barracuda, Octopus, Aegir' bash install script.

  • Aegir-up provides a collaborative, distributed development environment, that encourages the use of Drupal best-practices. It deploys the Aegir Hosting System in a local virtual environment for development and testing. It provides all the ease-of-use of Aegir, wrapped in the convenience of Vagrant-based virtual machines. Creating sites and platforms is a matter of a click or two, while rebuilding the entire environment is a matter of minutes.

Tasks

Creating

Platform

Use a build make file to call the main make (possibly on-top of a base profile).

Base .build file that Git pulls the base development distro .make and .profile (and .info for Profiler lib).

Behind the scenes pseudo;

drush make --working-copy "$PROJECT_MAKE" "$PLATFORM_PATH"
drush provision-save @platform_PlatformName --root="$PLATFORM_PATH" --context_type=platform
drush @hostmaster hosting-import @platform_PlatformName

from aegir;

/usr/local/bin/php /var/aegir/drush/drush.php --php='/usr/local/bin/php'  --context_type='platform' --master_url='http://aegirmaster.example.org/' --root='/var/aegir/platforms/exampleplatform' --server='@server_master' --web_server='@server_master' --makefile='https://raw.github.com/so/me/build.make' --make_working_copy='1' provision-save '@platform_ExamplePlatformDec02' --backend

Site

Things to remember for a site build in hostmaster;

  • Don't forget full domain name!
  • Create dev.* alias for BOA cache-busting

Behind the scenes;

drush provision-save "@$SITE_DOMAIN" --uri="$SITE_DOMAIN" --context_type='site' --platform="@platform_PlatformName" --profile="$PROJECT_NAME"
drush "@$SITE_DOMAIN" provision-install
drush @hostmaster hosting-task @platform_"$PLATFORM_NAME" verify --force --verbose
drush user-login

In Hostmaster, make sure that all sites have an associated Client, otherwise the site will be listed as available for all Clients/Users you have added.

Importing

Cloning

Aegir provides an easy method of making entire copies of a site. This includes the actual site files, modules and so on, as well as a copy of the actual database. This feature is called 'Clone' in Aegir, because it is a method of duplicating a site with a new URL or 'site name'.

The feature is very closely linked to the Migrate feature because it is almost the same, except that rather than move the site, it leaves the existing site in place and just copies it to a new name. For this reason, enabling the Clone feature also enables the Migrate feature.

Migrating and updating

In .info;

“old_short_name = new_profile_name”

"Example: your site has been created with that old Commerce Dev platform when it was using ‘commercedev’ as a machine name for its installation profile, and you want to migrate it to newer Commerce 7.x Kickstart platform, but it is using ‘commerce_kickstart’ as a machine name for its installation profile. You only need to add one line in your commerce_kickstart.info file, with “old_short_name = commercedev” (without quotes), just below “name = Commerce Kickstart” line. Then re-verify the newer Commerce Kickstart platform in Aegir and Voilà! – now you can migrate your sites from the old Commerce Dev platform to the new Commerce Kickstart platform"


Aegir does not manage profiles..

the following is incomplete!!

Basic core and module upgrade;

  • Git commit theme and push to remote
  • Use profiler_builder to create new distro files (info/profile/make)
  • Edit files (todo/missing info)
  • Add new set of profile files to git repo


build a new platform with the upgrades, then migrate sites to the new platform. Clone and migrate to test before.

Be careful about creating additions or changes in sites/*/modules, sites/*/themes, etc. Migrate tasks will fail due to path issues.

"No, really, don't use sites/domain-name/modules for anything and save yourself headaches and frustration."

...

OK, so what is the correct workflow for sites upgrades in Aegir? It highly depends on how you manage your code, but some general rules are always valid and we will list them below:


  1. Create or choose new platform.
  2. Upload all your contrib modules and themes to the new target platform.
  3. Re-verify the target platform in Aegir.
  4. Clone your live site with some working subdomain in the old platform.
  5. Re-verify old platform and also just cloned site.
  6. Migrate cloned site to the new platform.
  7. Check if the cloned site works without any issues.
  8. If the step 7 above works, you can safely migrate also the live site.

Troubleshooting

If a site install task fails, and the build make/info/profile cannot be fixed and the Install and Verify run again to completion, there is no clean way to remove it.

Instead;

  • Delete failed site install task item
  • Delete failed site item
  • Remove failed site table from DB

Provision

Troubleshooting

/usr/bin/php /var/aegir/drush/drush.php @hostmaster hosting-dispatch
/usr/bin/php /var/aegir/drush/drush.php -y @hostmaster vset hosting_queue_tasks_frequency 1
/usr/bin/php /var/aegir/drush/drush.php @hostmaster hosting-task 1234 --verbose --debug

Run hostmaster tasks with debug

/usr/bin/php /var/aegir/drush/drush.php @hostmaster hosting-cron --verbose --debug

Restore backup;

drush @mysite.com provision-restore /var/aegir/backup/example.com...tgz

Older restore method(?)

drush @hostmaster provision-deploy /var/aegir/backup/example.com...tgz

Pause task cron;

drush @hostmaster hostmaster-pause

See also fimafeng, my older bash provision script for Aegir/Drush.

Remote

To sort with Drush#deployment

Proper master hub remote spoke Aegir requires remote Aegir user, Apache config changes and apache2ctl sudoers for restarting, so shared hosting environments are generally out of the question currently.

Saying that, one can manually create Drush site aliases with the relevant details to manually rsync and sql-sync.

Export

Aegir contrib

Access

Managing workflow

  • Hosting Features - provides a Task to Hostmaster that provides integration with a site's Features. It is currently in development but works for the most important task: Update & Commit Features
  • aegir-projec - A project-abstraktion on top of platforms and sites

DevShop

Backups

Remote import

Migration between Aegirs

Remote Import goes on receiving server, SSH key from server site is coming from

Docker

Services

BOA

Barracuda Octopus Aegir

  • All libraries & tools required to install and run Nginx based Aegir system.
  • Latest release of MariaDB 5.5 or 10.0 database server with Chive manager.
  • Latest version of Nginx web server.
  • PHP-FPM 5.6, 5.5, 5.4, 5.3 - multi-install mode, configurable per Octopus.
  • PHP extensions: Zend OPcache, PHPRedis, UploadProgress, MailParse and ionCube.
  • Fast Redis Cache with DB auto-failover for all 6.x and 7.x platforms.
  • Fast Redis Lock support with DB auto-failover for all 6.x and 7.x platforms.
  • Fast proxy DNS server (pdnsd) with permanent caching.
  • Limited Shell, SFTP and FTPS separate accounts per Octopus instance.
  • Limited Shell, SFTP and FTPS accounts per Aegir Client with per site access.
  • Drush access on command line in all shell accounts.
  • Drush Make access on command line for main shell account only.
  • Support for New Relic monitoring with per Octopus instance license key.
  • Solr 4 cores can be added/updated/deleted via site level INI settings.
  • HTTPS access with self-signed certificate for all hosted sites.
  • Magic Speed Booster cache, working like a Boost + AuthCache, but per user.
  • Entry level XSS built-in protection on the Nginx level.
  • Firewall csf/lfd integrated with Nginx abuse guard.
  • PHP errors debugging, including WSOD, enabled on the fly on dev. aliases.
  • Boost, AdvAgg, Domain Access and Drupal for Facebook built-in support.
  • Built-in collection of useful modules available in all platforms.
  • Autonomous Maintenance & Auto-Healing scripts in /var/xdrago.
  • Every 10 seconds uptime/self-healing local monitoring.
  • Automated, rotated daily backups for all databases in /data/disk/arch/sql.

Optional:

  • Compass Tools.
  • SPDY Nginx support.
  • PFS (Perfect Forward Secrecy) support in Nginx.
  • HHVM support - see docs/HHVM.txt for details.
  • MultiCore Apache Solr 1.4.1 with Jetty 7 - see docs/SOLR.txt for details.
  • MultiCore Apache Solr 3.6.2 with Jetty 8 - see docs/SOLR.txt for details.
  • MultiCore Apache Solr 4.2.0 with Jetty 8 or Jetty 9 on Precise and Wheezy.
  • New Relic Apps Monitor with per Octopus license and per Site reporting.
  • Image Optimize toolkit binaries.
  • FFmpeg support.
  • Bind9 DNS server.
  • Webmin Control Panel.
  • SQL Buddy database manager.
  • Collectd server monitor.
  • LDAP Nginx support via third-party module (experimental).
  • MongoDB driver for PHP 5.3 (experimental).
  • GEOS extension for PHP 5.3 (experimental).

Documentation =

Aegir master install goes in /var/aegir. Not as tuned and featured as the Octopus Aegir install. Best practice is to use Octopus for production.


Configuration

.barracuda.conf xtra shortcodes [3]

PDS --- fast DNS cache server (pdnsd) (default)
BND --- Bind9 DNS Server
SLR --- MultiCore Apache Solr Tomcat
CHV --- Chive DB Manager (default)
BDD --- SQL Buddy DB Manager
CGP --- Collectd Graph Panel
WMN --- Webmin Control Panel
CSF --- csf/lfd Firewall (default)
FTP --- ??? (default)

Nginx configuration layout; /etc/nginx/nginx.conf

user www-data;
worker_processes  4;  
pid /var/run/nginx.pid;

events {
  multi_accept on; 
}

http {
  default_type application/octet-stream;
  gzip on; 
  gzip_disable "msie6";
  keepalive_timeout 65; 
  sendfile on; 
  tcp_nodelay on; 
  tcp_nopush on; 
  types_hash_max_size 8192;
  include /etc/nginx/mime.types;
  include /etc/nginx/conf.d/*.conf;
  include /etc/nginx/sites-enabled/*;
}
  • /etc/nginx/nginx.conf
    • /etc/nginx/conf.d/aegir.conf -> /var/aegir/config/nginx.conf -> /var/aegir/config/server_master/nginx.conf barracuda specific
      • /var/aegir/config/server_master/nginx/pre.d/*;
        • extra_ip.conf
        • extra_ip_ssl.conf
        • nginx_speed_purge.conf
        • nginx_wild_ssl.conf
      • /var/aegir/config/server_master/nginx/platform.d/*;
        • /data/disk/o1/config/o1.nginx.conf - octopus specific
          • /data/disk/o1/config/server_master/nginx/vhost.d/*; - o1 hosted Drupal sites
      • /var/aegir/config/server_master/nginx/vhost.d/*; - master and admin tool sites
        • chive.master.purple.thingsandstuff.org
        • master.purple.thingsandstuff.org
      • /var/aegir/config/server_master/nginx/post.d/*; - empty

Install and upgrade

xdrago cron runs tool helper scripts

See also HINTS.txt

Do not use apt to upgrade. Upgrading got easier with BOA 2. See UPGRADE.txt for full details.


# Download and run BOA Meta Installer.
wget -q -U iCab http://files.aegir.cc/BOA.sh.txt
bash BOA.sh.txt
Will honour settings in;
/root/.barracuda.cnf
/root/.o1.octopus.cnf
/root/.o2.octopus.cnf
# To upgrade system and Aegir Master Instance to Stable
barracuda up-stable

To upgrade system and Aegir Master Instance to HEAD
barracuda up-head

#To upgrade selected Aegir Satellite Instance to Stable
octopus up-stable o1

# To upgrade *all* Aegir Satellite Instances to Stable
octopus up-stable all
# To upgrade selected Aegir Satellite Instance to HEAD
octopus up-head o1

# To upgrade *all* Aegir Satellite Instances to HEAD
octopus up-head all

See also Security#csf.2Flfd


Caching

  • Redis is an open source, advanced key-value store. It is often referred to as a data structure server since keys can contain strings, hashes, lists, sets and sorted sets.

New system uses only Redis cache and the same configuration for all Drupal 6 and Drupal 7 platforms. This new system doesn't require any extra module to be enabled in any site. Complete integration is already enabled by default for every platform/site installed by default and for every custom platform as before - the next day after first site on the custom platform has been created. You can disable this caching layer using the same modules/cache/NO.txt control file as before. While there is just one cache engine (Redis) used, there is also an automatic, instant failover to standard database caching, just in case Redis is not available for some reason. You can also disable Redis cache on the fly for debugging by adding ?noredis=1 to any URL.