New-age Transactional Systems - Not Your Grandpa's OLTP
John Hugg discusses high volume transaction processing applications with high and low frequency profiles, and how VoltDB can be used for that purpose.
The content has been bookmarked!
There was an error bookmarking this content! Please retry.
Posted by Abel Avram on May 08, 2008
EQATEC has created a code profiler for applications written for the .NET Compact Framework. Initially written for their own needs, EQATEC decided to release the profiler to the entire community of .NET Compact Framework developers. This is not a memory usage profiler, but a tool used to detect application bottlenecks, the places in the code where most of processing time is spent.
These are the main features according to EQATEC:
- Code profiler for optimizing your application's speed/performance, not a memory profiler
- Very low overhead; typically less than 30% longer runtime and 50% extra code size
- All .NET 2.0/3.5 Compact Framework (.NET CF) applications can be profiled
- Command-line version can integrate profiling into your auto build
- Precise instrumentation, as opposed to sampling profilers
- Will profile methods, not individual statements
- Full call-graph details are reported
- 100% free for all to use
Running this profiler is simple. The application is compiled as usually, then the profiler is used to inject binary code into the assemblies which are to be monitored. The application is then run on the device producing a report which is loaded into the profiler viewer for analysis.
There are some limitations to the profiler according to EQATEC:
- User-defined generics are not supported. If you define your own generic type of method the resulting assembly currently would not work. Right now the profiler simply skips all assemblies containing generics, but that's pretty annoying. Fixing this has top priority.
- Recursive methods is reported as sum of the calls. The viewer should be more clever in this respect.
- Blocking methods, such as Read(), will be counted as the total time, including the time the thread spends being unscheduled and waiting for the call to complete.
- Strong-name signed assemblies are not supported now. They would have to be re-signed after having been profiled. This feature is currently missing.
- No debug information is available for the profiled assemblies. It means that you cannot debug the profiled versions - but you would probably not like to do that, anyway.
- No Visual Studio integration yet. We'd like to create an add-in that will make it even easier to enable profiling your solution's assembly files.
A video demo of the profiler is available. The profiler can be downloaded here.
Transforming Software Delivery: An IBM Rational Case Study
Fair Trade Software Licensing - A Guide to Neo4j Licensing Options
Using Drools? See what you're missing! Get the Power of Drools with the Assurance of Red Hat
In today’s hyper-competitive world, later may be too late to adopt Agile development and this Roadmap for Success will help you get started. Download "Agile Development: A Manager's Roadmap for Success" now!
John Hugg discusses high volume transaction processing applications with high and low frequency profiles, and how VoltDB can be used for that purpose.
Kevlin Henney examines code samples to see what can be learned from them starting from the premise that one won’t write great code unless he knows how to read it.
Jason Ayers share the observations he made watching a team of developers collaborating in real time on the same code base, pushing XP, pair programming and continuous integration to their extremes.
Michael Snoyman presents Yesod, a web framework written in Haskell and containing a web server, templating, ORM, libraries (templating, gravatar, etc.).
Richard Kreuter and Kyle Banker on how to avoid classical RDBMS transactional systems by using compensation mechanisms, transactional messaging or transactional procedures.
Attila Szegedi talks about performance tuning Java and Scala programs at Twitter: how to approach GC problems, the importance of asynchronous I/O, when to use MySQL/Cassandra/Redis, and much more.
One category of risk that project teams need to ensure they address is business value failure – delivering a product that fails to provide value for the business investor.
InfoQ spoke to the authors of Software Systems Architecture on a couple of new topics, the System Context viewpoint and Agile, which have been added to the second edition.
1 comment
Watch Thread Reply