Tuesday, December 30, 2008

how to run EBS(create snapshot) by using cron

previously I have shown you how to integrate EBS and create snapshot of that volume where EBS is running.

sometime it is necessary to take the snapshot using cron. which is very much easy just save the following code into a file. and run the with the cron job and you are done. remember that in that case you have to installed EC2-api-tools on the Ec2 instance. and need to configure all environment variable. this codes i have found from Eric Hammond's blog.



#!/usr/bin/perl -w
#
# ec2-snapshot-xfs-mysql - EBS snapshot XFS file system with MySQL database
#
# Usage:
#
# ec2-snapshot-xfs-mysql XFSMOUNTPOINT VOLUMEID
#
# Requires:
#
# Amazon EC2 API tools should be installed on the instance,
# especially /usr/local/bin/ec2-create-snapshot
#
# MySQL username and password are stored in $HOME/.my.cnf in the
# usual manner following this format:
#
# [client]
# user=MYUSERNAME
# password=MYPASSWORD


use strict;
use DBI;

BEGIN {
$ENV{PATH} = '/bin:/usr/bin:/usr/local/bin';
}

my ($mountpoint, $volume_id) = @ARGV;
die "Usage: $0 XFSMOUNTPOINT VOLUMEID" unless $mountpoint && $volume_id;

# Get the MySQL username/password from $HOME/.my.cnf and connect
my ($username, $password);
open(FH, "$ENV{HOME}/.my.cnf") or die "Unable to open .my.cnf: $!";
while ( defined (my $line = ) ) {
$username = $1 if $line =~ m%^\s*user\s*=\s*(\S+)%;
$password = $1 if $line =~ m%^\s*password\s*=\s*(\S+)%;
}
close(FH);
my $dbh = DBI->connect('DBI:mysql:;host=localhost', $username, $password);

# Flush, lock, freeze
$dbh->do(q{ FLUSH TABLES WITH READ LOCK });
my ($logfile, $position) = $dbh->selectrow_array(q{ SHOW MASTER STATUS });
system('sudo', 'xfs_freeze', '-f', $mountpoint);

# Snapshot
my $snapshot_output = `ec2-create-snapshot $volume_id`;
my ($snapshot_id) = ($snapshot_output =~ m%(snap-[0-9a-f]{8})%);

# Thaw, unlock
system('sudo', 'xfs_freeze', '-u', $mountpoint);
$dbh->do(q{ UNLOCK TABLES });

print $snapshot_id ?
"$snapshot_id (master_log_file=\"$logfile\", master_log_pos=$position)\n"
:
"snapshot FAILED\n";


In my next post "problem you may find during running the corn of EBS" you will get issues you may find during running the corn job for EBS.

Wednesday, December 10, 2008

Cron job on ROR without any third party gem and library

When you are working of a large project it is very much natural that you will need to run cron job. suppose you want to take a back up of your database on every day. or you have such a site that you have to include a recurring billing system for the members. So what you will do now ?? simple you will need a cron job to do these sort of tasks. there are couple of ways you can run cron job on ROR. but all the cases you have to use third party gems or other things. here I will show you a simple way to run cronjob. without any third party gem or library and using the linux's crontab command.


you have to make a new class which actually extend the active records base class. for an instance suppose we are going to create an invoice_generator class which actually make an invoice on the first day of every month.

Here I am making the invoice_generator.rb file under app/cron folder. you can create it some where else.

class invoice_generator < ActiveRecord::Base
invoice = Invoice.new
company = Company.find_by_id(1)
invoice << company.generate_invoice
invoice.save!


end


Note: Here I am showing only the invoice_generator.rb file not all other files. these line of code will generate the invoice for only one company.

now you can test the file from the command line by running the following command

ruby script/runner app/cron/invoice_generator.rb

now you can run the same command from the linux's crontab command
$ crontab -e

then type

* * 1 * * ruby script/runner -e production /root/sami/test/app/cron/invoice_generator.rb

Note: here my aplication folder is test and that is under /root/sami directory

Wednesday, November 12, 2008

How to create an Elastic IP and associate that IP with an Instancenah

When you create an EC2 instance, it’s by default assigned two IP addresses to that instance. One is public IP address which one is mapped with the private IP address through Network Address Translator (Nat). you can surf an instance from another instance through private IP address and from the outer world you can access with the public IP address.

But Amazon provides another type of IP address which static IP and that one is designed for dynamic cloud computing. And this IP address will remain associated with your account until you release the IP.

The main thing I liked about the elastic IP address that it will provide zero downtime when you will want to switch one instance to another instance. You will don’t have to wait for DNS to resolve the IP address. Because at any moment you can change the instance that an elastic IP address has pointed.

Now let’s have a look how can you create an elastic IP address and point an instance by that IP address.

From the EC2 command line tools run the command

ec2-allocate-address

This command will return an IP address

Address xx.xx.xx.xx

Now you have to associate this address with an EC2 instance by using the following command

Suppose your instance is i-xxxxxxxxx

    ec2-associate-address –i i-xxxxxxxxx xx.xx.xx.xx

Now your elastic IP xx.xx.xx.xx is associated with the instance i-xxxxxxxxx

If you run the following command you will see that Address xx.xx.xx.xx is pointing the instance i-xxxxxxxxx

 
        ec2-describe-addresses xx.xx.xx.xx

From now on you will be able to access that instance by you elastic IP from the outer world

If you want to disassociate the elastic IP from the instance then run the following command

       ec2-disassociate-address xx.xx.xx.xx

Now you will get new public IP address for that instance. And your elastic IP has become free to point a new instance.

Friday, August 15, 2008

How to install EC2 API tools

In my previous post I had mentioned that I will show you how to install EC2 API command line tools. This post will guide you to install EC2 tools. This is quite an easy task. Let me show you the steps

1. First you have to download the EC2 API command line tools from Amazon
2. unzip the EC2 API tools
unzip EC2-api-tools.zip

3. Now you have to set up some environment variable

export EC2_HOME=/home/lib/ec2-api-tools
(here I have unzip the EC2-api-tools to home/lib/ec2-api-tools)

export EC2_PRIVATE_KEY=/home/.ec2/pk-XXXXXXXXXXXXXXXXXXXX.pem
(this will be the path to your private key file)

export EC2_CERT=/HOME/.ec2/cert-XXXXXXXXXXXXXXXXXXXX.pem

(this will be the path to your cert file)

Note: you can directly put these lines to you ~/.bashrc file. Another thing you have to remember that EC2-command-line tools use JAVA so you have to install JAVA on the machine and have to set the JAVA_HOME path as well

Sunday, August 3, 2008

Integrating EBS(Elastic Block Storage)

Amazon AWS provides really strong support to make the application more scalable and secured. EBS is one of that support what Amazon provide.

The main two main supports that EBS will provide you as following

1. Incremental database back up

2. EBS will take the snapshot and upload it to S3. so somehow if your EC2 instance get destroyed then you can attach the volume to another EC2 instance and restore the snapshot.

Few days back I was thinking how can I take an incremental back up for a project. And thank god that our project was deployed on EC2 and Amazon has provided the EBS support. Now lets have a look how can we integrate EBS. Here I will also discuss some problem at the end what I have faced to integrate EBS.

  1. first we have to create a volume for this reason you will need to download and configure EC2 command line API tools (in my next blog i will show you how to install it)
          ec2-create-volume -z us-east-1b -s 10  
(here –z means zone, remember that this should be same for instance and volume
and –s means the size of the EBS storage in GB)


NOTE: this command will return the volume number of newly created volume take a note of that volume number , we have use it later.

  1. You can give the following command to view the details of the volume.
        ec2-describe-volumes vol-XXXXXXXX
(this number should be the returned number of the previous command)


  1. Now you have to attach the volume with the EC2 instance from which you want to take the data base backup

      ec2-attach-volume -d /dev/sdh -i i-XXXXXXX vol-XXXXXXXX 
       (here i-XXXXXXX is the instance number and vol-XXXXXXXX is the volume number)
  1. you have to log in into the EC2 instance
  1. now you have to use the following commands to install xfs which will help you to take the back up incrementally
               apt-get update && apt-get upgrade -y
apt-get install -y xfsprogs mysql-server
  1. now you have to create XFS file system and mount a directory from where volume will take the database updates for the snapshot
mkfs.xfs /dev/sdh
echo "/dev/sdh /vol xfs noatime 0 0" >> /etc/fstab
mkdir /vol
mount /vol
  1. now we have to configure MySQl to use the EBS volume
    1. stope the MySQL Server
                  /etc/init.d/mysql stop
    1. Move the existing database files to the EBS volume (My recommendation is to copy the data base it will be safe if you face any problem then you can come to current position very quickly and this is risk free)
               mkdir /vol/lib /vol/log
mv /var/lib/mysql /vol/lib/
(my recommendation : cp –rf /var/lib/mysql/* /vol/lib/ )
mv /var/log/mysql /vol/log/
(my recommendation : cp –rf /var/log/mysql/* /vol/log/ )
test -f /vol/log/mysql/mysql-bin.index &&
perl -pi -e 's%/var/log/%/vol/log/%' /vol/log/mysql/mysql-bin.index
  1. now we have to tell MySQL to look at on the mounted EBS volume and also save the configuration of EBS for future use
cat > /etc/mysql/conf.d/mysql-ec2.cnf << EOM
[mysqld]

innodb_file_per_table
datadir = /vol/lib/mysql
log_bin = /vol/log/mysql/mysql-bin.log
max_binlog_size = 1000M
log_slow_queries = /vol/log/mysql/mysql-slow.log
long_query_time = 10
EOM

Note: In my case I have to add tmpdir = /vol/tmp because I have shifted that folder on EBS.

        rsync -aR /etc/mysql /vol/
  1. now you have to start the mysql
         /etc/init.d/mysql start

Note: if MySQL gets started successfully then you can remove the previous data directory of our server

  1. now you have to take the snapshot for the mysql backup
    1. first you have to log in into mysql using your password and user name

mysql -uusername –ppassword

    1. flush the tables to disk and acquire a lock. Flush the file system to disk and freeze it. Do not exit the MySQL session or you will lose the lock and snapshot potentially inconsistent database files
FLUSH TABLES WITH READ LOCK;
SHOW MASTER STATUS;
SYSTEM xfs_freeze -f /vol
    1. now you have to create the snapshot of the current volume from you pc using ec2 command line tools
                  ec2-create-snapshot vol-XXXXXXXX 
    1. Back in the same MySQL session on the instance, unfreeze the file system, release the database lock, and you're done
                     SYSTEM xfs_freeze -u /vol
UNLOCK TABLES;
EXIT

You can describe the snapshot to see the status and to know whether it is done or not.

                  ec2-describe-snapshots snap-xxxxxx