Friday, November 27, 2009

My droid eye verizon is blogged about :P

Android Application Top 10 Countdown – Week Ending 11/14/2009 | AndroidGuys
4 – Droid Eye Verizon
Price: Free
Description: This is a silly application to display the Motorola red Droid. It does not do anything else.
Thoughts: For those of us stuck with ‘Mo we can download this. It’s a picture of the red Droid, nothing more, nothing less. At least its free.


Wednesday, November 18, 2009

How to add ringtones to your DROID

Motorola Owners' Forum: DROID : How do I transfer ringtones,...
My old LG-8300 was fine. I had some neat ringtones in there that I garnered from far and wide and wanted to put them in my Droid. Since no manual came with my droid other the thiny fold-out sheet and the built in help in the droid just shows you how to use the keyboard, I was wondeing how to xfer the rintones to my droid. In my LG I had them all on the micro-SD card. Droid has one too- but where is it? The fold-out sheet doesb't tell you! Well, I believe you have to take the battery out to get to it. OK, I can "mount" the droid to my confuser so I copied the contents of my LG microSD card to the confuser. Did some tedious search on-line and found this:



"If you already have music files you'd like to use for ringtones, alarms, notifications, etc. Connect your device to your PC, on the device, got to USB, then mount the SD card. Now on the root of SD card create the following folders by type, they are as follows:

Notifications: media/audio/notifications
Ringtones: media/audio/ringtones
Alarms: media/audio/alarms"



In better terms, on the Droid SD card create a directory called "media". Then in the media dir create a subdir called "audio". Then in the audio dir create subdirectories called "notifications", "ringtones", and "alarms".



The directories in my old LG sd card that had data in them were:

my_flix (videos)

my_pix (pictures)

ringers (ringtones)



Sooooo, I copied the ringtones to the new ringtones dir on the Droid SD card. I also created a new dir called Pix and one called Flix and copied my pix and flix to them. I'll sort that out later when I have time. Unmounted the Droid. Checked it out and all my ringtones are available without me doing anything further. I set up some contacts with the new ringtones and they are working fine.



Just thought I would pass this on. Hope it is useful to someone. (Thanks to Jared elsewhere on this thread for the initial info!)


Tuesday, November 10, 2009

1024x480 display! nuts!

Engadget
And from Softbank:

* Sharp AQUOS Mobile FULLTOUCH 941SH: All we need to say about this one is "4-inch 1024 x 480 display," which, as you might be able to imagine, is a world's first.
* Sharp AQUOS Mobile 943SH: Dual one-seg tuners let you watch one program and record another, and a mention of transferring Blu-ray content has us thinking that Managed Copy is along for the ride.
* Toshiba dynapocket X02T: Remember how NTT DoCoMo had previously gotten the TG01 as the T01A? Yeah, well, now it's Softbank's turn -- and this time, it's called the X02A. Not much more to it than that.
* Samsung X01SC: This looks to be a localized version of AT&T's Samsung Jack, of all phones, meaning that it's a Windows Mobile 6.5 Standard phone (no touchscreen) with a QVGA display and portrait QWERTY keyboard.
* Sharp 942SH KT: No lineup would be complete without the obligatory Hello Kitty marketing tie-in, and the 942SH KT does the honors this time around with a black shell featuring stylized pink text and graphics.
* Samsung OMNIA VISION 940SC: Samsung's now-famous OMNIA brand comes to Softbank on the wings of a 3.5-inch AMOLED display, one-seg tuner, and kickstand for desktop viewing.
* Sharp Jelly Beans 840SH: We don't think you'd want to try eating it, but the 840SH comes in seven colors -- hence the name, we think.
* Android: The simply-named Android runs -- you guessed it -- Android with a 3.7 inch AMOLED display and 1GHz Snapdragon processor; unfortunately, it won't be available until next Spring and the manufacturer isn't being revealed right now.


Saturday, November 07, 2009

How to synch yahoo mail on the droid

Motorola DROID / DROID Eris now available in stores, online « Boy Genius Report
1.select the email icon
2.select the physical menu button
3.select accounts
4.select the physical menu button
5.select add account
6.enter in email address and password
7.select manual setup in the lower left hand corner
8.select imap account
9.enter the following into the imap server field -
imap.mail.yahoo.com
10.select next
11.enter the following into the smpt server field -
smpt.mail.yahoo.com
12.select next
13.choose your email frequency and if you would like the email to be your default account
14.select next
15.name the account
16.select done


Wednesday, November 04, 2009

Great post on how to modify the sms inbox

Android Tips
Monday, September 7, 2009
SMS Blocking in Android
Recently, I tried to develop an app that would block sms from certain numbers that you can choose. It seems that you cannot completely block the incoming sms.

These were the problems that I faced while working with this app.

1. There are no APIs supplied, that handles the SMS inbox (I mean, no content providersm which can be directly queried to fetch records from the sms table). However, you have a workaround of finding the tables where the sms is stored, and then querying and updating that table. Well, there is actually a content provider, that exposes this table to other applications, but it is not documented anywhere. So, I have to hardcode the column values. This is potentially dangerous, if in the next Donut release, Google changes the column names, my application would fall apart.

2. On receiving of an SMS, I have 2 things to do. Remove the SMS from the sms table, and disable the notification. Deleting the sms from the table was pretty easy, but I couldn't find a way to remove the Notification. Perhaps, there is no way that we can disable this notification. One workaround might be, to temporarily change the Notification settings, the moment you sense an incoming message from a blocked number. And, after you delete the message from the sms table, you just turn on the notification. I haven't worked on this, but this might just work.

3. If the Messaging application is already open, and an sms arrives, weird things start to happen. I can see the blocked sms being deleted, and the list of sms gets updated. But the next message in the list is marked as "Unread". Probably, this is done my the Notification, I don't know.

4. SMS broadcast, is definitely, an un-ordered one. So, the easiest way, that could have worked, would have been just to abort the broadcast. But in this case, you don't have this option. so, once you recieve this broadcast, you have to manually go and delete the message, by matching the incoming number, timestamp etc. Timestamp method isn't foolproof. Because, the timestamp you receive, is the timestamp of the broadcast, and not the time when the sms is written into the DB. So they wont match. You should pick up the incoming number, and check for the timestamp within a range of about 1 seconds. This should give you the sms that you need to delete.

5. There's another problem. When you recieve the broadcast, the system wont write the sms into the table, before it is sure that all the broadcast receivers have done their work. So, it waits for some time, and then writes the sms into the table. Before this, if you try to delete the sms, obviously, you would not find it in the table. So, make your code sleep for about a second, and then go and delete the SMS. That should do it.

But, the most important problem still persists. THE NOTIFICATION. I guess, it can't be removed.


Monday, November 02, 2009

Mio Miuddy GPS unit for Windows CE moves to Android

Mio MiBuddy GPS units to trade Windows CE for Android
Mio MiBuddy GPS units to trade Windows CE for Android

by Joshua Topolsky posted Nov 2nd 2009 at 9:22AM
If you're keeping tabs on Mio Technology's GPS happenings, you'll be interested to dip into some facts that PC World has uncovered about the company's upcoming offerings. According to the mag, the next version of the electronics-maker's MiBuddy satnav unit will dash the underlying Windows CE architecture for Google's newer and far more suave Android platform. The new device will be pushing into MID territory, boasting a 4.7-inch touchscreen along with a hardware slider keyboard, the ability to browse the internet, and WiFi and Bluetooth onboard. Call us crazy, but it seems possible that devices like dedicated PNDs running Android could easily adapt Google's new turn-by-turn system as their primary mode of operation. Alternately, you could switch between Mio's proprietary version and Google's variation... or they could axe the big G's altogether, though that awkward situation makes far less sense to us. No word on timing or price just yet, but we'll keep you posted.


Soyea MID Android Device

Soyea's MID Z5 features an Atom CPU, 3G, and a significant price tag
Soyea's MID Z5 features an Atom CPU, 3G, and a significant price tag

by Joseph L. Flatley posted Nov 2nd 2009 at 1:01PM
Sure, there are some of us who like to play around -- and a first-generation Android MID might be lots of fun to those folks -- but how about the peeps out there that need a portable Internet device with serious muscle? Soyea's Z5 features a 5-inch (800 x 480) resistive touchscreen, 1.2GHz Intel Atom processor, 1GB RAM, WiFi, 3G (from China Telecom) and Bluetooth 2.0. A dual boot device, this bad boy eschews the cell phone OS du jour for both Windows XP and Linux -- and since you're liable to fall in love with this thing (and quickly max out the storage) the included microSD slot should take the sting out of the mere 8GB SSD. But that ain't all! It also rocks stereo speakers, a webcam, a VGA port, and mini USB. Of course, a device this serious has a serious price to match -- expect to pay 5,999 Chinese yuan (roughly $879) from Amazon China. Available in black and white, we have one more pic for you after the break.


Wednesday, October 14, 2009

Motorola CLIQ review

Review: Motorola CLIQ
The Short Version

Motorola has released the phone it should have released a few years ago to compete with phones like the Helio Ocean and feature phones from LG and Samsung. Android brings this phone into the 21st century and the QWERTY keyboard and BLUR UI tweaks will please those looking for a keyboard Android phone with social networking features.


Monday, October 12, 2009

Savage moon walkthrough

Savage Moon Walkthrough - PS3 Forums
I think it best that you at least try a few times to complete the missions before going to these walkthroughs as this is a great game and it'd be a shame to miss out on it.

The game is separated into 3 different Moons. Xipe, Ymir and Zeus

XIPE (1st Moon)

Xipe is essentially a tutorial, with the last mission on xipe (Overgar) being the first challenging mission, unfortunately there are no walkthroughs for any of Xipes missions yet, once some go up, I'll make sure to update the OP with them.


Wednesday, October 07, 2009

lovely website on java interview questions

Java Interview Questions » Java Interview Questions
What if the main method is declared as private?

The program compiles properly but at runtime it will give “Main method not public.” message.

What is meant by pass by reference and pass by value in Java?

Pass by reference means, passing the address itself rather than passing the value. Pass by value means passing a copy of the value.

If you’re overriding the method equals() of an object, which other method you might also consider?

hashCode()

What is Byte Code?

Or

What gives java it’s “write once and run anywhere” nature?

All Java programs are compiled into class files that contain bytecodes. These byte codes can be run in any platform and hence java is said to be platform independent.

Expain the reason for each keyword of public static void main(String args[])?

public- main(..) is the first method called by java environment when a program is executed so it has to accessible from java environment. Hence the access specifier has to be public.

static: Java environment should be able to call this method without creating an instance of the class , so this method must be declared as static.

void: main does not return anything so the return type must be void

The argument String indicates the argument type which is given at the command line and arg is an array for string given during command line.

What are the differences between == and .equals() ?

Or

what is difference between == and equals

Or

Difference between == and equals method

Or

What would you use to compare two String variables - the operator == or the method equals()?

Or

How is it possible for two String objects with identical values not to be equal under the == operator?

The == operator compares two objects to determine if they are the same object in memory i.e. present in the same memory location. It is possible for two String objects to have the same value, but located in different areas of memory.

== compares references while .equals compares contents. The method public boolean equals(Object obj) is provided by the Object class and can be overridden. The default implementation returns true only if the object is compared with itself, which is equivalent to the equality operator == being used to compare aliases to the object. String, BitSet, Date, and File override the equals() method. For two String objects, value equality means that they contain the same character sequence. For the Wrapper classes, value equality means that the primitive values are equal.

public class EqualsTest {

public static void main(String[] args) {

String s1 = “abc”;
String s2 = s1;
String s5 = “abc”;
String s3 = new String(”abc”);
String s4 = new String(”abc”);
System.out.println(”== comparison : ” + (s1 == s5));
System.out.println(”== comparison : ” + (s1 == s2));
System.out.println(”Using equals method : ” + s1.equals(s2));
System.out.println(”== comparison : ” + s3 == s4);
System.out.println(”Using equals method : ” + s3.equals(s4));
}
}

Output
== comparison : true
== comparison : true
Using equals method : true
false
Using equals method : true

What if the static modifier is removed from the signature of the main method?

Or

What if I do not provide the String array as the argument to the method?

Program compiles. But at runtime throws an error “NoSuchMethodError”.

Why oracle Type 4 driver is named as oracle thin driver?

Oracle provides a Type 4 JDBC driver, referred to as the Oracle “thin” driver. This driver includes its own implementation of a TCP/IP version of Oracle’s Net8 written entirely in Java, so it is platform independent, can be downloaded to a browser at runtime, and does not require any Oracle software on the client side. This driver requires a TCP/IP listener on the server side, and the client connection string uses the TCP/IP port address, not the TNSNAMES entry for the database name.

What is the difference between final, finally and finalize? What do you understand by the java final keyword?

Or

What is final, finalize() and finally?

Or

What is finalize() method?

Or

What is the difference between final, finally and finalize?

Or

What does it mean that a class or member is final?

o final - declare constant
o finally - handles exception
o finalize - helps in garbage collection

Variables defined in an interface are implicitly final. A final class can’t be extended i.e., final class may not be subclassed. This is done for security reasons with basic classes like String and Integer. It also allows the compiler to make some optimizations, and makes thread safety a little easier to achieve. A final method can’t be overridden when its class is inherited. You can’t change value of a final variable (is a constant). finalize() method is used just before an object is destroyed and garbage collected. finally, a key word used in exception handling and will be executed whether or not an exception is thrown. For example, closing of open connections is done in the finally method.

What is the Java API?

The Java API is a large collection of ready-made software components that provide many useful capabilities, such as graphical user interface (GUI) widgets.

What is the GregorianCalendar class?

The GregorianCalendar provides support for traditional Western calendars.

What is the ResourceBundle class?

The ResourceBundle class is used to store locale-specific resources that can be loaded by a program to tailor the program’s appearance to the particular locale in which it is being run.

Why there are no global variables in Java?

Global variables are globally accessible. Java does not support globally accessible variables due to following reasons:

* The global variables breaks the referential transparency
* Global variables creates collisions in namespace.

How to convert String to Number in java program?

The valueOf() function of Integer class is is used to convert string to Number. Here is the code example:
String numString = “1000″;
int id=Integer.valueOf(numString).intValue();

What is the SimpleTimeZone class?

The SimpleTimeZone class provides support for a Gregorian calendar.

What is the difference between a while statement and a do statement?

A while statement (pre test) checks at the beginning of a loop to see whether the next loop iteration should occur. A do while statement (post test) checks at the end of a loop to see whether the next iteration of a loop should occur. The do statement will always execute the loop body at least once.

What is the Locale class?

The Locale class is used to tailor a program output to the conventions of a particular geographic, political, or cultural region.

Describe the principles of OOPS.

There are three main principals of oops which are called Polymorphism, Inheritance and Encapsulation.

Explain the Inheritance principle.

Inheritance is the process by which one object acquires the properties of another object. Inheritance allows well-tested procedures to be reused and enables changes to make once and have effect in all relevant places

What is implicit casting?

Implicit casting is the process of simply assigning one entity to another without any transformation guidance to the compiler. This type of casting is not permitted in all kinds of transformations and may not work for all scenarios.

Example

int i = 1000;

long j = i; //Implicit casting

Is sizeof a keyword in java?

The sizeof operator is not a keyword.

What is a native method?

A native method is a method that is implemented in a language other than Java.

In System.out.println(), what is System, out and println?

System is a predefined final class, out is a PrintStream object and println is a built-in overloaded method in the out object.

What are Encapsulation, Inheritance and Polymorphism

Or

Explain the Polymorphism principle. Explain the different forms of Polymorphism.

Polymorphism in simple terms means one name many forms. Polymorphism enables one entity to be used as a general category for different types of actions. The specific action is determined by the exact nature of the situation.

Polymorphism exists in three distinct forms in Java:
• Method overloading
• Method overriding through inheritance
• Method overriding through the Java interface

What is explicit casting?

Explicit casting in the process in which the complier are specifically informed to about transforming the object.

Example

long i = 700.20;

int j = (int) i; //Explicit casting

What is the Java Virtual Machine (JVM)?

The Java Virtual Machine is software that can be ported onto various hardware-based platforms

What do you understand by downcasting?

The process of Downcasting refers to the casting from a general to a more specific type, i.e. casting down the hierarchy

What are Java Access Specifiers?

Or

What is the difference between public, private, protected and default Access Specifiers?

Or

What are different types of access modifiers?

Access specifiers are keywords that determine the type of access to the member of a class. These keywords are for allowing
privileges to parts of a program such as functions and variables. These are:
• Public : accessible to all classes
• Protected : accessible to the classes within the same package and any subclasses.
• Private : accessible only to the class to which they belong
• Default : accessible to the class to which they belong and to subclasses within the same package

Which class is the superclass of every class?

Object.

Name primitive Java types.

The 8 primitive types are byte, char, short, int, long, float, double, and boolean.

What is the difference between static and non-static variables?

Or

What are class variables?

Or

What is static in java?

Or

What is a static method?

A static variable is associated with the class as a whole rather than with specific instances of a class. Each object will share a common copy of the static variables i.e. there is only one copy per class, no matter how many objects are created from it. Class variables or static variables are declared with the static keyword in a class. These are declared outside a class and stored in static memory. Class variables are mostly used for constants. Static variables are always called by the class name. This variable is created when the program starts and gets destroyed when the programs stops. The scope of the class variable is same an instance variable. Its initial value is same as instance variable and gets a default value when its not initialized corresponding to the data type. Similarly, a static method is a method that belongs to the class rather than any object of the class and doesn’t apply to an object or even require that any objects of the class have been instantiated.
Static methods are implicitly final, because overriding is done based on the type of the object, and static methods are attached to a class, not an object. A static method in a superclass can be shadowed by another static method in a subclass, as long as the original method was not declared final. However, you can’t override a static method with a non-static method. In other words, you can’t change a static method into an instance method in a subclass.

Non-static variables take on unique values with each object instance.

What is the difference between the boolean & operator and the && operator?

If an expression involving the boolean & operator is evaluated, both operands are evaluated, whereas the && operator is a short cut operator. When an expression involving the && operator is evaluated, the first operand is evaluated. If the first operand returns a value of true then the second operand is evaluated. If the first operand evaluates to false, the evaluation of the second operand is skipped.

How does Java handle integer overflows and underflows?

It uses those low order bytes of the result that can fit into the size of the type allowed by the operation.

What if I write static public void instead of public static void?

Program compiles and runs properly.

What is the difference between declaring a variable and defining a variable?

In declaration we only mention the type of the variable and its name without initializing it. Defining means declaration + initialization. E.g. String s; is just a declaration while String s = new String (”bob”); Or String s = “bob”; are both definitions.

What type of parameter passing does Java support?

In Java the arguments (primitives and objects) are always passed by value. With objects, the object reference itself is passed by value and so both the original reference and parameter copy both refer to the same object.

Explain the Encapsulation principle.

Encapsulation is a process of binding or wrapping the data and the codes that operates on the data into a single entity. This keeps the data safe from outside interface and misuse. Objects allow procedures to be encapsulated with their data to reduce potential interference. One way to think about encapsulation is as a protective wrapper that prevents code and data from being arbitrarily accessed by other code defined outside the wrapper.

What do you understand by a variable?

Variable is a named memory location that can be easily referred in the program. The variable is used to hold the data and it can be changed during the course of the execution of the program.

What do you understand by numeric promotion?

The Numeric promotion is the conversion of a smaller numeric type to a larger numeric type, so that integral and floating-point operations may take place. In the numerical promotion process the byte, char, and short values are converted to int values. The int values are also converted to long values, if necessary. The long and float values are converted to double values, as required.

What do you understand by casting in java language? What are the types of casting?

The process of converting one data type to another is called Casting. There are two types of casting in Java; these are implicit casting and explicit casting.

What is the first argument of the String array in main method?

The String array is empty. It does not have any element. This is unlike C/C++ where the first element by default is the program name. If we do not provide any arguments on the command line, then the String array of main method will be empty but not null.

How can one prove that the array is not null but empty?

Print array.length. It will print 0. That means it is empty. But if it would have been null then it would have thrown a NullPointerException on attempting to print array.length.

Can an application have multiple classes having main method?

Yes. While starting the application we mention the class name to be run. The JVM will look for the main method only in the class whose name you have mentioned. Hence there is not conflict amongst the multiple classes having main method.

When is static variable loaded? Is it at compile time or runtime? When exactly a static block is loaded in Java?

Static variable are loaded when classloader brings the class to the JVM. It is not necessary that an object has to be created. Static variables will be allocated memory space when they have been loaded. The code in a static block is loaded/executed only once i.e. when the class is first initialized. A class can have any number of static blocks. Static block is not member of a class, they do not have a return statement and they cannot be called directly. Cannot contain this or super. They are primarily used to initialize static fields.

Can I have multiple main methods in the same class?

We can have multiple overloaded main methods but there can be only one main method with the following signature :

public static void main(String[] args) {}

No the program fails to compile. The compiler says that the main method is already defined in the class.

Explain working of Java Virtual Machine (JVM)?

JVM is an abstract computing machine like any other real computing machine which first converts .java file into .class file by using Compiler (.class is nothing but byte code file.) and Interpreter reads byte codes.

How can I swap two variables without using a third variable?

Add two variables and assign the value into First variable. Subtract the Second value with the result Value. and assign to Second variable. Subtract the Result of First Variable With Result of Second Variable and Assign to First Variable. Example:

int a=5,b=10;a=a+b; b=a-b; a=a-b;

An other approach to the same question

You use an XOR swap.

for example:

int a = 5; int b = 10;
a = a ^ b;
b = a ^ b;
a = a ^ b;

What is data encapsulation?

Encapsulation may be used by creating ‘get’ and ’set’ methods in a class (JAVABEAN) which are used to access the fields of the object. Typically the fields are made private while the get and set methods are public. Encapsulation can be used to validate the data that is to be stored, to do calculations on data that is stored in a field or fields, or for use in introspection (often the case when using javabeans in Struts, for instance). Wrapping of data and function into a single unit is called as data encapsulation. Encapsulation is nothing but wrapping up the data and associated methods into a single unit in such a way that data can be accessed with the help of associated methods. Encapsulation provides data security. It is nothing but data hiding.

What is reflection API? How are they implemented?

Reflection is the process of introspecting the features and state of a class at runtime and dynamically manipulate at run time. This is supported using Reflection API with built-in classes like Class, Method, Fields, Constructors etc. Example: Using Java Reflection API we can get the class name, by using the getName method.

Does JVM maintain a cache by itself? Does the JVM allocate objects in heap? Is this the OS heap or the heap maintained by the JVM? Why

Yes, the JVM maintains a cache by itself. It creates the Objects on the HEAP, but references to those objects are on the STACK.

What is phantom memory?

Phantom memory is false memory. Memory that does not exist in reality.

Can a method be static and synchronized?

A static method can be synchronized. If you do so, the JVM will obtain a lock on the java.lang.
Class instance associated with the object. It is similar to saying:

synchronized(XYZ.class) {

}

What is difference between String and StringTokenizer?

A StringTokenizer is utility class used to break up string.

Example:

StringTokenizer st = new StringTokenizer(”Hello World”);

while (st.hasMoreTokens()) {

System.out.println(st.nextToken());

}

Output:

Hello

World

If you think that an important java interview question is missing or some answers are wrong in the site please contribute it to sriniappl@gmail.com


Tuesday, September 29, 2009

cassandra connect to thrift port 9170 instead of 7000 or 7001

cassandra> connect 127.0.0.1/9160
Connected to 127.0.0.1/9160
cassandra> show keyspaces

for cassandra make sure you set the internal address

  <ListenAddress>domU-12-31-38-11-11-A2</ListenAddress>
  <!-- TCP port, for commands and data -->
  <StoragePort>7000</StoragePort>
  <!-- UDP port, for membership communications (gossip) -->
  <ControlPort>7001</ControlPort>

If the listenaddress is set to localhost, the server won't able to discover itself.



cassandra 0.4.0 is out

Mailing list archives
adies and gentlemen, I give you Cassandra 0.4.0. It's hard to imagine that it has only been 2 months since our very first release[1]; an impressive amount of progress has been made. For example: * Nodes can now scale to billions of keys instead of millions. * There is support for multiple keyspaces (formerly known as tables). * You can now create snapshots * A new bootstrap feature for adding nodes to a running cluster * A new multiget API * Numerous improvements to the Thrift API And many, many, more. In fact, don't take my word for it, check out the changelog[2], or the 176 closed Jira issues (176!)[3]. Many thanks to all those that contributed patches, reviewed, tested, documented, or counseled.


Pretty cool.

On my macbook pro, I got about 2400 inserts / s with cassandra 0.4.0. I was not able to get a multinode setup on my ec2 enviroment.



Friday, September 18, 2009

recommended use for hbase htable and cached hbase configuration

RE: HBase Client Concerns
Many thanks again. I think I'll go initially with cached HBaseConfiguration and one new HTable instance per request thread and accept the resulting slowness overhead per request. When the HTablePool pause/retry param issue is resolved, I can switch to that. To workaround the problem of restarting the client app when the HBase servers are restarted, I can then maybe wrap HTablePool into a class which essentially clears the pool cache [forcing instantiating a new HTable] when any of the HTablePool.getTable() client calls time out, so the client app need not be restarted... Cheers,


Thursday, September 17, 2009

Check out javadocs for using hbase with hadoop!

org.apache.hadoop.hbase.mapreduce (HBase 0.20.0 API)
Package org.apache.hadoop.hbase.mapreduce Description

Provides HBase MapReduce Input/OutputFormats, a table indexing MapReduce job, and utility


Sunday, September 13, 2009

struts 2 veloctiy and javarebel rock!

Man java rebel rocks!

By using Javarebel with struts 2 and velocity I can eliminate the whole compile deploy wait cycle!

Use these maven opts at startup.

MAVEN_OPTS="-Xmx712m -XX:MaxPermSize=256m -noverify -Drebel.spring_plugin=false -Drebel.velocity_plugin=true -Drebel.struts2-plugin=true -Drebel.aspectj_plugin=true -javaagent:javarebel203/javareb
el.jar -Drebel.dirs=target/classes,../target/classes

To refresh my struts file.

cp src/main/resources/*struts*.xml target/work/webapp/WEB-INF/classes

To reload any classes

mvn compile

To refresh any velocity files

cp src/main/webapp/*.vm target/work/webapp/





Thursday, September 10, 2009

mysql benchmark on mac

Ran a quick benchmark on my macbook pro :P

1,000,000 rows inserted serially.
596023 ms taken.
1677 rows inserted /s.

MySQL is faster on my localhost than memcacheDB.

Monday, September 07, 2009

MemcacheDB benchmark

On ubuntu amazon ec2 large instance - using java and spy memcache client.
Ran memcachedb with command

memcachedb -m 2064 -p 11211 -u memcachedb -l 127.0.0.1 -b 22000

Results - 10,000 puts of 140 characters in 22143 ms.
Roughly..
451 puts / s.

inserted 140 characters with a 5 character key.







key value store time taken to insert 10,000 recordsMB taken for storage inserts /s
memcachedb22143 ms1300 MB451 puts / s


Note - I had to add an artificial 1 ms delay after every insert. The memcache client would throw a queue size exception.
If time took 12143 ms, we would get roughly.

900 puts / s

Sunday, September 06, 2009

How to setup a Single node - hadoop cluster with hBASE

This guy has good instructions - http://blog.ibd.com/Part 1 setup Hadoop1. Get download and untar
wget http://apache.mirrors.hoobly.com/hadoop/core/hadoop-0.20.0/hadoop-0.20.0.tar.gz

tar xvf hadoop-0.20.0.tar.gz


2. Modify configuration files

cd hadoop-0.20.0/conf$edit core-site.xml
Add
<configuration>
<property>
<name>fs.default.name</name>
<value>hdfs://localhost:9000</value>
</property>
</configuration>

3. Edit site configuration for replication.

hadoop-0.20.0/conf$edit hdfs-site.xml
<configuration>
<property>
<name>dfs.replication</name>
<value>1</value>
</property>
</configuration>


4. Set Map reduce node - note even if we are not using it.

hadoop-0.20.0/conf$edit mapred-site.xml

<configuration>
<property>
<name>mapred.job.tracker</name>
<value>localhost:9001</value>
</property>
</configuration>

5. Check local ssh access

hadoop-0.20.0/conf$ssh localhost
Last login: Sat Sep 5 11:56:25 2009
LOLCAT@~$exit
logout
Connection to localhost closed.

6. Format / initialize hadoop file system

hadoop-0.20.0$bin/hadoop namenode -format
09/09/05 12:01:28 INFO namenode.NameNode: STARTUP_MSG:
/************************************************************
STARTUP_MSG: Starting NameNode
STARTUP_MSG: host = LOLCAT.local/10.0.1.193
STARTUP_MSG: args = [-format]
STARTUP_MSG: version = 0.20.0
STARTUP_MSG: build = https://svn.apache.org/repos/asf/hadoop/core/branches/branch-0.20 -r 763504; compiled by 'ndaley' on Thu Apr 9 05:18:40 UTC 2009
************************************************************/
09/09/05 12:01:28 INFO namenode.FSNamesystem: fsOwner=spicysquid,staff,com.apple.sharepoint.group.2,admin,com.apple.sharepoint.group.1
09/09/05 12:01:28 INFO namenode.FSNamesystem: supergroup=supergroup
09/09/05 12:01:28 INFO namenode.FSNamesystem: isPermissionEnabled=true
09/09/05 12:01:28 INFO common.Storage: Image file of size 100 saved in 0 seconds.
09/09/05 12:01:28 INFO common.Storage: Storage directory /tmp/hadoop-spicysquid/dfs/name has been successfully formatted.
09/09/05 12:01:28 INFO namenode.NameNode: SHUTDOWN_MSG:
/************************************************************
SHUTDOWN_MSG: Shutting down NameNode at LOLCAT.local/10.0.1.193
************************************************************/

8. Start everything up!
./start-all.sh
starting namenode, logging to /Users/spicysquid/hbase/hadoop20/hadoop-0.20.0/bin/../logs/hadoop-spicysquid-namenode-LOLCAT.local.out
localhost: starting datanode, logging to /Users/spicysquid/hbase/hadoop20/hadoop-0.20.0/bin/../logs/hadoop-spicysquid-datanode-LOLCAT.local.out
localhost: starting secondarynamenode, logging to /Users/spicysquid/hbase/hadoop20/hadoop-0.20.0/bin/../logs/hadoop-spicysquid-secondarynamenode-LOLCAT.local.out
starting jobtracker, logging to /Users/spicysquid/hbase/hadoop20/hadoop-0.20.0/bin/../logs/hadoop-spicysquid-jobtracker-LOLCAT.local.out
localhost: starting tasktracker, logging to /Users/spicysquid/hbase/hadoop20/hadoop-0.20.0/bin/../logs/hadoop-spicysquid-tasktracker-LOLCAT.local.out


9. Check urls to see if they are up:

The Job Tracker can be found at http://localhost:50030
The Task Tracker can be found at http://localhost:50060

The NameNode / Filesystem / log browser can be found at http://localhost:50070



Part 2 - Setup HBASE


1. download hbase 20 and untar

wget http://people.apache.org/~stack/hbase-0.20.0-candidate-3/hbase-0.20.0.tar.gz

tar xvf hbase-0.20.0.tar.gz

2. Modify conf/hbase-site.xml for hdfs server

<property>
<name>hbase.rootdir</name>
<value>hdfs://localhost:9000/hbase</value>
<description>The directory shared by region servers.
</description>
</property>


3. start hbase
*** optional --- i had to start zookeeper first...
hbase-0.20.0/bin$./hbase-daemon.sh start zookeeper
./start-hbase.sh

4. create a table.
hbase-0.20.0/bin/hbase shell
1 row(s) in 0.0170 seconds

hbase(main):003:0> disable 'test'
09/09/05 13:22:13 INFO client.HBaseAdmin: Disabled test
0 row(s) in 4.0660 seconds
hbase(main):004:0> drop 'test'
09/09/05 13:22:17 INFO client.HBaseAdmin: Deleted test
0 row(s) in 0.0120 seconds
0 row(s) in 0.0040 seconds
0 row(s) in 0.0440 seconds
hbase(main):005:0> create 'test','data'
0 row(s) in 0.0500 seconds
hbase(main):006:0> list

5. Check
Check hdfs web url to see how the files are created
The NameNode / Filesystem / log browser can be found at http://localhost:50070

6. stop hbase
stop hadoop

hadoop-0.20.0/bin$./stop-all.sh
stopping jobtracker
localhost: stopping tasktracker
stopping namenode
localhost: stopping datanode
localhost: stopping secondarynamenode


hbase-20.0/bin/./stop-hbase.sh

Tuesday, August 11, 2009

hbase benchmarks

on macbook pro.

hbase 19.3
hadoop 19.2

insert one millions rows with one column family with one column.
333 rows / s

read one million rows
52465 ms

Monday, August 10, 2009

how to unlock your vx9800

How can I get past the lock code on my LG Chocolate? - IhAv.NET
This MAY work on your VX series LG phones for verizon. it has been tested on my vx9800 and my girlfriends vx8100. all you need to know is your phone number.

This works on:
vx8100
vx9800

DO:
1. *22899
2. Let it reprogram your phone
3. Now your unlock code should be the last 4 digits of your phone number.


Sunday, April 05, 2009

How to delete old time machine backups

How to Delete Individual Backups from Apple Time Machine « Psychohistory
One of those menu items is “Delete Backup”.

So, to delete a full backup, you just do the following:

1. Navigate to the date you want to delete. In my case, I wanted to delete my oldest backup, from 1/30/2008.
2. Navigate in the Finder window to your overall machine. In my case, it’s called “Powersmash G5″, where I have 2 internal drives that are backed up.
3. Select the “Gear” menu, and select “Delete Backup”
4. Enter the admin password for the Finder, if it asks.

My guess is that Apple wasn’t trying to make this hard - they are just suffering from a non-standard interface, and then an overloading of that “gears” menu, which I’m sure is theoretically supposed to be a “contextual menu”. For me, a menu that showed on on right-click of either the finder window itself or the Time Machine backup marker on the right would have been more obvious to me.

Hope this tip is useful to someone. It sure helped me today.


Thursday, January 29, 2009

pretty cool stuff spring and ruby integration!

Squaremasher: Spring IOC in JRuby - life outside the container
Spring IOC in JRuby - life outside the container
If you're a JRuby aficionado you probably read about the Spring IOC Plugin for rails, but what if you want to get spring IOC running outside a servlet container? Here's how.