<?xml version='1.0' encoding='UTF-8'?><rss xmlns:atom='http://www.w3.org/2005/Atom' xmlns:openSearch='http://a9.com/-/spec/opensearchrss/1.0/' xmlns:georss='http://www.georss.org/georss' xmlns:gd='http://schemas.google.com/g/2005' xmlns:thr='http://purl.org/syndication/thread/1.0' version='2.0'><channel><atom:id>tag:blogger.com,1999:blog-3109386887529685808</atom:id><lastBuildDate>Mon, 16 Apr 2012 00:51:53 +0000</lastBuildDate><category>software complexity</category><category>systems effectiveness</category><category>systems integration</category><category>asynchronous</category><category>XP</category><category>delivery hubs</category><category>transaction performance</category><category>creeping elegance</category><category>change</category><category>dsl speed problems</category><category>telecom</category><category>siteminder</category><category>crisis bridge protocol</category><category>pitfalls in outage situations</category><category>barely sufficient</category><category>common IT problems</category><category>web services performance</category><category>service  management</category><category>agile</category><category>content control is king</category><category>software reuse</category><category>adsl</category><category>IT people</category><category>CPU profile of scalable applications</category><category>organizational behavior</category><category>enterprise support</category><category>proactive</category><category>IT execution</category><category>dark arts</category><category>reactive</category><category>bea</category><category>top talent recruiting</category><category>synchronous</category><category>search engine optimization</category><category>IT support maturity model</category><category>lessons learned</category><category>trial and error</category><category>software quality</category><category>performance tuning</category><category>systems availability</category><category>windows server 2003</category><category>Software 101</category><category>change management</category><category>recurring patterns</category><category>transaction variance</category><category>global warming</category><category>application support</category><category>debugging in live</category><category>IT job specialization</category><category>default config</category><category>layered distributed systems</category><category>ETA bait</category><category>IT failures</category><category>Performance engineering</category><category>historical performance reporting</category><category>Systems monitoring</category><category>oracle</category><category>computer associates</category><category>wikipedia</category><category>IT top talent</category><category>scope creep</category><category>IT 101</category><category>colocation</category><category>sequential execution</category><category>project execution</category><category>analyze table</category><category>crisis management</category><category>i've fallen and I can't get up</category><category>broadband boost</category><category>IT support</category><category>microsoft</category><category>systems performance</category><category>enterprise common components</category><category>infrastructure  configuration</category><category>cpu profile</category><category>maxconnections</category><category>database maintenance</category><category>iis server</category><category>sequential analysis</category><category>reuse</category><category>IT effectiveness</category><title>knownbugs</title><description>Ever gone through the experience of staying up a couple of nights to resolve a crisis situation due to a problem that was 'known' ?! Doesn't feel good does it, yet we keep on making the same mistake. An open discussion on best practices in the area of IT systems management, quality, prevention of crisis, etc.</description><link>http://www.knownbugs.org/</link><managingEditor>noreply@blogger.com (Milan Gupta)</managingEditor><generator>Blogger</generator><openSearch:totalResults>29</openSearch:totalResults><openSearch:startIndex>1</openSearch:startIndex><openSearch:itemsPerPage>25</openSearch:itemsPerPage><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-6398016572721341978</guid><pubDate>Mon, 23 Aug 2010 11:37:00 +0000</pubDate><atom:updated>2010-08-23T12:37:21.623+01:00</atom:updated><title>Good software starts with good people - not cheap people</title><description>In well over a decade of working for software consultancies, I have observed a recurring problem that I find personally frustrating.&lt;br /&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Total cost of software development is a very difficult figure to calculate - and even more difficult to compare across projects. &amp;nbsp;Because of this difficulty, some corporates attempt to use developer day rates as their measure of spending effectiveness. &amp;nbsp;This approach tends to mean that they hire only the cheapest developers available. &amp;nbsp;They then turn to "consultancies" to provide additional "expertise" when quality plummets and costs begin to spiral out of control. &amp;nbsp;The expectation is that the consultancy will provide better developers than they are willing to hire themselves. &amp;nbsp;The client often seems to assume that, because they are paying more for a consultant than for in-house staff, the consultant will be more skilled. &amp;nbsp;&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Unfortunately, this approach is driven by a fundamental lack of understanding of the software development market. &amp;nbsp;In reality, the inflated price of a "consultant" is usually driven entirely by the margin that a consultancy must charge in order to themselves make a profit. &amp;nbsp;This margin is often quite large, as a consultancy must cover their overheads while they are short on work - not just while their staff are gainfully employed.&lt;br /&gt;&lt;div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;A consultancy is driven by entirely different incentives than its clients. &amp;nbsp;While their clients&amp;nbsp;expect (in some fashion) to profit off the software they write, a consultancy expects to make money off the writing of the software. &amp;nbsp;Unless they charge a margin, they will make a loss.&lt;br /&gt;&lt;div&gt;&lt;div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Although hiring better developers can lead to a better quality product and lower development costs, (and my own experience has shown this to be the case, over and over,) these factors are not of direct relevance to a consultancy. &amp;nbsp;When they are done, they will move on to the next project without ever having to actually use the software. &amp;nbsp;If the software achieves it return on investment goals, they will generally not see a dime. &amp;nbsp;Providing better quality (and therefore more expensive) staff is only profitable to a consultancy if they can charge a higher margin - and that is on top of their base cost! &amp;nbsp;Given the propensity for client organisations to seek lower day rates, it is sometimes difficult to keep a senior consultant charged out at the margin necessary for profitability. &amp;nbsp;One thing is certain - those clients willing to pay top rates are the ones that get first call on the top talent.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;Because they derive no direct benefit from better quality software and/or lower delivery costs, most consultancies (despite what they might prefer) will attempt to address quality and cost only to the extent demanded by the market. &amp;nbsp;(i.e. their clients.) &amp;nbsp;The same market that sees most of their clients more driven by day rate than by total cost of development, also forces them to adapt their own hiring practices accordingly. &amp;nbsp;(In fact, I have personally worked for a consultancy that tried to adopt to the opposite approach and only hire the best possible developers. &amp;nbsp;Unfortunately, they tended to find that their clients did not want to pay the inflated day rate that the best developers required.) &amp;nbsp;Most software consultancies are forced to just "build the pyramid". &amp;nbsp;i.e. Hire a few senior developers and supplement (or swamp) them with a multitude of minimum-rate staff.&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;So, those very organisations that stand to profit the most from hiring top-quality development staff, tend to instead pour their money into paying consultancy margins in order to sort out the problems that they create by cutting down on day rates in the first place. &amp;nbsp;At best, they will sometimes be lucky enough to find a consultant who is actually worth the margin they are paying. &amp;nbsp;At worst, they will end up with the cheapest (although still expensive, compared to their in-house staff) consultants they can find and simply "prove" to themselves that more expensive developers are not really worth the extra money. &amp;nbsp;Regardless, they then get rid of the consultancy (in order to cut costs) as soon as the immediate problem is solved - and the cycle begins again.&lt;br /&gt;&lt;br /&gt;Almost laughably, those organisations sometimes then try to address the inadequacies of their minimum-rate development staff by dictating in detail how they should go about their jobs - as if they had a clue themselves!&lt;br /&gt;&lt;br /&gt;To those organisations that I am describing, I would like to note, for the record, that I have personally (on too many occasions,) replaced teams of minimum-rate developers with developers whose day rates are 3 times that of the incumbents and still realised overall cost savings of greater than 50%. &amp;nbsp;(Note that before-and-after comparisons of total development cost are much easier to draw than cross-project comparisons.) &amp;nbsp;While this might keep me employed, (or run off my feet, more often than not,) that employment is (in light of the larger picture I have attempted to paint here,) gainful only to myself and hardly fulfilling. Perhaps it is time to consider another approach?&lt;br /&gt;&lt;br /&gt;&amp;nbsp;The only path to good software is through good software developers.&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-6398016572721341978?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2010/08/good-software-starts-with-good-people.html</link><author>noreply@blogger.com (ADK)</author><thr:total>5</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-6694861871854223408</guid><pubDate>Thu, 28 Jan 2010 11:11:00 +0000</pubDate><atom:updated>2010-01-28T11:54:36.608Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>agile</category><category domain='http://www.blogger.com/atom/ns#'>barely sufficient</category><category domain='http://www.blogger.com/atom/ns#'>scope creep</category><category domain='http://www.blogger.com/atom/ns#'>creeping elegance</category><title>barely sufficient</title><description>I observed a very talented engineering team making a basic mistake today.&lt;br /&gt;&lt;br /&gt;I think we often mis-interpret what 'barely sufficient' means in the context of agile software development and delivery. It is mistakenly interpreted as an excuse to cut down requirements. In reality, I believe it really applies more to engineering and design than to requirements. There are two different syndromes to be careful of in a software project - 'scope creep' and 'creeping elegance'.&lt;br /&gt;&lt;br /&gt;In an agile methodology, we iterate through cycles of 'design a little', 'code a little', 'test a little'. We embarq on writing software often without fully understanding the problem. I am a big fan of this vs up front. Personally, I pretty much think on the keyboard as I believe, people learn incrementally. That said, I am aware always that there is a risk in this mode until I have a full grasp of the problem. My energy is always directed towards activities or areas that help me flesh out unknowns. Whilst in this mode, I 'hack' for speed and refactor only after I think I have my arms around the business problem.&lt;br /&gt;&lt;br /&gt;What I found the team doing was laying the 'foundation' down aka building middleware.  That by itself wasnt a problem, however, they had taken their eyes of the business problem and failed to deliver the results in the needed timeframe.&lt;br /&gt;&lt;br /&gt;Programming competitions are a great way to teach developers this mindset. You have a fixed duration so you have to be quick. You have to focus on the problem and only the problem .. no deviating onto bunny trails. You have to solve the problem in the simplest quickest way. As engineers, we love complexity so, the last discipline is the hardest.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-6694861871854223408?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2010/01/barely-sufficient.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>2</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-9184118135842082993</guid><pubDate>Thu, 04 Jun 2009 17:04:00 +0000</pubDate><atom:updated>2009-06-04T18:09:05.173+01:00</atom:updated><title>Service granularity and re-use</title><description>&lt;div&gt;Architects in the IT organisation where I work display an interesting tendency to equate re-usabilty with granularity.  The received wisdom seems to be that the more granular a service is, the more re-useable it is.  To a certain extent it is useful to have the ability to mix and match just the bits of functionality you require.  This becomes detrimental at the point where it starts to push behaviour to toward the consuming systems, of which there are usually more than one.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;As a case in point, a new system is being written, which (among other things) exposes the ability to lookup items in a cache.  It employs a side-caching strategy to do this.  It's API looks something like this:&lt;/div&gt;&lt;div&gt;&lt;/div&gt;&lt;blockquote&gt;&lt;div&gt;MyItemCache&lt;/div&gt;&lt;div&gt;    findItem(itemId : String) : Item&lt;/div&gt;&lt;div&gt;    createItem(item : Item)&lt;/div&gt;&lt;/blockquote&gt;&lt;div&gt;Consumers of this service will call findItem() to check for the item in the cache, using the Item if it is there.  If the Item is not there, they are expected to fetch the Item from the source system - which is a different system entirely - and then add it to the cache, using createItem().&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;There are a number of issues with this approach.&lt;/div&gt;&lt;div&gt;* The fact that the cache is a side cache (and therefore does not front the source system) means that consumers of this cache must also have knowledge of the source system - making the overall architecture more complicated and brittle.&lt;/div&gt;&lt;div&gt;* Each consuming system is expected to implement over again the logic required to check in the cache, then fetch and add the Item if it is not already cached.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;While this last point may seem like a small amount of code to write, it should be remembered that forcing each client system to re-implement this logic means that the difficultly of changing this logic is multiplied by the number of client systems, with all the associated co-ordination of teams that this involves.  Add to that the impact that differing or buggy implementations might add to the mix and you have a problem far more damaging that the cost of a few lines of code.&lt;/div&gt;&lt;div&gt;&lt;br /&gt;&lt;/div&gt;&lt;div&gt;An alternative approach, which would eliminate both of these problems, would be to make the cache a through-cache, with the cache itself handling the "if not cached: fetch from source" behaviour. Having eliminated the need to manually add things to the cache, the service interface is simplified, as follows:&lt;/div&gt;&lt;div&gt;&lt;/div&gt;&lt;blockquote&gt;&lt;div&gt;MyService&lt;/div&gt;&lt;div&gt;    findItem(itemId : String) : Item&lt;/div&gt;&lt;/blockquote&gt;&lt;div&gt;Client systems are then relieved of responsibility for implementing this logic over and over, and need not have knowledge of yet another system.  Re-use is enhanced, while complexity is reduced.  Everyone is happy!  :-)&lt;/div&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-9184118135842082993?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2009/06/service-granularity-and-re-use.html</link><author>noreply@blogger.com (ADK)</author><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-2470933624191757449</guid><pubDate>Fri, 02 May 2008 19:13:00 +0000</pubDate><atom:updated>2008-05-12T00:03:22.133+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>Performance engineering</category><title>Performance Engineering</title><description>A good &lt;a href="http://www.theserverside.com/tt/articles/article.tss?l=PerformanceEngineering"&gt;article &lt;/a&gt;from Alok Mahajan &amp;amp; Nikhil Sharma from Infosys ! Am quite stunned to be frank.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-2470933624191757449?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2008/05/performance-engineering.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>5</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-5976154192299878243</guid><pubDate>Tue, 18 Mar 2008 22:22:00 +0000</pubDate><atom:updated>2008-03-18T22:28:45.143Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>agile</category><category domain='http://www.blogger.com/atom/ns#'>colocation</category><title>on colocation</title><description>One of the interesting things I found was the impact of colocation on the productivity of teams. &lt;br /&gt;&lt;br /&gt;Consider a team of six people working on a module. Try this out .. place them at random seats within an office floor out of line of sight from each other. What you will find is that they may as well be in different countries. &lt;br /&gt;&lt;br /&gt;Now place them in a six person pod or cubicles adjescent to each other. You will be amazed at the difference this makes in their productivity. &lt;br /&gt;&lt;br /&gt;Back in 96, I was amazed one day to find one team started the habit of standing up on their desks (across six partitioned cubicles) for a daily quick discussion / debrief. It was quite funny as this was before the days of 'agile' and 'standups' etc. They found it quite effective to just stand up on their desks and confer when they had a quick team decision to make. &lt;br /&gt;&lt;br /&gt;Just something that make me smile back then.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-5976154192299878243?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2008/03/on-colocation.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>6</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-7273120333006801540</guid><pubDate>Sun, 09 Mar 2008 08:56:00 +0000</pubDate><atom:updated>2008-03-09T10:26:02.922Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>systems integration</category><category domain='http://www.blogger.com/atom/ns#'>delivery hubs</category><title>running systems integration delivery hubs</title><description>A large SI (systems integration) project typically involves the requirements, design, development, integration, testing and deployment of an integrated enterprise software release. This typically involves the work of a large number of people spread across numerous teams, typically, across the organization and often across organizational boundaries.&lt;br /&gt;&lt;br /&gt;Ideally, there are only two roles in this setup. A business role and a technical role. The business role represents the 'user' or the 'customer'. They lead on  requirements specification &amp; testing. The technical role lead on design, development, integration and deployment. Of course, each activity involves folks from both roles, however, it is important to keep perspective of who 'leads'. &lt;br /&gt;&lt;br /&gt;The main source of inefficiency within any structure is communication. It is the hardest problem to solve. That is why people with multi-dimensional skills are so much more effective than people with a single dimension or specialized roles. &lt;br /&gt;&lt;br /&gt;Having separate teams perform each specialized function (requirements, design, development, integration, testing, deployment etc) causes havoc as imagine the inefficiency and discontinuity created by the hand-offs. Where possible, such optimizations must be made, however, some specialization is inevitable when you scale up. &lt;br /&gt;&lt;br /&gt;The establishment of the critical roles (leadership) and the required infrastructure is key to success. &lt;br /&gt;&lt;br /&gt;Delivery Hub must-haves. &lt;br /&gt;1&gt; co-location facility with open floor plan, plenty of whiteboards, and 2-3 breakout rooms.&lt;br /&gt;&lt;br /&gt;2&gt; strongest presence from the e2e testing team (ideally also the 'users'). &lt;br /&gt;&lt;br /&gt;3&gt; e2e solution design team (also ideally the integration leads).&lt;br /&gt;&lt;br /&gt;4&gt; representation from each of the component teams (project manager + 2-3 key developers)&lt;br /&gt;&lt;br /&gt;5&gt; e2e test environments - ideally 3. One being production mirror, another one for development-integration and the last being integration-release. The config and release management for the production mirror and integration-release environment must be formally managed to ensure integrity and optimal uptime that allows testing productivity. Expect the dev-int environment to be the most dynamic of the three with daily drops from component teams. &lt;br /&gt;&lt;br /&gt;6&gt; Core delivery hub roles :&lt;br /&gt;a&gt; overall program lead with program management support&lt;br /&gt;b&gt; overall architect / design lead (ideally also the integration lead)&lt;br /&gt;c&gt; overall business lead (requirements, business process etc.)&lt;br /&gt;d&gt; testing lead (ideally also the requirements lead)&lt;br /&gt;e&gt; test/config management lead (manages change control and integrity of the test environments, also ideally leads the software deployment to production)&lt;br /&gt;f&gt; deployment lead (focussed on pulling together all aspects of the deployment - training, data grooming, documentation, systems conversion &amp; cut-over etc.)&lt;br /&gt;g&gt; e2e support lead (service management including e2e monitoring)&lt;br /&gt;&lt;br /&gt;7&gt; Daily program stand-up. I always did a 6 pm (1 hr) stand-up every day that helped bring focus to our execution.&lt;br /&gt;&lt;br /&gt;In the project, there are three key phases that you will encounter. Am assuming that some form of agile or spiral methodology is used, so, these phases while unique, may not represent a distinct milestone. You will know when you are in each phase and effort must be made to prioritize activities that allow you to move to the next phase. &lt;br /&gt;&lt;br /&gt;Phase I: This is where the requirements and design are still under a fair amount of churn and incomplete. &lt;br /&gt;Phase II: The scope is now locked down, the designers have more or less finished their stuff with the developers now with plenty to do and on the critical path. &lt;br /&gt;Phase III: Testing / integration is critical path with the developers and designers fixing defects. &lt;br /&gt;&lt;br /&gt;&lt;INSERT DIAGRAM HERE&gt;&lt;br /&gt;&lt;br /&gt;The diagram above gives you a sense of the dynamics and activities in the project. A couple of core principles to highlight.&lt;br /&gt;a&gt; In phase I, it is the designers that are under stress. All help to make them productive. What this really means is that component development teams help with the e2e solution design and not wait to be spoon fed a document. The burden is really more the feeling of being the bottleneck than the technical challenge. This also solves another standard pitfall in that it improves the efficiency of knowledge transfer from design to development. &lt;br /&gt;b&gt; Tight requirement documentation and change control from the start is a must.&lt;br /&gt;c&gt; Test case development starts with the requirements .. ideally, use cases are translated to test scenarios from the start. Data setup demands for the test environments are looked at from the start.&lt;br /&gt;d&gt; In phase II, force early drops from the development teams. Any and all early feedback from the 'users' and 'testers' helps derisk the project. Early integration = SUCCESS ! Get into the specify/design-code-integrate-test spiral as quickly as possible. In this phase, give as much flexibility to the development teams. Anticipate frustration from the testers due to quality and downtime of test environments. Do not underestimate the value of this although .. this is crucial that they stay engaged and provide any and all early feedback. The only thing to not compromise with the development teams is releasing into test. In this phase, testers are usually buddies with the developers. &lt;br /&gt;e&gt; This is where testers become antagonistic towards the developers. Here the balance shifts to testing productivity. You must favor discipline in release management for test environments over the development team's inclination to fix (aka change) things constantly. &lt;br /&gt;&lt;br /&gt;On the e2e project plan : &lt;br /&gt;The critical artifact for me was what I called the 'component integration matrix'. It was a simple spreadsheet that had a breakdown of functionality of the enterprise release on one axis and the components on the other. The solution design outlines which components are involved for each functional grouping. The program managers working with the component delivery managers would work out the release dates and software versions for their components ready for integration. The easy optimization that this allowed was to align/prioritize the work for each component so that e2e functional threads would be completed as a priority thereby allowing the e2e test teams to get going. Of course, in parallel to the design, the test teams aligned their e2e test cases to each of these horizontals and reported test coverage along these lines. That way, I could in a single spreadsheet see the convergence and critical path of the program from a software development and integration perspective. &lt;br /&gt;&lt;br /&gt;&lt;INSERT EG. HERE&gt;&lt;br /&gt;&lt;br /&gt;This was always more useful than the prettiest gantt charts. It is only finalizing this that gave me any sense of a target date, so, completing this was always a priority. &lt;br /&gt;&lt;br /&gt;-------------------------------&lt;br /&gt;NB&gt; This is by no means expected to represent a comprehensive view of the subtleties or complexities within a delivery hub ... just some food for thought. This represents 15 years of experience brain dumped within 30 mins so take it for value added.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-7273120333006801540?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2008/03/running-systems-integration-delivery.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>2</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-4980019808436421499</guid><pubDate>Tue, 20 Nov 2007 12:47:00 +0000</pubDate><atom:updated>2007-11-20T12:51:58.203Z</atom:updated><title>It's not done until it's deployed and working!</title><description>It may amaze some people, but there are still development teams out there that think their job is done when they hand over to the test team.  It should be obvious to everyone that the business derives no value from a system until it is deployed and working.  Finger pointing and claiming that "it works on my machine" doesn't make money for the business!&lt;br /&gt;&lt;br /&gt;Scripting or otherwise automating the deployment of an application is an invaluable aid to the whole development process.  It speeds the process, thereby reducing the code/test feedback cycle.  Even more importantly, it makes the process repeatable.  The same script used for deployment to test should be used for deployment to production, thereby exercising the deployment scripts as part of the test cycle.&lt;br /&gt;&lt;br /&gt;Likewise, if your project has difficulty with deployments, having a developer present during production deployments will pay dividends. There is nothing like first hand experience for bringing home to the development team the issues faced when their application is used in anger.&lt;br /&gt;&lt;br /&gt;Until you have confidence that your deployment will go perfectly every time, involve the development team in every production deployment.  And make automated deployment a requirement of every development project.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-4980019808436421499?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/11/its-not-done-until-its-deployed-and.html</link><author>noreply@blogger.com (ADK)</author><thr:total>3</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-3864137081540957970</guid><pubDate>Sun, 11 Nov 2007 18:09:00 +0000</pubDate><atom:updated>2007-11-11T18:43:37.089Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>wikipedia</category><title>wikipedia</title><description>Wikipedia - continues to amaze me every day.&lt;br /&gt;&lt;br /&gt;I am often faced with situations I have absolutely no technical information or background on. All Believe it or not, in many situations, all I have as starting tools are my instincts. However, this is rapidly corrected by good ol' google search and wikipedia lookups although, I still do miss speed reading documentation in book form.&lt;br /&gt;&lt;br /&gt;On vacation with nothing better to do than just relax, I came across these amazing pictures ..&lt;br /&gt;&lt;a href="http://en.wikipedia.org/wiki/Wikipedia:Featured_pictures"&gt;http://en.wikipedia.org/wiki/Wikipedia:Featured_pictures&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;div style="padding:.5em 0em .5em 0em; text-align:center; margin:auto; width:100%;"&gt;&lt;b&gt;English Wikipedia Featured Pictures&lt;/b&gt;&lt;/div&gt;&lt;br /&gt;&lt;div style="overflow-x:scroll;overflow-y:hidden;"&gt;&lt;br /&gt;&lt;div style="width:9500px;"&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Mandel_zoom_10_satellite_seehorse_valley.jpg" class="image" title="Mandel zoom 10 satellite seehorse valley.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/8/89/Mandel_zoom_10_satellite_seehorse_valley.jpg/333px-Mandel_zoom_10_satellite_seehorse_valley.jpg" width="333" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Incandescence.jpg" class="image" title="Incandescence.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/1/1b/Incandescence.jpg/166px-Incandescence.jpg" width="166" height="249" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:NASA-Apollo8-Dec24-Earthrise.jpg" class="image" title="NASA-Apollo8-Dec24-Earthrise.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/a/a8/NASA-Apollo8-Dec24-Earthrise.jpg/250px-NASA-Apollo8-Dec24-Earthrise.jpg" width="250" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Global_tropical_cyclone_tracks-edit2.jpg" class="image" title="Global tropical cyclone tracks-edit2.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/2/23/Global_tropical_cyclone_tracks-edit2.jpg/500px-Global_tropical_cyclone_tracks-edit2.jpg" width="500" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Yellow-rattle_close_700.jpg" class="image" title="Yellow-rattle close 700.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/4/43/Yellow-rattle_close_700.jpg/189px-Yellow-rattle_close_700.jpg" width="189" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:World_Map_1689.JPG" class="image" title="World Map 1689.JPG"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/3/3b/World_Map_1689.JPG/290px-World_Map_1689.JPG" width="290" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Divers_-_Illustrated_London_News_Feb_6_1873-2.PNG" class="image" title="Divers - Illustrated London News Feb 6 1873-2.PNG"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/4/42/Divers_-_Illustrated_London_News_Feb_6_1873-2.PNG/200px-Divers_-_Illustrated_London_News_Feb_6_1873-2.PNG" width="200" height="249" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:SeattleI5Skyline.jpg" class="image" title="SeattleI5Skyline.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/3/36/SeattleI5Skyline.jpg/417px-SeattleI5Skyline.jpg" width="417" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Grapevinesnail_01.jpg" class="image" title="Grapevinesnail 01.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/6/69/Grapevinesnail_01.jpg/424px-Grapevinesnail_01.jpg" width="424" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Apollo_11_bootprint.jpg" class="image" title="Apollo 11 bootprint.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/8/89/Apollo_11_bootprint.jpg/248px-Apollo_11_bootprint.jpg" width="248" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Yarra_Night_Panorama%2C_Melbourne_-_Feb_2005.jpg" class="image" title="Yarra Night Panorama, Melbourne - Feb 2005.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/8/8d/Yarra_Night_Panorama%2C_Melbourne_-_Feb_2005.jpg/655px-Yarra_Night_Panorama%2C_Melbourne_-_Feb_2005.jpg" width="655" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Early_flight_02561u_%284%29.jpg" class="image" title="Early flight 02561u (4).jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/4/4a/Early_flight_02561u_%284%29.jpg/171px-Early_flight_02561u_%284%29.jpg" width="171" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Haeckel_Spumellaria.jpg" class="image" title="Haeckel Spumellaria.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/0/0c/Haeckel_Spumellaria.jpg/176px-Haeckel_Spumellaria.jpg" width="176" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:St_Vitus_stained_glass.jpg" class="image" title="St Vitus stained glass.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/8/8e/St_Vitus_stained_glass.jpg/376px-St_Vitus_stained_glass.jpg" width="376" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Anser_cygnoides.jpg" class="image" title="Anser cygnoides.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/1/15/Anser_cygnoides.jpg/375px-Anser_cygnoides.jpg" width="375" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Moons_of_solar_system_v7.jpg" class="image" title="Moons of solar system v7.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/4/4f/Moons_of_solar_system_v7.jpg/354px-Moons_of_solar_system_v7.jpg" width="354" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Cuban_missiles.jpg" class="image" title="Cuban missiles.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/en/thumb/5/57/Cuban_missiles.jpg/247px-Cuban_missiles.jpg" width="247" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Eyjafjallaj%C3%B6kull.jpeg" class="image" title="Eyjafjallajökull.jpeg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/8/8e/Eyjafjallaj%C3%B6kull.jpeg/373px-Eyjafjallaj%C3%B6kull.jpeg" width="373" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Coyote_portrait.jpg" class="image" title="Coyote portrait.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/7/73/Coyote_portrait.jpg/438px-Coyote_portrait.jpg" width="438" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:STS-116_spacewalk_1.jpg" class="image" title="STS-116 spacewalk 1.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/8/89/STS-116_spacewalk_1.jpg/379px-STS-116_spacewalk_1.jpg" width="379" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Two_Gannets_edit_2.jpg" class="image" title="Two Gannets edit 2.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/7/76/Two_Gannets_edit_2.jpg/375px-Two_Gannets_edit_2.jpg" width="375" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Salad_platter.jpg" class="image" title="Salad platter.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/9/94/Salad_platter.jpg/375px-Salad_platter.jpg" width="375" height="250" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Cricket_fielding_positions2.svg" class="image" title="Cricket fielding positions2.svg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/9/9a/Cricket_fielding_positions2.svg/187px-Cricket_fielding_positions2.svg.png" width="187" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Mark_48_Torpedo_testing.jpg" class="image" title="Mark 48 Torpedo testing.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/5/51/Mark_48_Torpedo_testing.jpg/388px-Mark_48_Torpedo_testing.jpg" width="388" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Seagull_on_sale_pier.jpg" class="image" title="Seagull on sale pier.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/f/ff/Seagull_on_sale_pier.jpg/373px-Seagull_on_sale_pier.jpg" width="373" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Lion_waiting_in_Nambia.jpg" class="image" title="Lion waiting in Nambia.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/1/10/Lion_waiting_in_Nambia.jpg/333px-Lion_waiting_in_Nambia.jpg" width="333" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Washington_Monument_Dusk_Jan_2006.jpg" class="image" title="Washington Monument Dusk Jan 2006.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/c/c1/Washington_Monument_Dusk_Jan_2006.jpg/188px-Washington_Monument_Dusk_Jan_2006.jpg" width="188" height="250" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Joan_of_Arc-Notre_Dame.jpg" class="image" title="Joan of Arc-Notre Dame.jpg"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/e/eb/Joan_of_Arc-Notre_Dame.jpg/187px-Joan_of_Arc-Notre_Dame.jpg" width="187" height="249" border="0" /&gt;&lt;/a&gt;&lt;a href="http://en.wikipedia.org/wiki/Image:Mahdist_in_the_Khalifa%27s_house%2C_Omdurman%2C_Sudan.png" class="image" title="Mahdist in the Khalifa's house, Omdurman, Sudan.png"&gt;&lt;img alt="" src="http://upload.wikimedia.org/wikipedia/commons/thumb/2/20/Mahdist_in_the_Khalifa%27s_house%2C_Omdurman%2C_Sudan.png/198px-Mahdist_in_the_Khalifa%27s_house%2C_Omdurman%2C_Sudan.png" width="198" height="250" border="0" /&gt;&lt;/a&gt;&lt;/div&gt;&lt;br /&gt;&lt;/div&gt;&lt;br /&gt;&lt;br /&gt;&lt;p&gt;&lt;br /&gt;&lt;/p&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-3864137081540957970?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/11/wikipedia.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>0</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-6256936092641323145</guid><pubDate>Fri, 02 Nov 2007 15:23:00 +0000</pubDate><atom:updated>2008-12-11T16:35:14.177Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>adsl</category><category domain='http://www.blogger.com/atom/ns#'>dsl speed problems</category><category domain='http://www.blogger.com/atom/ns#'>broadband boost</category><title>double your broadband speed</title><description>&lt;a href="http://2.bp.blogspot.com/_EoOEH3E1dTA/RytBGEjomSI/AAAAAAAAADY/3Un6iiRCDAc/s1600-h/untitled1.GIF"&gt;&lt;img id="BLOGGER_PHOTO_ID_5128264173249665314" style="FLOAT: left; MARGIN: 0px 10px 10px 0px; CURSOR: hand" alt="" src="http://2.bp.blogspot.com/_EoOEH3E1dTA/RytBGEjomSI/AAAAAAAAADY/3Un6iiRCDAc/s320/untitled1.GIF" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;I have been struggling with my DSL service since I moved into this new home. For some reason, my modem was training to 4M instead of the 8M in my previous home. My first reaction was acceptance that this was due to the distance factor from the exchange (which IS a significant factor). However, after months of resentment that life should be better, I decided to do something about it.&lt;br /&gt;&lt;br /&gt;I had suspected that my internal home wiring was a factor. I knew that I should get a boost by changing things around, however, did not expect the level of impact. 15 minutes of investment boosted my speed from 4 MB to 8 MB.&lt;br /&gt;&lt;br /&gt;So here is what I did and some explanation of what was causing the problem.&lt;br /&gt;&lt;br /&gt;In the picture above, scenario A is your typical home internal wiring. The pair comes into the home through a special wall plate (NTE) and is then distributed around the home. This is a spiderweb typically. Worse, there may be other devices using the phone lines .. intercoms, alarm systems, pay-per-view box etc. The ADSL modem is typically on the end of one of these legs so, the signal to the modem has the interference and loss caused by the spiderweb of internal home wiring in addition to the normal loss and interference.&lt;br /&gt;&lt;br /&gt;Scenario B uses a special device called an NTE5 central adsl splitter that plugs into the wall-&lt;a href="http://2.bp.blogspot.com/_EoOEH3E1dTA/RytE3EjomTI/AAAAAAAAADg/cqRcwegRf_Q/s1600-h/t_16134.jpg"&gt;&lt;img id="BLOGGER_PHOTO_ID_5128268313598138674" style="FLOAT: left; MARGIN: 0px 10px 10px 0px; CURSOR: hand" alt="" src="http://2.bp.blogspot.com/_EoOEH3E1dTA/RytE3EjomTI/AAAAAAAAADg/cqRcwegRf_Q/s320/t_16134.jpg" border="0" /&gt;&lt;/a&gt;plate where the copper pair from the exchange enters your home (you will have to do a mini external home survey to find where the pair disappears into the wall into your home).&lt;br /&gt;&lt;br /&gt;&lt;p&gt;You can see from the diagram that the signal to the modem does not have any of the issues with the internal home wiring. This also eliminates the need to put splitters on each and every outlet that has a phone. &lt;/p&gt;This is a 15 min job. Really trivial. Only limitation is that your ADSL modem now has to be located and plugged into this wall plate only. Here is a good link / site that explains further.&lt;br /&gt;&lt;br /&gt;&lt;a href="http://www.broadbandzone.co.uk/shop/centralisedfilter.html"&gt;http://www.broadbandzone.co.uk/shop/centralisedfilter.html&lt;/a&gt;&lt;br /&gt;&lt;br /&gt;The issue of having the ADSL modem locked into one place possibly far away from a computer is really a non-issue now-a-days. Two options / reasons : most ADSL modems now have WIFI built in (G or N standards will be more than enough). Alternately, there are powerline ethernet devices that work very well. What these devices do is basically make your internal home power (220V) cables into a transmission network for ethernet. Fairly pricey still, however, extremely flexible and they work !! I use the &lt;a href="http://www.netgear.com/Products/PowerlineNetworking/PowerlineEthernetAdapters/HDX101.aspx"&gt;NetGear Powerline Ethernet HD adapters&lt;/a&gt; and have no complaints.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-6256936092641323145?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/11/double-your-broadband-speed.html</link><author>noreply@blogger.com (Milan Gupta)</author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://2.bp.blogspot.com/_EoOEH3E1dTA/RytBGEjomSI/AAAAAAAAADY/3Un6iiRCDAc/s72-c/untitled1.GIF' height='72' width='72'/><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-1681465364746388934</guid><pubDate>Thu, 01 Nov 2007 12:30:00 +0000</pubDate><atom:updated>2008-12-11T16:35:14.469Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>IT support maturity model</category><title>Maturing IT support - framework / model</title><description>&lt;a href="http://1.bp.blogspot.com/_EoOEH3E1dTA/RynHGUjomRI/AAAAAAAAADQ/AYRLcaA26Pk/s1600-h/untitled.GIF"&gt;&lt;img id="BLOGGER_PHOTO_ID_5127848562149333266" style="FLOAT: left; MARGIN: 0px 10px 10px 0px; CURSOR: hand" alt="" src="http://1.bp.blogspot.com/_EoOEH3E1dTA/RynHGUjomRI/AAAAAAAAADQ/AYRLcaA26Pk/s320/untitled.GIF" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;&lt;div&gt;&lt;/div&gt;&lt;br /&gt;&lt;p&gt;I find the model I created useful in evaluating where teams stand in their maturity and the kinds of things I ask them to focus on to move up the value chain and improve their performance. &lt;/p&gt;&lt;p&gt;An example, to move from a state of 'managed' to 'measured', I ask teams to put in place measures in the following areas : &lt;/p&gt;&lt;p&gt;A&gt; Business KPI reporting in the context of the system being measured. B&gt; Measures around the utilization of the system (beyond CPU etc.). The most basic is a graph of concurrent user logins at 15 min intervals. More sophesticated is transactional level measures. C&gt; Systems availability reporting which of course is always 99%+. A better way is measuring business impact i.e. #minutes downtime / call centre agent / month.  &lt;/p&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-1681465364746388934?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/11/maturing-it-support-framework-model.html</link><author>noreply@blogger.com (Milan Gupta)</author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://1.bp.blogspot.com/_EoOEH3E1dTA/RynHGUjomRI/AAAAAAAAADQ/AYRLcaA26Pk/s72-c/untitled.GIF' height='72' width='72'/><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-6656404641192032243</guid><pubDate>Thu, 01 Nov 2007 12:06:00 +0000</pubDate><atom:updated>2007-11-01T12:16:49.593Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>systems performance</category><category domain='http://www.blogger.com/atom/ns#'>performance tuning</category><category domain='http://www.blogger.com/atom/ns#'>i've fallen and I can't get up</category><title>I've fallen and I can't get up</title><description>Too often I get a plea for help wherein a development/delivery manager runs into problems taking a system into production. Guess most often where they run into trouble .. yep ! Performance.&lt;br /&gt;&lt;br /&gt;When questioned about the technical details, same old pattern. Lack of understanding of underlying middleware, database, 3rd party tools etc.&lt;br /&gt;&lt;br /&gt;When a team displays such a lack of understanding, what I hear is the team saying to me - "I can code it, however, I don't know how to actually make it work !"&lt;br /&gt;&lt;br /&gt;Performance considerations are intrinsic to good development practices &amp;amp; design. While a focussed effort on performance optimization for a week using a highly skilled team always yields amazing results, it is a bad idea to deliver under that assumption.&lt;br /&gt;&lt;br /&gt;This is often the simple difference between average and good teams.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-6656404641192032243?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/11/ive-fallen-and-i-cant-get-up.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>3</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-8641424948069033082</guid><pubDate>Sun, 16 Sep 2007 17:52:00 +0000</pubDate><atom:updated>2007-09-16T19:01:16.535+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>software reuse</category><category domain='http://www.blogger.com/atom/ns#'>reuse</category><category domain='http://www.blogger.com/atom/ns#'>organizational behavior</category><category domain='http://www.blogger.com/atom/ns#'>IT effectiveness</category><title>reuse</title><description>On reuse within IT. I seem to be talking about this a lot so .. might as well put this down.&lt;br /&gt;&lt;br /&gt;IMHO, I break reuse within IT into the following stages :&lt;br /&gt;&lt;br /&gt;Stage 0 : Reuse teams (just this gets you 60% of the way)&lt;br /&gt;Stage 1 : Reuse design patterns (typically effected by having a clearly articulated architecture and some governance frameworks). This however, may be a legacy of waterfall methodologies.&lt;br /&gt;Stage 2 : Reuse software (libraries, SOA, components etc.)&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-8641424948069033082?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/09/reuse.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-1991738985209060829</guid><pubDate>Sat, 07 Jul 2007 21:43:00 +0000</pubDate><atom:updated>2007-07-07T23:35:03.048+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>Systems monitoring</category><category domain='http://www.blogger.com/atom/ns#'>layered distributed systems</category><category domain='http://www.blogger.com/atom/ns#'>siteminder</category><category domain='http://www.blogger.com/atom/ns#'>enterprise common components</category><category domain='http://www.blogger.com/atom/ns#'>computer associates</category><title>on monitoring enterprise shared/common components</title><description>I had an encounter with a commonly used enterprise component - single sign-on, specifically, a tool called Site-minder (now owned by computer associates).&lt;br /&gt;&lt;br /&gt;First my rant, as this cost me 3 days of my life and a weekend away from my family. While quite a nifty tool and what appears to be a highly scalable platform, I was not prepared for the level of 'blindness' to simple things like throughput and response time. You can get all sorts of information about connections, threads etc. however, the information isn't sufficient within the package to fully monitor what is going in and out of this black-box. Also, no historical graphs in the monitor ? Wait, that is another product you have to buy from CA ? Wouldn't it be awesome if only we could reset the stats/counters at run-time ? That way, you could tune, then reset the stats/counters &amp; re-measure.&lt;br /&gt;&lt;br /&gt;OK. Got that off my chest and it wasn't completely venomous. Believe me, its been a tough week.&lt;br /&gt;&lt;br /&gt;Seriously, shared infrastructure typically have really compelling business cases and yes, there are truly efficiencies to be gained, however, effective monitoring becomes absolutely critical. All eggs in one basket means you save on baskets and runners, however, the stakes for a mistake  go way up !! So you better be careful.&lt;br /&gt;&lt;br /&gt;Shared infrastructure is also more complex to model and monitor, specifically when you are dealing with layered distributed systems. Eg., in the Siteminder model, there are agents that consume transactions (may be locally cached) from a series of policy servers which in turn consume transactions from downstream services, eg. LDAP directory servers, authentication servers ...&lt;br /&gt;&lt;br /&gt;In such a framework, I would closely monitor the following aspects :&lt;br /&gt;- daily/hourly transaction arrival rate from each agent (and the cache rate).&lt;br /&gt;- transaction response time variance (this is a sign of downstream bottlenecks)&lt;br /&gt;- resource consumption in the policy server (no. of threads active/in-use) .. monitor at peak&lt;br /&gt;- above three for each of the downstream consumables.&lt;br /&gt;&lt;br /&gt;If your application support team can do this, they have the first clue about what is going on within their framework else, guess what, tomorrow you may go through what I just went through this past week.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-1991738985209060829?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/07/on-monitoring-enterprise-sharedcommon.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>0</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-6966319824059478672</guid><pubDate>Wed, 25 Apr 2007 11:15:00 +0000</pubDate><atom:updated>2007-04-25T13:05:05.206+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>content control is king</category><category domain='http://www.blogger.com/atom/ns#'>search engine optimization</category><category domain='http://www.blogger.com/atom/ns#'>dark arts</category><title>on the dark arts of search engine optimization</title><description>I have been trying to figure out why I cannot search the internet (&lt;a href="http://www.google.com"&gt;google&lt;/a&gt;, &lt;a href="http://www.msn.com"&gt;msn&lt;/a&gt;, &lt;a href="http://www.yahoo.com"&gt;yahoo &lt;/a&gt;...) and get to my blog even after doing an exact search for keyword combinations exclusive to my blog. What opened up to me is a whole new world. I know, I know, I am obsolete .. what world have I been living in ?! I am an old UNIX/C guy and html/xml really doesnt classify as programming to me. I now feel bad about poking fun at the mainframe guys back in the 90s. In saying that, now I really feel old !! I digress, sorry for the soapbox. &lt;br /&gt;&lt;br /&gt;My quest is to get a hit in google search using a combination of my name and 'knownbugs' keywords. Should be unique with the top hit bringing me to the website hosted on google blogspot .. big assumption being the search engines give you results ordered by relevance (occurence of all keywords). &lt;br /&gt;&lt;br /&gt;Well, not quite so. So, reading up on recommendations, I first researched &lt;a href="http://en.wikipedia.org/wiki/Tagging"&gt;tagging&lt;/a&gt;. &lt;a href="http://support.technorati.com/support/siteguide/tags"&gt;Technorati tags &lt;/a&gt;is an emerging 'power player' in the world of blogs. Supposedly, 'labels', 'titles', 'headers' in blog content/articles should be automatically picked up by the Technorati engine (invoked when you 'ping'). Alternatively, you can force a tag by using the 'Technorati Tags' method. &lt;br /&gt;&lt;br /&gt;Even so, this only makes your tags visible within &lt;a href="http://www.technorati.com"&gt;Technorati's blog search&lt;/a&gt;. For the normal google internet search, blog content hosted on blogspot appears invisible, however, on &lt;a href="http://www.google.co.uk/blogsearch?hl=en"&gt;google's blog search&lt;/a&gt;, it works. &lt;br /&gt;&lt;br /&gt;I also did the wait 30 days and magic will happen thing. This is what some recommend as the time it takes for &lt;a href="http://en.wikipedia.org/wiki/Web_crawler"&gt;spiders &lt;/a&gt;to crawl your content. &lt;br /&gt;&lt;br /&gt;So, further tricks/tips. I am now in the process of getting a custom domain name. &lt;a href="http://godaddy.com"&gt;Godaddy.com&lt;/a&gt; offers cheap registrar services. My selection - &lt;a href="http://www.knownbugs.org"&gt;www.knownbugs.org&lt;/a&gt; (or .info, .net, .biz .. unfortunately, .com was taken by someone who wants to make money by selling the name). &lt;br /&gt;&lt;br /&gt;What a custom domain name will do, is treat the blog content as regular www content and hopefully allow the search engine &lt;a href="http://en.wikipedia.org/wiki/Web_crawler"&gt;'spiders' &lt;/a&gt;to index the content making it visible in the regular google search world. &lt;br /&gt;&lt;br /&gt;I suspect, I will find other gotchas as there clearly is money at play here. &lt;br /&gt;&lt;br /&gt;Instead of us being in the age of 'content in king', we appear to be living in the age of 'content control is king'. Here is where there is a war going on. The behemoths - google, microsoft, yahoo .. all at play. &lt;br /&gt;&lt;br /&gt;'Influencing' search engines is worth a lot of money nowadays. A massive amount of complexity behind the scenes with 'SEC' or &lt;a href="http://en.wikipedia.org/wiki/Search_engine_optimization"&gt;search engine optimization &lt;/a&gt;being a real growth area. I worry ! &lt;br /&gt;&lt;br /&gt;I worry about such central control on information access, however, hacks like us always have a way of breaking free. &lt;br /&gt;&lt;br /&gt;More as my quest progresses !! Am still waiting for the DNS servers to update so expect to be redirected to www.knownbugs.org when you go to knownbugs.blogspot.com shortly.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-6966319824059478672?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/04/on-dark-arts-of-search-engine.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>2</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-3113363826942184876</guid><pubDate>Tue, 24 Apr 2007 15:31:00 +0000</pubDate><atom:updated>2007-04-24T17:16:25.935+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>sequential analysis</category><category domain='http://www.blogger.com/atom/ns#'>ETA bait</category><category domain='http://www.blogger.com/atom/ns#'>pitfalls in outage situations</category><category domain='http://www.blogger.com/atom/ns#'>debugging in live</category><category domain='http://www.blogger.com/atom/ns#'>trial and error</category><category domain='http://www.blogger.com/atom/ns#'>sequential execution</category><title>common pitfalls in outage/crisis situations</title><description>Teams dealing with outages typically suffer the following behavioral problems. Some of these conflict with each other in aims .. there isn't unfortunately a set formula I can come up with as each situation has its own variables/complexities. A standardized process/template however, would be great ! &lt;br /&gt;&lt;br /&gt;1&gt; Trial and error&lt;br /&gt;Don't fall for this. You know you are in trouble when you get ambiguity from the technical teams. If you are stuck, ask yourself what can you do to get additional information onto the table. Often, you will find teams stuck 'enjoying' the problem because they have no method for infusing new information or experience into the problem diagnosis. Doing things trial &amp; error mode also force you into a sequential analysis mode. Also, this leads to the '2 hr ETA bait' (see below). &lt;br /&gt;&lt;br /&gt;2&gt; Debugging in live&lt;br /&gt;While prevention of recurrence is key and that requires some investment in analysis / data collection during an outage, it MUST be capped. Do not fall into the trap of ... "give me 20 more minutes, I have almost figured it out ..". You will hate yourself later. Walk into the situation with a time limit in your mind upon which you will trigger a failsafe way of restoring service. Communicate that upfront to the team (I am assuming that you have a failsafe procedure to restart the system to restore service that you will trigger on .. may be something as simple as rebooting the servers). Of course, best practice is that you always execute the failsafe and never debug in live, however, that requires a significant investment in test infrastructures that are capable of reproducing the problem. Remember, there is a value to getting to true root cause as that is the only way you will prevent recurrence. &lt;br /&gt;&lt;br /&gt;3&gt; Sequential analysis&lt;br /&gt;Distinguish 'sequential analysis' from 'sequential execution'. Sequential execution is good, sequential analysis is BAD. On the analysis side, you should try to split off multiple teams (assuming you have the resources) on different aspects of the problem. That allows you to cover all bases quickly vs. an elongated recovery path where you are problem solving only one thing at a time. Sequential execution is GOOD because you want to introduce only one variable at a time else, you will break the cause and effect chain. Usually, problem solving is about eliminating variables and then incrementally fixing one thing at a time using a measured/scientific approach. &lt;br /&gt;&lt;br /&gt;4&gt; 2 hr ETA bait ...&lt;br /&gt;Setting expectations on 'expected time to restoral' is really really hard. Here is the dark art of estimation at its finest. Setting no expectation is unacceptable (it will be fixed when it is fixed .. attitude).  Your business partners/users will not be as upset about an outage as they will be about setting false expectations. Usually, a significant outage will require operational teams to build workaround/catch up plans where they may have to staff overtime or weekends. These plans depend on your estimates. &lt;br /&gt;&lt;br /&gt;And .. what's worse is none of your technology suppliers / partners will co-operate.&lt;br /&gt;&lt;br /&gt;On crisis situations with financial implications, vendors get very very conservative or worse, clam up ! In a crisis situation, you always will feel the information is inadequate to make a decision or set an expectation. I usually follow my instincts here (of course, harnessing whatever facts are available on the situation).  Don't try this unless you have the right technical experience.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-3113363826942184876?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/04/common-pitfalls-in-outagecrisis.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-3703447029913654900</guid><pubDate>Tue, 24 Apr 2007 15:00:00 +0000</pubDate><atom:updated>2007-04-24T17:13:46.042+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>enterprise support</category><category domain='http://www.blogger.com/atom/ns#'>microsoft</category><category domain='http://www.blogger.com/atom/ns#'>bea</category><category domain='http://www.blogger.com/atom/ns#'>oracle</category><title>enterprise support from technology partners</title><description>Five years ago, I was pounding Microsoft on their lack of understanding of enterprise support. It is amazing how far they have come. I remember a couple of years back, an incident relating to a system based on SQL server. It was terrible !! The answers back from Microsoft were very casual .. try this patch ! Of course, nothing being hot patchable however, luckily not requiring a complete rebuild of WindowsNT server, an hour later when we figured that didn't work, the answer was, OK, try this now. We felt really foolish architecting a mission critical enterprise application on SQL server. &lt;br /&gt;&lt;br /&gt;Microsoft has really come a long way since that. I was very pleasantly surprized in a recent encounter on how they have matured. Their crisis technical lead was clear, crisp, unfazed by pressure and clearly knew what he was talking about. That instilled confidence. He knew how to distill and present the facts and avoid making false promises. Also, their follow-the-sun model actually worked !! The transitions were seamless with knowledgement transfer occuring behind the scene and a warm hand-off with 1 hr overlap. Their account team was on the ball and follow-up and follow through was perfect. In fact, they chased me !! &lt;br /&gt;&lt;br /&gt;Other examples of great support I have received are from BEA. BEA's account manager takes the unique honor of being the only sales guy I know who stuck with me for 36 hours straight during a crisis situation helping with anything he could (including doing the coffee rounds). I never believed a sales guy had that kind of stamina ;-). Oracle's down systems group are also top notch. &lt;br /&gt;&lt;br /&gt;Technology partners usually have to support crisis situations remotely. They will depend on you for information and one of the challenges is to be able to supply it to them - real-time. Simple things like file-size limits in your email servers can look like bad ideas in these circumstances. Firewalls are a fact of life so, have a strategy on how your technology partners get access to your systems/intranet when you need them to.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-3703447029913654900?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/04/enterprise-support-from-technology.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-4767140497543374910</guid><pubDate>Tue, 24 Apr 2007 14:42:00 +0000</pubDate><atom:updated>2007-04-24T16:00:09.531+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>crisis bridge protocol</category><title>crisis bridge protocol</title><description>When dealing with outage situations, it is important to establish a clear bridge protocol for the participants. Hopefully, you won't have to go through these on each call as this will contribute to your MTTR (remember, you are in an outage/crisis situation). &lt;br /&gt;&lt;br /&gt;a&gt; one person speak at a time&lt;br /&gt;b&gt; identify the lead (hopefully you !)&lt;br /&gt;c&gt; people mute when not speaking&lt;br /&gt;d&gt; people not put you on hold (most PBXs will play music for the rest of the participants)&lt;br /&gt;e&gt; mute if you want to have a sidebar conversation&lt;br /&gt;f&gt; remember, if you go to sleep, you will be spotted because of your snoring&lt;br /&gt;g&gt; no calling from a cell phone (or c becomes very important)&lt;br /&gt;h&gt; establish clearly the participants and their role/what function they represent&lt;br /&gt;&lt;br /&gt;Traditional conference bridges are slowly evolving into a multimedia facility - IM session in parallel is becoming commonplace with Netmeeting/Livemeeting quickly following. At Qwest, it was nice to have the facility to dial into an 800 number and then select a sub-bridge (option 1..9). That way, the main bridge team could quickly branch sub-teams off without confusion and avoid wasting time on communicating bridge numbers. &lt;br /&gt;&lt;br /&gt;Separate out from the start a management bridge, customer bridge and the technical bridge. Chaos ensues if you mix them all into one.&lt;br /&gt;&lt;br /&gt;Just my two minutes of brain dump .. will add more as I flesh this out/collect my thoughts.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-4767140497543374910?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/04/crisis-bridge-protocol.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>0</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-200713081906112099</guid><pubDate>Tue, 24 Apr 2007 14:16:00 +0000</pubDate><atom:updated>2007-04-24T15:41:32.747+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>Systems monitoring</category><category domain='http://www.blogger.com/atom/ns#'>historical performance reporting</category><title>Systems monitoring - historical views - best practice</title><description>One of the best things I have seen is the standardized use of a monitoring framework with historical reporting for the technical aspects of a system (CPU, i/o, network, memory, database, kernel ..). &lt;br /&gt;&lt;br /&gt;There are several tools out there in the marketplace that do this. IBM Tivoli, HP Openview, BMC, EMC SMARTS (and then some), all offer solutions along these lines. The key is to instrument agents / data collectors across the estate (on each server) and have a central database &amp; reporting web-site that allows IT folks to select a node and display historical results around a wide variety of technical aspects. The value seems ambiguous, however, let me tell you that it makes my life much much easier. &lt;br /&gt;&lt;br /&gt;When in crisis mode, this data helps immensely. It is crucial data that tells you when something changed. It allows technical teams to quickly focus, analyze and resolve a set of issues that normally are thorny and contribute to large MTTR numbers on problem incidents. Yes, logging into the box and monitoring real time tells you there is a problem, however, a historical view tells you when something changed. Also, this is crucial for another best practice - server capacity management and monitoring. &lt;br /&gt;&lt;br /&gt;The key is universal rollout / standardization. Don't get trapped in the technology selection mode. Pick one and implement universally. This isn't difficult work, however, best implemented within your server provisioning process so that anything new automatically has the standardized framework. &lt;br /&gt;&lt;br /&gt;It is amazing how telling something as simple as a historical CPU profile is. You see processing/business utilization patterns, exactly when backups occur, batch jobs etc. and more importantly, when something CHANGED.&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-200713081906112099?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/04/systems-monitoring-historical-views.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>2</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-4107927211821768163</guid><pubDate>Wed, 07 Mar 2007 04:19:00 +0000</pubDate><atom:updated>2007-04-23T17:07:19.667+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>database maintenance</category><category domain='http://www.blogger.com/atom/ns#'>cpu profile</category><category domain='http://www.blogger.com/atom/ns#'>oracle</category><category domain='http://www.blogger.com/atom/ns#'>analyze table</category><title>database maintenance</title><description>&lt;a href="http://technorati.com/tag/oracle" rel="tag"&gt;Oracle&lt;/a&gt; &lt;a href="http://technorati.com/tag/database%20maintenance" rel="tag"&gt;database maintenance&lt;/a&gt;.&lt;br /&gt;&lt;br /&gt;One recurring theme I see with junior dbas is the lack of understanding of the '&lt;a href="http://technorati.com/tag/analyze%20table" rel="tag"&gt;analyze table&lt;/a&gt;' proceedure. This is crucial for proper database performance. Can be scheduled  once a week or more frequently based on system profile.&lt;br /&gt;&lt;br /&gt;Basically, the 'analyze table' command gathers statistics on the table and stores them internally as hints for the query optimizer. Indexes are picked up based on these statistics. For dynamic tables (large growth or shrinkage or changes to key indexed fields), it is imperative this is performed frequently. For safety, run it anyway after key database operations.&lt;br /&gt;&lt;br /&gt;Know what 'good' looks like for your system. Baseline and save (better still commit to memory) the key behavioral aspects of your system eg. cpu utilization profile, throughput, response times, i/o levels etc. That way, you will know when this profile changes and will be a key trigger for you to action for early detection of problems. More importantly, when you implement change, you should compare the before and after profile of your system.&lt;br /&gt;&lt;br /&gt;&lt;a href="http://technorati.com/tag/milan%20gupta" rel="tag"&gt;Milan Gupta&lt;/a&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-4107927211821768163?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/03/database-maintenance.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-8396204092919474672</guid><pubDate>Sat, 03 Mar 2007 11:14:00 +0000</pubDate><atom:updated>2007-04-23T16:22:52.900+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>change management</category><category domain='http://www.blogger.com/atom/ns#'>change</category><title>Change  management</title><description>The first question I ask a team when something breaks is &lt;em&gt;what changed &lt;/em&gt;?. 99% of problems end up relating to change. Amazing !!&lt;br /&gt;&lt;br /&gt;I did not put &lt;em&gt;change&lt;/em&gt; as the top problem within my post on what keeps me busy because I believe that change is good. It is necessary and as inevitable as evolution.  It is necessary for healthy growth. So IT cannot take the simplistic approach of 'if it ain't broke, don't fix it!'.&lt;br /&gt;&lt;br /&gt;Any decent sized telco typically has an IT estate of 3000+ systems, 50K+ computing assets and 10K+ people all changing stuff. Is it any surprise that systems availability &amp; stability actually goes up during christmas ?&lt;br /&gt;&lt;br /&gt;What is key to establishing a high performance IT organization is managing change effectively. It is instrumental to have a proper inventory of systems, more importantly, their inter-dependencies and impact on business process. Most importantly, a team that understands this model.&lt;br /&gt;&lt;br /&gt;While end-to-end testing frameworks can flesh out unexpected side-effects of change, it isn't reasonable to expect that all work will go through this framework. With 10K+ employees, there will be leakage and impact. Specifically around stuff that you would least suspect.&lt;br /&gt;&lt;br /&gt;Proper and effective change management framework would consist of the following :&lt;br /&gt;&lt;ul&gt;&lt;li&gt;A team as described above that performs the function of a change approval board (centralized or decentralized)&lt;/li&gt;&lt;li&gt;An e2e testing framework that certifies each change&lt;/li&gt;&lt;li&gt;An effective communication framework typically a change ticket process that notifies the relevant enterprise pieces that are potentially impacted by the change&lt;/li&gt;&lt;li&gt;Leadership &amp; support from the development teams on implementing change. &lt;/li&gt;&lt;li&gt;Post-implementation verification of change (ideally monitoring key business KPIs before and after the change). &lt;/li&gt;&lt;/ul&gt;&lt;br /&gt;&lt;br /&gt;&lt;author&gt;Milan Gupta&lt;/author&gt;&lt;br /&gt;&lt;managingEditor&gt;milangupta1@gmail.com&lt;/managingEditor&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-8396204092919474672?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/03/change-management.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>0</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-8951799032602710612</guid><pubDate>Sat, 03 Mar 2007 10:23:00 +0000</pubDate><atom:updated>2008-12-11T16:35:15.124Z</atom:updated><category domain='http://www.blogger.com/atom/ns#'>reactive</category><category domain='http://www.blogger.com/atom/ns#'>organizational behavior</category><category domain='http://www.blogger.com/atom/ns#'>proactive</category><category domain='http://www.blogger.com/atom/ns#'>application support</category><title>proactive vs. reactive application support</title><description>&lt;a href="http://4.bp.blogspot.com/_EoOEH3E1dTA/RelM8Mz0chI/AAAAAAAAAC4/AVuSmdPW9Js/s1600-h/App+Support+Model.gif"&gt;&lt;img id="BLOGGER_PHOTO_ID_5037642255305044498" style="FLOAT: left; MARGIN: 0px 10px 10px 0px; CURSOR: hand" alt="" src="http://4.bp.blogspot.com/_EoOEH3E1dTA/RelM8Mz0chI/AAAAAAAAAC4/AVuSmdPW9Js/s320/App+Support+Model.gif" border="0" /&gt;&lt;/a&gt;&lt;br /&gt;&lt;div&gt;A key aspect of a good application support model that is often missed is the importance of each application support group behaving as a customer of a downstream dependent system.&lt;/div&gt;&lt;br /&gt;&lt;div&gt;A common fallacy is to assume that each application and its support group is an independent unit purely acting on a reactive basis. This puts the onus of taking a business user problem and translating it to a specific application problem, onto some form of a centralized service management wrap. Not the most efficient as most problems are first detected within the application support teams (provided they are awake). It is imperative that they drive the resolution of the problem to their downstream dependent system.&lt;/div&gt;&lt;br /&gt;&lt;div&gt;As an example, consider the picture wherein the application arena is a simple service order processing chain wherein system A is some CRM system, system B is an orchestration / workflow layer, system C is a inventory / assignment system and system D is a service activation system. Typically, there is tight coupling and dependencies between each of these layers - any anomalies impact business KPIs and flow-through. The users of the CRM systems will see these anomalies as orders not being completed on time. The orchestration system will see these as orders stuck at a particular stage. The problem may actually lie within the assign / inventory layer or the service activation layer which also will be noticed by the respective app support teams. &lt;/div&gt;&lt;br /&gt;&lt;div&gt;Behavior within the teams should be as follows :&lt;/div&gt;&lt;div&gt;1&gt; Ideally, the bridge monitoring system should have received alarms and alerted the respective systems .. this would represent IT being pro-active. &lt;/div&gt;&lt;div&gt;2&gt; Failsafe on this would be the app-support team for the CRM system creating an IT fault on the orchestration system who in turn would transfer the fault to the assign / inventory system. Not the most effective, however, necessary as a failsafe and reinforces proper organizational behavior. For complex scenarios, a service management layer may be introduced. I still consider this pro-active. &lt;/div&gt;&lt;div&gt;3&gt; Least ideal is 1 &amp; 2 failing with the users reporting the fault - this is IT being reactive. &lt;/div&gt;&lt;br /&gt;The usual breakdown I observe is in #2 with companies mostly operating in #3. #1 requires a sophesticated business process monitoring infrastructure, something I consider to be still an industry wide problem given state of investment and commitment to such projects within an IT portfolio. Breakdown in #2 is usually an artifact of organizational boundaries and/or poor skillsets &amp;amp; focus. Each team operates in a silo and purely on a reactive basis. A truly dangerous place to be for any CIO.&lt;br /&gt;&lt;br /&gt;&lt;author&gt;Milan Gupta&lt;/author&gt;&lt;br /&gt;&lt;managingEditor&gt;milangupta1@gmail.com&lt;/managingEditor&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-8951799032602710612?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/03/application-support-organizational.html</link><author>noreply@blogger.com (Milan Gupta)</author><media:thumbnail xmlns:media='http://search.yahoo.com/mrss/' url='http://4.bp.blogspot.com/_EoOEH3E1dTA/RelM8Mz0chI/AAAAAAAAAC4/AVuSmdPW9Js/s72-c/App+Support+Model.gif' height='72' width='72'/><thr:total>4</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-485286962871686102</guid><pubDate>Fri, 02 Mar 2007 00:04:00 +0000</pubDate><atom:updated>2007-04-23T16:22:00.463+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>transaction variance</category><category domain='http://www.blogger.com/atom/ns#'>transaction performance</category><category domain='http://www.blogger.com/atom/ns#'>asynchronous</category><category domain='http://www.blogger.com/atom/ns#'>synchronous</category><title>synchronous vs asynchronous transactions</title><description>If you have ever built call center apps .. you will already have learned this lesson. For some reason, we keep repeating these mistakes over and over and over ...&lt;br /&gt;&lt;br /&gt;Remember - synchronous transactions for time-sensitive stuff. For transactions that a call center rep has to wait on (while customer is on the phone) .. use synchronous backplane eg. web-services. For others (non-time sensitive), use asynchronous. Your messaging architecture MUST support both.&lt;br /&gt;&lt;br /&gt;The thing that creates havoc the most in call centers is transaction performance variance. Not always just transaction performance. If something consistently takes 90 seconds, you will find your call center reps work around this poor performance by predicting this period of wait and filling it with other work or small talk with the customer. What makes call center agents mad is transaction variance - sometimes it only takes 4 secs, sometimes 300. That's when the customer on the line gets the embarrassed comments - 'my system is slow .. my system has frozen up ..' etc. etc.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;author&gt;Milan Gupta&lt;/author&gt;&lt;br /&gt;&lt;managingEditor&gt;milangupta1@gmail.com&lt;/managingEditor&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-485286962871686102?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/03/synchronous-vs-asynchronous.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>0</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-3901930081303081215</guid><pubDate>Thu, 01 Mar 2007 23:29:00 +0000</pubDate><atom:updated>2007-04-23T16:21:41.051+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>application support</category><category domain='http://www.blogger.com/atom/ns#'>service  management</category><category domain='http://www.blogger.com/atom/ns#'>systems effectiveness</category><category domain='http://www.blogger.com/atom/ns#'>systems availability</category><title>systems availability vs. systems effectiveness</title><description>First of a series of posts where I will cover the area of application support &amp; service management. This is probably one of the largest problem areas in an IT portfolio and the number one reason that leads to CIO departures.&lt;br /&gt;&lt;br /&gt;Providing excellent day-to-day service ! What is the role of IT in this ? What is the role of a particular application support team ?&lt;br /&gt;&lt;br /&gt;A typical CIO challenge is to take the IT group up the value chain within a company. This applies to all disciplines including providing day-to-day support.&lt;br /&gt;&lt;br /&gt;Support teams and IT value is typically stuck at the systems availability monitoring and reporting level. 99.95% uptime. Famous words. We've all heard this. Somehow that 0.05% seems to hide a massive amount of operational impact. Putting that under the microscope usually leads to startling revelations.&lt;br /&gt;&lt;br /&gt;An alternate strategy is to focus on systems effectiveness - my name for nothing other than business process monitoring, however, this is a little different. Here, you apply the concepts of business process monitoring in a 'systemy' way.&lt;br /&gt;&lt;br /&gt;To clarify, each system typically performs a specific function within a process chain. Systems monitoring at the technical level covers all the engineering aspects of the platform eg.&lt;br /&gt;Database, hardware, CPU, I/O, Filesystem space etc. Usually, this stuff is trapped using tools like HP Openview, BMC etc. and monitored by a 7x24 bridge operation. When alerts are received, automatic callouts are performed with an extra pair of eyes to make sure.&lt;br /&gt;&lt;br /&gt;Better groups take this up one level. Monitoring of log files for errors eg. SQL errors, core dumps, etc. However, this is also usually insufficient. Even better groups start getting sophesticated around application level capacity monitoring - eg. thread utilization, queuing behavior and other subtleties around bad jvm characteristics eg. full GCs.&lt;br /&gt;&lt;br /&gt;However, that also isn't usually sufficient. The trick is to customize a set of measures that are relevant to the business use of the application and monitor for that. Keep your finger on that pulse and magic happens. Your operational partners will no longer care if the system goes up or down .. they are happy for you to measure based on the business performance. An example of this is to measure performance response time and variance for transactions that are time sensitive - eg. those that a call center application calls on the back-office systems. Alternately, in the case of workflow, some measure of cycle time and right first time (on-time being trivial case of RFT).&lt;br /&gt;&lt;br /&gt;Do this and suddenly, you have gone up the value chain and made your life simpler. Your teams grow as they go from being purely reactive to being proactive. Also, more importantly, they learn the operational side of things and recognize exactly the criticality and value of their system in the larger picture.&lt;br /&gt;&lt;br /&gt;This isn't anything fancy. I'm not talking about a full-scale business process monitoring framework here. Full BPM requires a standardization of metrics and process and usually abstracts away from the systems design and implementation. For architectures that are a mix of legacy and new, this is usually never perfect either. I'm talking about a simple application of common sense to what you monitor. They challenge is usually understanding the design of the system and extrapolating the meaningful set of measures that the end-to-end business process depends on. This is usually very specific to the design and implementation of the system as the data must be harvested frequently and usually in real-time.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;author&gt;Milan Gupta&lt;/author&gt;&lt;br /&gt;&lt;managingEditor&gt;milangupta1@gmail.com&lt;/managingEditor&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-3901930081303081215?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/03/systems-availability-vs-systems.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-7777171280122117029</guid><pubDate>Wed, 14 Feb 2007 23:42:00 +0000</pubDate><atom:updated>2007-04-23T16:21:12.549+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>lessons learned</category><category domain='http://www.blogger.com/atom/ns#'>project execution</category><category domain='http://www.blogger.com/atom/ns#'>common IT problems</category><category domain='http://www.blogger.com/atom/ns#'>Software 101</category><category domain='http://www.blogger.com/atom/ns#'>IT 101</category><category domain='http://www.blogger.com/atom/ns#'>IT execution</category><title>Project Execution</title><description>For any significant development project or classical integration programme, there are a number of necessary ingredients, the absence of which usually are a recipe for disaster.&lt;br /&gt;&lt;br /&gt;1&gt; The right leadership.&lt;br /&gt;Any project must have its technical leadership and its business leadership straight. Yes, this boils down to two people who will challenge each other and maintain the necessary checks and balances.&lt;br /&gt;&lt;br /&gt;2&gt; Management &amp; Escalation.&lt;br /&gt;One of the biggest blunders and chaotic environments is where you have non-technical management managing technical work. Recipe for disaster as you will spend you life on escalations that look complex and scary, however, are very simply solved. Also, a lack of understanding of the development cycle usually leads to pre-mature questions from the management which in turn leads to pre-mature decision making, needless work etc. Eg. on one of my projects, being the  architect / technical lead, I was asked (by the VP) for a technical specification of the system within the first month of what was a 2 yr project !! Understand that managers want to know when things will get done even before they allow anything to start. Developers will not reliably tell you when things will get done until they are actually done. Such is life and the variability of agile. You are welcome to use waterfall if you want a 100% schedule predictability, however, understand, that you are basically getting 1 unit of work at a cost of 5 (the addl. 4 are padding to manage the risks/unknowns which are inherent in most projects). On structure, you have basically two philosophies, architect/tech lead report to the manager or manager report to the architech / tech lead. I vote for the latter. As long as the manager / project manager understand their role wrt the tech lead / architect, things typically are fine. Watch for this dynamic very very carefully as this is where bad bad decisions are usually made. You do NOT want a non-technical person making a technical decision. &lt;br /&gt;&lt;br /&gt;3&gt; Top talent recruiting - the best attract the best. No one likes carrying dead weight. Once you seed the team correctly, this will be self-correcting. I have and never will believe in the 200+ project team size. I have done amazing things with a 40 person development team. Remember, the software design and tools you choose itself brings limitations on how many developers can work concurrently and productively.&lt;br /&gt;&lt;br /&gt;4&gt; Pay attention to the learning curve. Things will not progress at the pace you would expect until you have a seed development team that has matured sufficiently around their understanding of the business problem. These will become your technical leads as your project grows. It is wise to invest this learning in the best technical developers from the start as they are the ones who are going to produce the software.&lt;br /&gt;&lt;br /&gt;5&gt; Match your technology choices to your developer team skills. If you want your project to be the guinea pig for the 'next cool new tool / technology' .. OK .. but understand your risks. You need the time to get your developers up to speed on this.&lt;br /&gt;&lt;br /&gt;6&gt; Establish the right roles within the team from the start.&lt;br /&gt;Architect/Designer, Developer/Tech Lead, Business SME/Tester, Project Manager, Test/Development Environment Manager, Application support lead, Deployment Lead, Integration Lead (Designer), Business Implementation Lead (Training/Comms/Metrics)&lt;br /&gt;&lt;br /&gt;7&gt; Get and stay close to the end-user/customer.&lt;br /&gt;The shorter the communication chain between an end user and a developer, the greater the chance of success.&lt;br /&gt;&lt;br /&gt;8&gt; Test from the start - your user stories are really test cases in disguise. Pay attention to test data. &lt;a href="http://www.mercury.com/us/products/quality-center/testdirector/"&gt;Test Director &lt;/a&gt;is a decent tool to document your tests and track your coverage.&lt;br /&gt;&lt;br /&gt;9&gt; Solve the hard problems first. Focus on the unknowns as early as possible. PANIC EARLY !!&lt;br /&gt;Its only great teams that have a 40 hr work week in their final week before deployment. No magic here .. it comes from spending the weekends before that so that you are coasting in style when you near the finish line.&lt;br /&gt;&lt;br /&gt;10&gt; Develop/Test with real data as early as possible.&lt;br /&gt;At the early phases of a project, the developers must have flexibility over the testers. This is the best-effort co-operative testing phase. It is extremely frustrating for the testers as the productivity is low. If you are using end-users, you must have alignment, else, you will be fire-drilling all the time trying to manage perceptions of problems from above. This phase of testing is key as your end goal is to get as much early feedback to the developers. During the last phase of the project, the testers must be the enemy of the developers as they move to the 'antagonistic' testing and the user acceptance testing phase. Here, the testers must be the focus with full support from the developers and the test environment leads. Another best practice is to have a repeatable set of test cases rather than a set of testers. This provides a very easy way to manage stakeholders as anybody who wants a say, can review and add to the test cases. The better they are, the better your chances for a quality delivery.&lt;br /&gt;&lt;br /&gt;11&gt; Co-locate as much as possible.&lt;br /&gt;NB&gt; Do not assume co-location means same building or floor. Even team members strewn across the floor randomly will not have the same effectiveness as an integration pod or 6 adjascent cubicles housing a sub-team working on a common area. There is truly an amazing effect on productivity. Make the hard call and force this if you are getting into the red zone. I understand the day and age of offshoring, however, in crunch mode, you cannot replace good old co-location with anything. Remember, communication/organizational barriers is the most common problem to integration problems. The main problems will be at the boundaries.&lt;br /&gt;&lt;br /&gt;12&gt; Basic software engineering disciplines - makefiles, daily/continuous builds, regression test automation, code reviews, use of software quality and analysis tools (purify, jprobe, ..).&lt;br /&gt;&lt;br /&gt;13&gt; If you are using 3rd party tools, understand your risks. There will be issues and it is up to you to design around them. Remember, you will have limited flexibility to fix/modify the 3rd party tool. A third party tool does not relieve you from the need to understand the details.&lt;br /&gt;&lt;br /&gt;14&gt; Certain roles go hand in hand with accountabilities and later roles in the project lifecycle eg. it is ideal to have the people who specified the user requirements also be the testers; the solution designers/architects be also intrinsic in the integration / testing / defect resolution of the project.&lt;br /&gt;&lt;br /&gt;15&gt; Plan for production - clean up the logfiles - meaningful and concise. Write the required business process monitoring reports that allow you to ensure the platform's effectiveness post production. Do this early as this will allow you to identify gaps in the design / functionality that can make your life extremely difficult post production. A easy example is for a workflow based system, have the ability to take a snapshot of the in-flight jobs and where they are. Have a clear model of expected execution profile so you can catch exceptions, performance issues, bottlenecks, etc.&lt;br /&gt;&lt;br /&gt;16&gt; Measure before you implement, measure after you implement .. you are not done until you restabilize the business KPIs (and this will take you a month). Your end-users may not notice things as they are new to the system too .. so, don't expect to get the usual level of guidance from operation on 'problem areas / defects'.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;author&gt;Milan Gupta&lt;/author&gt;&lt;br /&gt;&lt;managingEditor&gt;milangupta1@gmail.com&lt;/managingEditor&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-7777171280122117029?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/02/project-execution.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>1</thr:total></item><item><guid isPermaLink='false'>tag:blogger.com,1999:blog-3109386887529685808.post-8546970342212095612</guid><pubDate>Sun, 11 Feb 2007 14:57:00 +0000</pubDate><atom:updated>2007-04-23T16:20:59.249+01:00</atom:updated><category domain='http://www.blogger.com/atom/ns#'>IT people</category><category domain='http://www.blogger.com/atom/ns#'>IT top talent</category><category domain='http://www.blogger.com/atom/ns#'>IT job specialization</category><title>People</title><description>What's more important for a sucessful project - is it people ? Or is it process / technology (in that with a certain set of technologies and processes, things become repeatable / predictable that the people do not matter anymore) ? I know, I know, its all three factors. However, I find over and over again, managers not paying attention to the people aspect of the equation.&lt;br /&gt;&lt;br /&gt;We have all gone through the IT top talent recruiting paradigm. There is however, another angle to the people aspect. What makes better people ?&lt;br /&gt;&lt;br /&gt;I have seen organizations that are so highly structured and specilialized in their jobs that they start showing two evils : 1&gt; they no longer are downward scaleable 2&gt; they lose the ability to solve problems efficiently (this shows up of course in my job area).&lt;br /&gt;&lt;br /&gt;Here is why.&lt;br /&gt;&lt;br /&gt;Imagine the role of a requirements analyst, architect, solution designer, component designer, developer, tester, configuration manager, application support, deployment manager ... the list goes on. Now overlay the technical development aspect with people who are specialized dbas, network designers, hardware / infrastructure designers, bea specialists, mq specialists, iis server/windows/asp specialists, c/c++/UNIX specialists, java/jvm specialists etc. You can start seeing the problem.&lt;br /&gt;&lt;br /&gt;Problems usually go through a period of analysis (or finger pointing). This is where having skill sets that span the technology spectrum is important. The difference is night and day between the response time of resolution when you have a single person who knows BEA / Oracle / UNIX / Networking concepts vs. someone who only is a trained BEA person without a thorough knowledge of UNIX kernal parameters or networking concepts. Typically for any large IT organization, this will typically be a 4 or 5 person team.&lt;br /&gt;&lt;br /&gt;I grew up in an environment where we executed projects e2e. We conceptualized, we presented, we sold, we interviewed, we architected, we designed, we developed, we tested, we deployed, we installed servers, we supported, we wore the pagers. On the technology side, we made the choices and had to live with them - no excuses. This gave us a very unique perspective.&lt;br /&gt;&lt;br /&gt;There don't appear to be many people like me. The newer technologies are allowing people a level of abstraction that is a death sentence to any development that isn't absolutely no-brainer. I see this in the resume stream for even my top talent industry search.&lt;br /&gt;&lt;br /&gt;So, is this what companies are breeding ? I don't see the flexibilities to grow across dimensions anymore .. where else are the kids going to get their experience from ?&lt;br /&gt;&lt;br /&gt;This is one that does have a fix.&lt;br /&gt;&lt;br /&gt;&lt;br /&gt;&lt;author&gt;Milan Gupta&lt;/author&gt;&lt;br /&gt;&lt;managingEditor&gt;milangupta1@gmail.com&lt;/managingEditor&gt;&lt;div class="blogger-post-footer"&gt;&lt;img width='1' height='1' src='https://blogger.googleusercontent.com/tracker/3109386887529685808-8546970342212095612?l=www.knownbugs.org' alt='' /&gt;&lt;/div&gt;</description><link>http://www.knownbugs.org/2007/02/people.html</link><author>noreply@blogger.com (Milan Gupta)</author><thr:total>2</thr:total></item></channel></rss>
