Friday, December 28, 2007
Python - log viewer
Python is also object oriented, which means you can scale to current day requirements and also scale up very easily in future.
It has rich collection of modules, which makes most of your development fairly easy.
I did a bit of research before I arrived into Python. My background has been implementation/ consultancy in Banking and my experience has been or rather my bread has been universe initially and then jbase because the product I was working with adapted to jbase. Programming is called infobasic or jbc. It is quite a self-sufficient language for any activities. I think only thing missing in that is the object orientation other than that we can do most of the stuff there. Ofcourse they miss modules for networking (other things) and are quite slow for large amount of data. jbase/jbc is quite extend able in its own sense, because you can call 'c' function quite easily from jbase or viceversa.
Ok Back to how I arrived at Python. I was looking for new languages (rather more powerful and faster) to equip myself and my team and I evaluated few,
1. c++ - too complicated for me
2. perl - i didnt like it.
3. c - no object orientation
then i was left with java and python. Java is quite power full and eventually I think every programmer has to arrive at java. But writing a small programs or quick utility is bleady time consuming (probably not for those java geeks!!). I felt next natural progression from jbc/info basic should be to Python. I have been dealing with lots of T24 consultants, they are so comfortable with jbc that they choke when it comes to latest languages like java or c++ or c#. These consultants are high in demand and low in technical knowledge in true market sense (ofcourse, other than product (read as t24) and jbc).
I observe that when ever I wanted to do new products with new technology(with my team of t24 consultants - i had eventually recruit new people) there was so much resistance (from the so called technical architects/ experts{of t24}) that either people quit my team or my company. They are so comfortably placed with the current demand in their knowledge that they are not willing to spend time to learn new technologies and if u ask them to look into java or c++ or any thing else then my utilisation of these people becomes really low(as time required to be expert in these languages are quite high). So I strongly feel answer to all this and taking a route of natural progression, obvious next step for info basic programmers(rather t24 consultants) should be to python and then eventually they could arrive at Java or which ever(not a very big fan for windows languages-except c# {looks interesting}).
I have started using python for writing small utilities for my day to day activities. During my recent visit to one of the t24 sites, the client wanted(rather I wanted) a utility to view the como created by the t24 cob process in a single window. t24 allows cob to be run in multiple threads and the logging (or COMO) is stored AS 'n' number of files(Where 'n' is number of threads).
So I did the following program to view the same. The lazy that I am, I did the first search for available program with Google God!!. I eventually found what I was looking for at
http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/414771
I modified that to my requirements. The code is at following location as text file to maintain the indentation(yeah sometimes it is irritating),
comoviewer source
The code does the following,
1. takes directory to be monitored for log files
2. scan through all the files in the directory with the name starting with tSA
3. get the number of lines and stores them in a dictionary
4. scans the next time and checks whether the previous lines is less then the current number of lines in the file, if so then display them.
example of usage
python comoviewer.py /hds2/temp/bnk/bnk.run/'&COMO&'
Ofcourse if you want to use this you need to install python first.
Saturday, December 1, 2007
Performance Test
The performance testing is a measure of the performance characteristics of an application.
The main objective of a performance testing is to demonstrate that the system functions to Specification with acceptable response times while processing the required transaction volumes in real-time production database.
The performance of a computer system is based on human expectations and the ability of the computer system to fulfill these expectations. The objective for performance tuning is to match expectations and fulfillment. The path to achieving this objective is a balance between appropriate expectations and optimizing the available system resources.
Performance analyses are carried for various purposes such as:
- During a design or redesign of a module or a part of the system, more than one alternative presents itself. In such cases, the evaluation of a design alternative is the prime mover for an analysis.
- Modern applications are not entirely designed from the ground up. Use of third-party tools and components is almost a given. In such scenarios, the comparison of two or more systems must be undertaken.
- Post-deployment realities create a need for the tuning the existing system. A systematic approach like performance analysis is essential to extract maximum benefit from an existing system.
- Identification of bottlenecks in a system is more of an effort at troubleshooting. This helps to replace and focus efforts at improving overall system response.
- Capacity planning is usually done with a view to the future. The results are used as ipso facto for decisions regarding the purchase of additional hardware resources, software tools, etc.
- As the user base grows, the cost of failure becomes increasingly unbearable. To increase confidence and to provide an advance warning of potential problems in case of load conditions, analysis must be done to forecast performance under load.
Typically to debug applications, developers would execute their applications using different execution streams (i.e., completely exercise the application) in an attempt to find errors. When looking for errors in the application, performance is a secondary issue to features; however, it is still an issue.
In summary main objectives of performance tests are,
- Whether the system is able to handle the number of users
- Whether the system is able to give good response time and throughput
- Whether the systems BATCH process (all those flat files, incoming files/outgoing files or daily process/monthly processes. etc.) is with in a targeted time frame window.
The performance tests should include,
Type | Description |
Load testing | How many users can the application support? What actual response times will users experience |
Scalability Testing | How reliable is the system beyond normal usage point. , Stress testing - what are the application limitations and failure behavior |
Infrastructure Configuration testing | Encompasses setting up and testing various system configuration to asses requirement and investment needs |
Smoke Testing | To check how system behaves when there is sudden surge in the transaction as a particular time during the day. |
Endurance testing | Long duration load or stress test. Instead of test execution period lasting tens of minutes, tests are executed for hours or even days. This mainly to asses the slow memory leaks, accrual of uncommitted transactions in a rollback buffer, queuing of downstream systems or gradual impact upon system resources. |
What is required for performance tests?
Before going into actually doing the performance tests, you need to invest in getting the tools required for doing the performance tests. There are tools in the market, but be very sure that none of them will fit exactly that is required by you. Hence you need to spend time to fine tune the tools available in the open market to do your tests. Typically these tools should do the following,
- Simulate online users
- Simulate the interfaces
- Simulate the batch process.
These simulations should at the end of the tests be capable of giving the following,
- Throughput.
- Response Time.
Where,
Throughput is a measure of the amount of work performed over a period of time.
Response time is the time elapsed between when a request is submitted and when the response from that request is returned?
Now let’s move into a one typical situation in the real life. Lets take t24/Globus clients as example. T24 is used by at least 500 banks around the world. There are at least 10 new banks implementing the system at any time. There are at least 30% of the current client base, who are upgrading the system and their main concern is the performance. The performance tests are required in the following situations,
- Upgrade of t24/Globus (Service pack upgrade or Release Upgrade)
- Upgrade of database(jbase)
- Change of database(Universe – jbase)
- Hardware change/Upgrade.
- Addition of products/more business to the system
These concerns can be addressed and banks can have peaceful upgrade/implementation/support by performing the performance tests in advance and addressing the issues that rose in these tests.
In the performance tests, you need to,
- Identify performance bottlenecks as in at t24/Globus core or at t24/Globus Local (developments). (Application level)
- Identify performance bottlenecks as jBase or t24/Globus (Database level)
- Identify performance bottlenecks as Server or jbase (Server Level)
To resolve performance problems, you need to,
- Identify the party responsible for the changes(Bank or Vendor)
- Plan for implementing these changes.
If the issues are due to local developments, then the changes to the local developments is to be done and performance tests repeated until all the local developments issues are solved. (Generally fixing up Local development issues solves the core performance issues).
Every tests should give a summary of the test results and the documentation should cover the following.,
Example of resulting summary document –
The following are the results of the PERFORMANCE CYCLE NN test. (Where NN is the reference number)
Assessment of existing SW/HW adequacy
1. In current hardware and software configuration t24/Globus system is capable of processing about XX% of required volume of transactions in peak half hour period.
2. Performance of hard disks doesn't impact online processing of users and interfaces.
3. Local developments optimization speeds up processing of transactions received from interfaces. It enables parallelization of processing and because of that linear increase of performance with additional CPUs is possible. Parallelization happens only if input data is properly randomized.
4. COB batch was successful on ~XX% of daily volume of transactions. It took 30 minutes, with pre and post backups 25 minutes each. It still needs to be tested with full daily volume of transactions.
5. All of the bottlenecks identified in must be solved in order to make t24/Globus system capable of processing 100% of required volume of transactions.
Identified Issues | Description | Owner |
Main reasons (bottlenecks) for this situation | 1. Large Customers Processing rate for single Customer (hitting single account) is too low Current rate of processing for is 1 transaction per second. Additional CPUs wouldn't help in this case. | |
Area Not tested | Reason | Comments |
Large Customers in general | Issues with processing rate of transactions hitting the same account are expected. Large record size can be a problem. | |
Full number of Customers | Tests were performed on limited number of Customers (14.000). ~50.000 is needed. | |
Scalability with additional CPUs | Tests were performed on 4 CPUs. Test with additional CPUs should prove that performance would indeed increase linearly with more CPUs. | |
Scalability with additional memory (RAM) | Tests were performed on ‘n ‘GB of RAM. Test with additional RAM is needed (‘nn’ GB). | |
For maintaining the performance at optimal level, following activities and monitoring has to be done.
- Monitor the throughput and response time everyday.
- Monitor at least top 10 most time consuming jobs in the COB/EOD and address them.
- Check the file size of all the files every week. You can have a script checking the file size every Thursday and resizing the files every Friday. (Frequency of this depends on the database growth – so decide for yourself which is the best frequency for you).
- Archive the files regularly (again frequency is to be decided by you).
Gp.
Sunday, November 18, 2007
FlexCube or T24?
These consultants were t24 specialists and wanted a change in their profile, wanted to add another software experience and opted for Flexcube implementation.
These consultants were in Flexcube implementation for 2 years and they came running back to t24. t24 is a strange product people run away from it and they end up implementing it exactly 2 years later. t24 has all the nice features, flexibility and surprises for any body who work on it.
Ok, back to the subject usual question posted to me from my clients in the process of selection or by the companies trying partner with Iflex/t24 is, which is better product?.
It is difficult to decide or tell which is the best product unless you go through with your RFP. Both have their advantages and disadvantages. Both companies work differently. My advice also varies on the company/bank which is asking. In general I will summarise my differences as below,
As a Product....
1. Both are functionally rich
2. Iflex has ability to define accounting events. t24 rather rigid in that.
3. t24 has ability to add local developments/ products without any dependency on the vendor, which is very HUGE advantage in the ever changing requirement. Iflex is rather rigid and you are at Iflex door step for every enhancement. (if you are a company and looking at services and implementation independent of the vendor then t24 is the way you need to go!!).
4. Iflex is on oracle. earlier to t24 (known as Globus), the database was jbase/universe. Currently there are oracle and db2 version. t24 is database independent. (Please note that t24 is yet to prove in Oracle and db2, with their latest release-{read as R7}, but Temenos has more experience with Oracle )
As a company,
1. From the consultants experience - Temenos seems to be more structured then iflex. Product release are more controlled and scheduled with temenos. One functionality done for a bank is defiantly available for other clients. Iflex seem to have client specific versions.
2. Implementation from iflex seem to finish around an year, temenos manages to finish around 2years for a mid size bank (Temenos do have implementations which completed in 6 months). Temenos are trying to finish their implementation with in reasonable time with the help of the Model bank (this from my general experience and please come and challenge me !!).
3. for consultants - Working in iflex projects are very taxing and badly planned(they always plan 3 people work with one consultant), but they finish because of the sacrifices of the consultants. Temenos projects are generally well planned but get's generally delayed because of having a bunch of wrong consultants. t24 product can be implemented in 'n' number of ways and its success depends on having the right knowledgeable consultants.
In summary both products are good. Both have their own can of worms. From IT and functinal perspective t24 can scale up to the business requirements fast, but t24 is yet to prove with their latest offering from the technology front and performance front.
Gp.
P.S. Flexcube is trademark of Ifex solutions and t24/Globus is the trademark of Temenos Holdings. The comments/views are my own and does not represent any company/client I work for.
Sunday, November 11, 2007
Welcome
I am looking at presenting, exchanging ideas on Consulting. As Name suggests, this blog is to see 360degree view on any topics. I will be writing about my experiences and advices on consulting/Entrepreneurship.
My initial articles would be aimed at people working in the Banking Software and services. For consultants working on client sites implementing systems or designing and developing systems for software vendors. I would also be writing about different countries I have visited/visting during my consulting, along with few information on visa processing etc (which might be useful for Indian consultants)
You are all welcome to post relevent articles and bits of news that may be of interest. I would also like to hear your stories and feel free to write here.
I Hope, it is useful to you.
Welcome once again and enjoy reading it!!
GP