[
Date Prev][
Date Next][
Thread Prev][
Thread Next][
Date Index][
Thread Index]
[
List Home]
| Re: [higgins-dev] Performance Instrumentation of IdAS source | 
  
  
    
      if there's a tool available that will do what we need without us having to instrument our code, I'm in favor of that.  Can we use the TPTP project?  It looks like it can do what we want and more without us having to hand-instrument code.  I could be wrong.
>>> Prakash C Mallick <prakash.mallick@xxxxxxxxxx> 09/11/08 2:04 PM >>>
Hi Jim,
          Thanx for your quick response. Please see the code snippet below where I have instrumented the JNDIContext::_emitXDASRecord method. I will respond to your other queries soon.
private void _emitXDASRecord(
                int iEventNumber,
                int iOutcome,
                String sInitiatorInfo,
                String sTargetInfo,
                String sEventInfo) throws IdASException
        {
                StopWatch sw = null;
                final String METHODNAME = " _emitXDASRecord ";
                if( _log.isTraceEnabled( ) ){
                        _log.trace(ENTRY);
                        sw = new StopWatch();
                        sw.start();
                }
                if (_xdasSession != null)
                {
                        if (sTargetInfo == null)
                                sTargetInfo = "";
                        if (sEventInfo == null)
                                sEventInfo = "";
                        try
                        {
                                XDasRecord xdasRecord = _xdasSession.XDasStartRecord(iEventNumber, iOutcome,
                                        null, null, sEventInfo);
                                xdasRecord.setInitiatorInfo(null, null, sInitiatorInfo);
                                xdasRecord.setTargetInfo(null, _contextURIs, _contextTypes, null, null, sTargetInfo);
                                xdasRecord.commit();
                                if( _log.isTraceEnabled( ) ){
                                        sw.split();
                                        _log.trace(TIMESPENTIN+" openxdas.XDasRecord.commit() "+" [ " + sw + " ] ");
                                        sw.unsplit();
                                }
                                
                        }
                        catch (XDasException e)
                        {
                                throw new IdASException(e);
                        }
                        catch (IOException e)
                        {
                                throw new IdASException(e);
                        }
                }
                if( _log.isTraceEnabled( ) ){
                        sw.stop();
                        _log.trace(EXIT+MSGSEP+TIMESPENTIN+METHODNAME+" [ " + sw + " ] ");
                }
        }
If you want to know the behaviour of the above code marked blue please refer apache StopWatch class part of org.eclipse.higgins.dependencies.redistributable\commons-lang-2.1\commons-lang-2.1.jar. Please let me know if you need more clarification on this.
Thanks and Regards,
Prakash
---------------------------------------------------------------------------------------------------
Advisory Software Engineer,
Tivoli Security Products
ETZ, Plot No. 3 , Rajiv Gandhi Infotech Park
Phase II, Hinjewadi, Pune - 411057
Ph: +91-20-42025544
e-mail: prakash.mallick@xxxxxxxxxx
---------------------------------------------------------------------------------------------------
    
    
      
        | 
            "Jim Sermersheim" <jimse@xxxxxxxxxx> Sent by: higgins-dev-bounces@xxxxxxxxxxx
 
            09/11/2008 10:49 PM           
            
              | 
                  
                    Please respond to"Higgins \(Trust Framework\) Project developer discussions"        <higgins-dev@xxxxxxxxxxx>
 |  
            
 | 
            
              |  | 
                  <higgins-dev@xxxxxxxxxxx>                 |  
              |  | 
 |  
              |  | 
                  Re: [higgins-dev] Performance Instrumentation of IdAS source                 |  
            
 
            
 | 
    
    
      
      
      
      This is exciting.  Can u send a code snippet of how you do this?  Also, is there an accompanying parser which can graph the results?  If not, no biggie, this is better than nothing.
Do you think we should investigate using TPTP for doing this?  Here's a link http://www.eclipse.org/tptp/.I assume it does it without requiring one to hand-tool their code.
Jim 
>>> Prakash C Mallick <prakash.mallick@xxxxxxxxxx> 09/11/08 8:03 AM >>>
Hi Jim and All,
         If this is fine with all of you I would be fine to contribute to performance instrumentation implementation without affecting the production cycle. In fact I have already instrumented JNDI-CP using StopWatch classes for my prototype  implementation which shows the following output when perfermance instrumentation is enabled in Trace mode.
Aug 29, 2008 6:07:22 PM org.eclipse.higgins.idas.cp.jndi.JNDIContext _setupContext
FINEST: -->> ENTERING
Aug 29, 2008 6:07:22 PM org.eclipse.higgins.idas.cp.jndi.JNDIContext _setupContext
FINE: Attempting to create initial context: ldap://ltoyota.in.ibm.com:3389
Aug 29, 2008 6:07:22 PM org.eclipse.higgins.idas.cp.jndi.JNDIContext _setupContext
FINEST: <<-- EXITING ---- time spent in  _setupContext()  [ 0:00:00.015 ] 
Aug 29, 2008 6:07:22 PM org.eclipse.higgins.idas.cp.jndi.JNDIContext _emitXDASRecord
FINEST: -->> ENTERING
Aug 29, 2008 6:07:22 PM org.eclipse.higgins.idas.cp.jndi.JNDIContext _emitXDASRecord
FINEST: <<-- EXITING ---- time spent in  _emitXDASRecord  [ 0:00:00.000 ] 
Aug 29, 2008 6:07:22 PM org.eclipse.higgins.idas.cp.jndi.JNDIContext open
FINE: Context opened:  as: cn=root
Aug 29, 2008 6:07:22 PM org.eclipse.higgins.idas.cp.jndi.JNDIContext open
FINEST: <<-- EXITING ---- time spent in  open(Object )  [ 0:00:00.015 ] 
We are yet to finalize the format of of permance data marked red.
Please let me know if above implementation looks ok, so that I can apply the same implementation in other IdAS packages.
Thanks and Regards,
Prakash
---------------------------------------------------------------------------------------------------
Advisory Software Engineer,
Tivoli Security Products
ETZ, Plot No. 3 , Rajiv Gandhi Infotech Park
Phase II, Hinjewadi, Pune - 411057
Ph: +91-20-42025544
e-mail: prakash.mallick@xxxxxxxxxx
---------------------------------------------------------------------------------------------------
    
    
      
        | 
            "Jim Sermersheim" <jimse@xxxxxxxxxx>Sent by: higgins-dev-bounces@xxxxxxxxxxx
 08/19/2008 10:12 PM
 
 
 
            
              | 
                  
                    Please respond to"Higgins \(Trust Framework\) Project developer discussions"        <higgins-dev@xxxxxxxxxxx>
 |  
            
 | 
            
 
            
              |  | 
                  <higgins-dev@xxxxxxxxxxx>                 |  
              |  | 
 |  
              |  | 
                  Re: [higgins-dev] Performance Instrumentation of IdAS source                  |  
            
 
 
 
            
 | 
    
    
      
      
      
      
      We can either instrument, or we can use the inmem CP.  In fact, I've been trying to migrate the SPI code to a point where the inmem cp is pretty much obsolete.  Still, I'm not at all opposed to instrumenting idas.cp.spi and idas.common as long as the instrumentation doesn't eat cycles in production environments.
Getting some baseline performance tests sounds great to me -- also it would be nice if someone could do some scalability testing.  There are places in the spi that we're certain have scalability problems.
Jim
>>> Prakash C Mallick <prakash.mallick@xxxxxxxxxx> 08/19/08 8:00 AM >>>
Hi All,
         We are not very sure if there is any plan or any mechanim already used to measure the performance of IdAS components. As in almost all usage performance is the mandatory non-feature requiement that  is supported by all products, we need to provide a mechanism to  mesure the performance of IdAS components(APIs) and also if possible we can provide performance bench mark for the same.
Requirement (To measure the performance of IdAS APIs)
-------------------------------------------------------------------------------------
Since  IdAS components are inteded to be used along with consumer code and as well as with service provider codes, its always a good idea to isolate the time consumed by IdAS APIs only when used along with these codes and let the consumer and service provider decide the performance impact of the code owned by them.
At present its not possible to identify performance issues that occurs becuase of the following reasons as we have seen so far  through debugging,
      1. Slow response in accessing  remote resources such as context dbs,remote objects ,operating on remote APIs and so on becuase bandwidth or any other infrastructure problem.
       2. Performance issue becuase of error prone or poorly written SPI code or consumer code.
Proposal to measure performance of IdAS code
-----------------------------------------------------------------------
We can use one of the following options to measure the performance
1.  Measuirng performanceof IdAS APIs  by using dynamic instrumentation(using various JVM profiling options during run time) .
2. Implementing static instrumentation(by adding  least CPU bound time based APIs such as start,stop as used in StopWatch kind of implementation to calculate the time spent by various APIs).
3. Possibly by building/executing IdAS based application in some platform provided by performance measuring tools .
But as mentioned above IdAS components are not used in isolation like other stand-alone application, so its not possible to get more accurate or realistic time data as consumed by these APIs to perform a task in a production environment  by using either dynamic instrumentation mechanism or any performance tools.
So using static instrumentation we will have more control to extract the  time consumed by IdAS APIs from external codes such as consumer code and service provider code. Once the time consumed data is obtained through instumentation , the same can be logged (using trace/debug log level) to a log file.This mechanism will also add entry and exit time into a method which is or can be added by apache common log calls already used in IdAS source codes. This  instrumentation can be protected through IsDebuggable/IsLoggable calls so that we will enable it at a particular log level such as TRACE/DEBUG .
Overally this feature will help the cosumer or service provider stakeholders to know the performance of IdAS code in their environment. In addition to that we can create a common package such as org.eclipse.higgins.util.performance to provide utility  methods for static instrumentation which can be used by IdAS developer,consumers and Service Providers.
We have a mechanism as suggested by David and TIM Hahn to implment the same using Stopwatch similar to the one provided by apache ..Please refer the link  http://commons.apache.org/lang/api/org/apache/commons/lang/time/StopWatch.html for more information.
If all of you think we need  this support , please let me know. Please provide your inputs on this. I am planning to have a prototype for this once I get some feed backs from all of you.
Thanks and Regards,
Prakash
---------------------------------------------------------------------------------------------------
Advisory Software Engineer,
Tivoli Security Products
ETZ, Plot No. 3 , Rajiv Gandhi Infotech Park
Phase II, Hinjewadi, Pune - 411057
Ph: +91-20-42025544
e-mail: prakash.mallick@xxxxxxxxxx
---------------------------------------------------------------------------------------------------_______________________________________________
higgins-dev mailing list
higgins-dev@xxxxxxxxxxx
https://dev.eclipse.org/mailman/listinfo/higgins-dev
_______________________________________________
higgins-dev mailing list
higgins-dev@xxxxxxxxxxx
https://dev.eclipse.org/mailman/listinfo/higgins-dev