Many times, your maven build fails because a unit test fails. SO, if want to debug the test you have 2 options
a) Run the test from eclipse> This is good for simple apps that do not need depend on 3rd party services . But, if your app relies on other 3rd party services starting up, chances are you have already configured maven to start those services when the unit tests are running. Now, if you have to run the same tests in eclipse, you will have to configure eclipse to start those services, and probably you will have to start the services from eclipse manually. Some developers choose this way, and there's nothing wrong with it, if it's easier for you to start everything from eclipse. However, remember that if you are working in a large team, other team members might change the configuration of the 3rd party servers in maven, and you are responsible for making sure the environment that you setup in eclipse reflects the environment in maven
b) Run the test from maven and remotely connect to maven from eclipse. If you want to run particulat test do like this
mvn -Dmaven.surefire.debug -Dtest= nameof test class test
This will run the test phase (along with all the other related phases), and just before it runs the surefire plugin, it will suspend execution and wait for debugger to connect on port 5005. Go to eclipse and srtup a remote debug configuration to port 5005 and start debugging. Your test will run, and stop at any breakpoints
Friday, September 4, 2009
Friday, July 31, 2009
Creating a Fedora machine with MYSQL on Amazon
- Login to AWS console
- Start a machine with AMI:- ami-2547a34c
- Make sure required ports are open in the security group that you used
- MYSQL:-3306
- SSH:- 22
- After the server is up, login to the server using ssh
- Install the mysql server :-
yum -y install mysql mysql-devel mysql-server
- start the server:-
/etc/init.d/mysqld start
- By default, mysql doesn;'t provide any password for root. This is dangerous, so first thing you do is set a password:-
mysqladmin -u root password
- By default root has permissions to only login from localhost. So, give permission to root to login from anywhere:-
mysql -u root -p
grant all on *.* to root@'%'
Thursday, July 23, 2009
Creating a Paid LINUX AMI
The Amazon documentation is here, but all examples don't work well. This blog is better. Most of the information below is reproduced from the above Blog. Here I am listing out all the things you need to do assuming you are creating an image from scratch
First you need the following
First you need the following
- User name/password of your Amazon acct
- Your account number. This is of the form of XXXX-XXXX-XXX. You can get it from the mail that Amazon sent you when you created the account or from your access identifiers page
- AWS access key: Looks like this AKIAIJAEHQEJP1PCA4IL. You can get it from the mail that Amazon sent you when you created the account or from your access identifiers page
- Secret key : Looks like this 5dgaxfawHIkan63XHAKDFJ3Jsdmfg9HAS. You can get it from the mail that Amazon sent you when you created the account or from your access identifiers page
- AMI Id of the starter image that you want to create your image from
- Dev pay product code. If you don;t have this, sing up for devpay using your amazon account. You will get a product code at the end
- Login to your access identifiers page
- If you haven't already, generate a new private key and certificate. Download this private key and certificate to your local machine. The private key will be named pk-XXXXXX.pem, The certificate is named cert-XXXXXX.pem. Protect these 2 files and do not share them publicly. These 2 files have private keys to your account. Also, if you are managing multiple Amazon accounts, make sure you don't mix the keys together
- Login to AWS console
- Create a key pair. Download the private key for the key pair into your local machine
- Start an instance using the starter AMI using the key pair that you just created
- SSH into this instance. (If you are using PUTTY, follow these instructions to create a ppk file)
- Create a directory named /mnt/bundle. We will create the image here. Also we will store your private keys here. It is important that the image be created in /mnt since by default /mnt is excluded from bundling. You don;t want your private keys to be bundled into the image
- copy the private key and certificate file to /mnt/bundle (If you are on windows use WinSCP)
- Bundle your image
cd /mnt/bundle\
ec2-bundle-vol -k pk-AAA...ZZZ.pem -c cert-AAA...ZZZ.pem -u -d /mnt/bundle/ -p - Wait. This will take some time. It will create a file named
.manifest.xml, along with files named .part.nn - Login to S3 organizer
- Create a bucket
- Upload the image to the bucket
ec2-upload-bundle -b
-m .manifest.xml -a -s - Wait. The image will be copied over to the bucket
- Register this image as an AMI using the AWS console. At this point your image is bundled. But no one else except you can use it. Now you have to turn this into a paid AMI
- go back to SSH console. You might need to setup the following envioroment variables in order to run the following commands
EC2_HOME
JAVA_HOME - Run the following command to associate your AMI with your devpay product
ec2-modify-image-attribute
--product-code -K pk-XXXX.pem -C cert-XXX.pem
Attaching and detaching a MYISAM datbase
Let's say you have a huge MYSQL database in one MYSQL instance. You want to make a copy of this database in another MYSQL instance. There are several ways you can do a copy
1) Export the database:- Use Mysqldump. Basically, this creates a huge SQL file that contains all the SQL statements for creating and populating data into the database. This way is good for creating empty starter databases, because you can easily change the schema by changing the SQL. A good tutorial is here
2) Just copy the database:- This works only for ISAM tables.
First a short background on how MYSQL stores data:- If you look into your MYSQL data folder, you will see that there is a folder for every database in the MYSQL instance. This folder has 3 files for every table in the database
So, this is how you detach and attach the database from one instance to another:- You just copy the folder that holds the database to the data folder of the instance you are attaching the database to. That's it! You don't even have to restart MYSQL.
1) Export the database:- Use Mysqldump. Basically, this creates a huge SQL file that contains all the SQL statements for creating and populating data into the database. This way is good for creating empty starter databases, because you can easily change the schema by changing the SQL. A good tutorial is here
2) Just copy the database:- This works only for ISAM tables.
First a short background on how MYSQL stores data:- If you look into your MYSQL data folder, you will see that there is a folder for every database in the MYSQL instance. This folder has 3 files for every table in the database
- frm table - I think this file contains the schema of the table
- myd table - for an ISAM table, this file holds the data. A InnodDB table doesn;t have any data in this file. The data is stored in a seperate file outside of the folder
- myi table - this file holds the indexes
So, this is how you detach and attach the database from one instance to another:- You just copy the folder that holds the database to the data folder of the instance you are attaching the database to. That's it! You don't even have to restart MYSQL.
Subscribe to:
Posts (Atom)