I've recently bought and built a new high performance machine.  I've previously done all of my development on my Inspiron 9300 with 2GB DDR2, but with latest activities with application servers and development environments it has become too slow to be highly productive on it.  Hopefully this new machine will prove to be worth the investment.
I gave myself a budget of approximately $1000.  The original intent wasn't for a gaming machine, albeit that's what the specs will look like.  I've went through and researched using many sources such as articles, forums, and benchmarks to find the best product to fit my requirements as a multi-tasking developer that may be running application servers, running tests, and developing at the same time.
Specifications
Motherboard: Gigabyte GA-P35-DS3L
Processor: Intel Core 2 Quad Q9450 2.66GHz 12MB Cache 1333MHz FSB
Hard Drive: Western Digital Raptor X 150GB 10,000 RPM
Memory: 4GB (2x2GB) XMS2 Corsair 800MHZ
Monitor: 24" Samsung 245BW
Video Card: EVGA 8600GT 256MB DDR3
Case: Antec Three Hundred
PSU: Thermaltake Purepower 500W
Keyboard: Microsoft Natural 4000 Ergonomics Keyboard
CD/DVD: Samsung 20X DVD Burner with LightScribe
I'm pretty sure these look like specs for a gaming machine, but that's not the intent.  The primary intent was to allow myself to be more efficient and productive in a working facet.  It's in preparation for an amount of work on a startup idea.  I was originally going to get the Q9300 processor, but decided to upgrade a little.  The Q9300 would have cost me $279, but the Q9450 was only $299.  The different is the Q9450 has a 12MB L2 cache vs. 6MB and 2.66GHZ vs 2.5GHZ.  If I plan to optimize further it's an easier road ahead of me because the Q9450 over clocks easier.
Future Options
I'm usually very interested in squeezing every bit out of my machines (e.g. over clocking).  I'm interested in overclocking my processor to at least 3GHZ with the current RAM.  I was originally going to buy 4GB (2x2GB) Corsair Dominator 1066MHZ but decided to go with the cheaper option as shown above.
Balance
The tough problem is balancing my time of building, overclocking, and optimizing my machine over productive time in other venues such as development, requirements planning, and other such activities.
A First Look
I'll post the rest, but these are a start.

Full speed ahead!
Wednesday, May 21, 2008
Full Speed Ahead: New Developer Machine
Wednesday, May 14, 2008
Load Testing Tools: JMeter vs. The Grinder
This is an attempt at reviewing load testing tools in an evaluation format (JMeter vs. The Grinder). At my organization we have the following use requirements for a load testing tool.
- Load test an application (e.g. HTTP) with  approx. 2000 concurrent users with approx. 500 transactions/sec.
- Parameterize URL for session id (e.g. Modifying URL parameters in the request based on previous test data)
- Measure performance of logical page transactions/sets of requests.  This could count an entire page load as a single transaction.  The entire page load may have html, javascript, css, and images but the page should be regarded as a single unit.
- Usability -- How usable the tool is (e.g. Functional GUI,  fulfills goals specified above).  It is important to reflect upon the target audience when looking at usability.  Is it functional for a tester, QA lead, or developer?
- Extensibility -- How extensible the tool is (e.g. Does it offer scripting support?).
- Experience -- My experience with the tool and any comments while trying to offer an unbiased point of view.
Note: By any means I am not an expert in either tool. This is simply a limited review of both tools. Please correct me if I am wrong in my statements.
JMeter
JMeter is a load testing tool for functional behavior and measuring performance. A user interface is provided to record, create, and run test scenarios.
Usability
The interface tool is very easy to use. However, there are issues with the included components for creating a test to be complicated. The tool was initially easy to figure out. I believe this is a product of it having a decent tutorial. Setting up a proxy is easy enough, but isn't enabled out of the box. It is very usable from a non technical perspective. I could trust that if the tool was given to a QA team the documentation would be okay to start performance/load testing.
Extensibility
There are many provided components when creating your test to do many things. It provides components for standard tasks. Many of the components aren't easily understood to work as you would expect them to.
Experience
In my limited experience with JMeter it is not viable for complex solutions to load testing. The documentation is plentiful, but not very helpful. It is extensible up to a point where the underlying use of the tool reaches a point. Given the above requirements JMeter isn't extensible enough. If your needs for a load testing tool involve less customizing then it should work just fine.
The Grinder
The Grinder is a tool designed to work in a distributed agent environment for load testing an application from many machines. It allows for easy scripting and customization of test scripts using Jython. It is very easy to load test and define logical transactions by redefining the way your data is recorded so it can then be analyzed.
Usability
The Grinder is seemingly aimed at the developer. It provides a usable interface that provides various metrics for collecting samples and looking at result data. The metrics that are given aren't too advanced, but it provides facilities for data to be exported into a higher quality analysis tool.
Extensibility
This is an area where The Grinder excels. It is very easy to customize the test scripts in Jython. This even includes importing other Jython scripts for other types of addons (e.g. for randomizing logins for multiple users. See below.)
Experience
With limited experience The Grinder has been an easy tool to work with. A strength is that it is very extensible and scripts can be written free form as said above. There are scripts out there for various functionality. When implementing login for multiple users it was very easy to adapt to the existing recorded/modified script that was written. If using Jython is a problem then the tool is probably not the best choice.
Conclusion
After looking at both applications I choose The Grinder as the tool to go with given the requirements for a load testing tool for my team. If your requirements are different and don't require customization then JMeter would be just as good.
Note: The Grinder has been in use and has so far been working great.
References
Subscribe to:
Comments (Atom)
