Skip to main content

promoting a drupal instance

solution: run my stupid script ;-)

issue:
At my small company we maintain our own Drupal hosting and content (what a pain).  Anyhow - I suggested that they utilize a "promotion" methodology whereas they do their dev/testing in a DEV/TEST environment, and then I could push the content from one environment to the other.

In this case, I have 2 environments, 2 vhosts, 2 databases, 2 etc...
test   and    www

If you run this script, it generates the command to run to go through the activity.


#!/bin/bash
# 20120224 - I don't need a script id?


TODAY=`date +%Y%m%d`
BACKUPDIR=/backups/${TODAY}
clear
echo ""
echo "You need to cut-and-paste the following output into a terminal to complete the promotion"
echo "########################################################################################"
echo ""
echo "mkdir -p ${BACKUPDIR}"


# THESE ARE JUST POINTERS TO MAKE IT EASY TO UPDATE WHICH ENVIRONMENT 
# GETS REPLICATED AND TO WHICH DIRECTORY IT SHOULD BE REPLICATED TO
SRC="test"
DEST="www"
dbPASSWORD="kissmypass"


# BACKUP THE EXISTING DATABASE(s)
echo "mysqldump -uroot -p${dbPASSWORD} --databases ${DEST} > ${BACKUPDIR}/mysqldump_${DEST}.sql "
echo "mysqldump -uroot -p${dbPASSWORD} --databases ${SRC} > ${BACKUPDIR}/mysqldump_${SRC}.sql "
echo "ls -lh ${BACKUPDIR}"


# COPY THE "web content" FIRST 
echo "service httpd stop"
echo "rm -rf /var/www/vhosts/${DEST}.example.com "
echo "cp -Rp /var/www/vhosts/${SRC}.example.com /var/www/vhosts/${DEST}.example.com "
echo "chown -R apache:apache /var/www/vhosts/; chmod -R 775 /var/www/vhosts"
echo "restorecon -RFvv /var/www/vhosts"


# UPDATE THE DATABASE CONNECTOR CONFIG TO POINT TO NEW SITE
echo "sed -i -e 's/localhost\/${SRC}/localhost\/${DEST}/g' /var/www/vhosts/${DEST}.example.com/sites/default/settings.php "
echo "sed -i -e 's/http\:\/\/${SRC}/http\:\/\/${DEST}/g' /var/www/vhosts/${DEST}.example.com/sites/default/settings.php"


echo "cp ${BACKUPDIR}/mysqldump_${SRC}.sql /tmp/mysqldump_${DEST}.sql"


# modify the SRC copy to become DEST
# THE next line may, or may not, be necessary
echo "sed -i -e 's/Database: ${SRC}/Database: ${DEST}/g' /tmp/mysqldump_${DEST}.sql"
echo "sed -i -e 's/Current Database: \`${SRC}\`/Current Database: \`${DEST}\`/g' /tmp/mysqldump_${DEST}.sql"
echo "sed -i -e 's/USE \`${SRC}\`/USE \`${DEST}\`/g' /tmp/mysqldump_${DEST}.sql"
echo "sed -i -e 's/\`${SRC}\`/\`${DEST}\`/g' /tmp/mysqldump_${DEST}.sql"


# DROP THE DATABASE {DEST}
echo "echo \"drop database ${DEST};\" | mysql -uroot -p${dbPASSWORD}"


# IMPORT the SRC Database (modified to be DEST) as the DEST Database
echo "mysql -uroot -p${dbPASSWORD} < /tmp/mysqldump_${DEST}.sql "
echo "service httpd start"
echo ""


# PROVIDE NOTES
echo "# Update the website from the admin portal"
echo "#  http://www.example.com/users/"
echo "#  Site Configuration"
echo "#       |--  Site Information"
echo "#       |--  YUI Common Settings"
echo ""


exit 0





The output will be:

You need to cut-and-paste the following output into a terminal to complete the promotion
########################################################################################


mkdir -p /backups/20120224
mysqldump -uroot -pkissmypass --databases www > /backups/20120224/mysqldump_www.sql 
mysqldump -uroot -pkissmypass --databases test > /backups/20120224/mysqldump_test.sql 
ls -lh /backups/20120224
service httpd stop
rm -rf /var/www/vhosts/www.example.com 
cp -Rp /var/www/vhosts/test.example.com /var/www/vhosts/www.example.com 
chown -R apache:apache /var/www/vhosts/; chmod -R 775 /var/www/vhosts
restorecon -RFvv /var/www/vhosts
sed -i -e 's/localhost\/test/localhost\/www/g' /var/www/vhosts/www.example.com/sites/default/settings.php 
sed -i -e 's/http\:\/\/test/http\:\/\/www/g' /var/www/vhosts/www.example.com/sites/default/settings.php
cp /backups/20120224/mysqldump_test.sql /tmp/mysqldump_www.sql
sed -i -e 's/Database: test/Database: www/g' /tmp/mysqldump_www.sql
sed -i -e 's/Current Database: `test`/Current Database: `www`/g' /tmp/mysqldump_www.sql
sed -i -e 's/USE `test`/USE `www`/g' /tmp/mysqldump_www.sql
sed -i -e 's/`test`/`www`/g' /tmp/mysqldump_www.sql
echo "drop database www;" | mysql -uroot -pkissmypass
mysql -uroot -pkissmypass < /tmp/mysqldump_www.sql 
service httpd start


# Update the website from the admin portal
#  http://www.example.com/users/
#  Site Configuration
#       |--  Site Information
#       |--  YUI Common Settings



You will also need to login to Drupal portal and update the values under System Configuration.




Comments

Popular posts from this blog

RHN Satellite Server (spacewalk) repomd.xml not found

"repomd.xml not found" If you add a channel, or if your RHN cache gets corrupted, and one of your guests complains that it cannot find repomd.xml for jb-ews-2-x86_64-server-5-rpm (for example) - you need to rebuild your repodata cache. Normally this is an automated job - which is exemplified by the fact that you have obviously built out your entire Satellite environment and never had to do any of the steps you are about to do. So - some prep work: Open 3 terminals to your Satellite Server and run: # Term 1 cd /var/cache/rhn watch "ls -l | wc -l" # Term 2 pwd cd /var/log/rhn tail -f rhn_taskomatic_daemon.log # Term 3 satellite-sync --channel=jb-ews-2-x86_64-server-5-rpm Once the satellite-sync has completed, you >should< see the count increment by one.  If you are unlucky (like me) you will not. You then need to login to the Satellite WebUI as the satellite admin user. Click on the Admin tab (at the top) Task Schedules (on the left) fin

Install RHEL 7 on old HP DL380 g5

Someone at work had been running RHEL on an HP DL380 G5 and blew it up.  After several attempts at doing an installation that made me conclude the hardware was actually bad... I kept digging for the answer. Attempt install and Anaconda could not find any disks - try a Drivers Disk (dd.img) both cciss and hpsa.   -- once we did that, when the system would reboot it would say it could not find a disk. hmmm. Boot from your installation media and interrupt the startup at grub. Add hpsa.hpsa_allow_any=1 hpsa.hpsa_simple_mode=1 to the line starting with linuxefi press CTRL-X to boot. Once the system restarts after the install, you need to once again interrupt the startup and add the line from above. After the system starts, edit /etc/default/grub and add those 2 parameters to the end of the line starting with GRUB_CMDLINE_LINUX (which likely has quiet at the end of the line currently). then run # cp /boot/grub2/grub.cfg /boot/grub2/grub.cfg.orig # grub2-mkconfig -o /boot/grub2

MOTD with colors! (also applies to shell profiles)

I'm not sure why I had never looked into this before, but this evening I became obsessed with discovering how to present different colored text in the /etc/motd. A person had suggested creating a shell script (rather than using special editing modes in vi, or something) and I agree that is the simplest way of getting this accomplished quickly. This most noteworthy portion of this script is the following: RESET="\033[0m" that puts the users shell back to the original color. I typically like a green text on black background. Also - a great reference for the different colors and font-type (underscore, etc...) https://wiki.archlinux.org/index.php/Color_Bash_Prompt I found this example on the web and I wish I could recall where so that I could provide credit to that person. #!/bin/bash #define the filename to use as output motd="/etc/motd" # Collect useful information about your system # $USER is automatically defined HOSTNAME=`uname -n` KERNEL=`un