#include <Transport_Cache_Manager.h>
Collaboration diagram for TAO_Transport_Cache_Manager:
Public Types | |
typedef ACE_Hash_Map_Manager_Ex< TAO_Cache_ExtId, TAO_Cache_IntId, ACE_Hash< TAO_Cache_ExtId >, ACE_Equal_To< TAO_Cache_ExtId >, ACE_Null_Mutex > | HASH_MAP |
typedef HASH_MAP::iterator | HASH_MAP_ITER |
typedef ACE_Hash_Map_Entry< TAO_Cache_ExtId, TAO_Cache_IntId > | HASH_MAP_ENTRY |
typedef TAO_Condition< TAO_SYNCH_MUTEX > | CONDITION |
Public Methods | |
TAO_Transport_Cache_Manager (TAO_ORB_Core &orb_core) | |
Constructor. More... | |
virtual | ~TAO_Transport_Cache_Manager (void) |
Destructor. More... | |
int | cache_transport (TAO_Transport_Descriptor_Interface *prop, TAO_Transport *transport) |
Add the transport to the cache. The transport has the property definition based on which caching can be done. More... | |
int | find_transport (TAO_Transport_Descriptor_Interface *prop, TAO_Transport *&transport) |
Check the Transport Cache to check whether the connection exists in the Cache and return the connection. More... | |
int | purge (void) |
Remove entries from the cache depending upon the strategy. More... | |
int | purge_entry (HASH_MAP_ENTRY *&) |
Purge the entry from the Cache Map. More... | |
void | mark_invalid (HASH_MAP_ENTRY *&) |
Mark the entry as invalid for use but keep it in cache. More... | |
int | make_idle (HASH_MAP_ENTRY *&entry) |
Make the entry idle and ready for use. More... | |
int | close (ACE_Handle_Set &reactor_registered, TAO_EventHandlerSet &unregistered) |
Close the underlying hash map manager and return the handle set that have been registered with the reactor. More... | |
size_t | current_size (void) const |
Return the current size of the cache. More... | |
size_t | total_size (void) const |
Return the total size of the cache. More... | |
Private Types | |
typedef HASH_MAP_ENTRY ** | DESCRIPTOR_SET |
Private Methods | |
int | bind (TAO_Cache_ExtId &ext_id, TAO_Cache_IntId &int_id) |
Associate <ext_id> with <int_id>. Grabs the lock and calls the implementation function bind_i. More... | |
int | find (const TAO_Cache_ExtId &key, TAO_Cache_IntId &value) |
Lookup entry<key,value> in the cache. Grabs the lock and calls the implementation function find_i. More... | |
int | bind_i (TAO_Cache_ExtId &ext_id, TAO_Cache_IntId &int_id) |
Non-Locking version and actual implementation of bind () call. More... | |
int | find_i (const TAO_Cache_ExtId &key, TAO_Cache_IntId &value) |
Non-locking version and actual implementation of find () call. More... | |
int | make_idle_i (HASH_MAP_ENTRY *&entry) |
Non-locking version and actual implementation of make_idle (). More... | |
int | close_i (ACE_Handle_Set &reactor_registered, TAO_EventHandlerSet &unregistered) |
Non-locking version and actual implementation of close (). More... | |
int | purge_entry_i (HASH_MAP_ENTRY *&entry) |
Purge the entry from the Cache Map. More... | |
void | mark_invalid_i (HASH_MAP_ENTRY *&) |
Mark the entry as invalid for use but keep it in cache. More... | |
int | get_last_index_bind (TAO_Cache_ExtId &key, TAO_Cache_IntId &val, HASH_MAP_ENTRY *&entry) |
This is called by the bind () call when a bind fails with a available entry. More... | |
int | is_entry_idle (HASH_MAP_ENTRY *&entry) |
Tries to find if the <int_id_> in entry is idle for use. More... | |
void | sort_set (DESCRIPTOR_SET &entries, int size) |
Sort the list of entries. More... | |
int | fill_set_i (DESCRIPTOR_SET &sorted_set) |
Fill sorted_set in with the TAO_Transport_Descriptor_Interface's in a sorted order. More... | |
void | close_entries (DESCRIPTOR_SET &sorted_set, int size) |
Look through the sorted set and close the connection on the required number of items in the set. More... | |
int | wait_for_connection (TAO_Cache_ExtId &extid) |
Wait for connections if we have reached the limit on the number of muxed connections. If not (ie. if we dont use a muxed connection or if we have not reached the limit) this just behaves as a no-op. <extid> has all the information about the connection that is being searched. More... | |
int | is_wakeup_useful (TAO_Cache_ExtId &extid) |
Is the wakeup useful todo some work? More... | |
Static Private Methods | |
int | cpscmp (const void *a, const void *b) |
Used by qsort. More... | |
Private Attributes | |
int | percent_ |
The percentage of the cache to purge at one time. More... | |
TAO_Connection_Purging_Strategy * | purging_strategy_ |
The underlying connection purging strategy. More... | |
HASH_MAP | cache_map_ |
The hash map that has the connections. More... | |
CONDITION * | condition_ |
The condition variable. More... | |
ACE_Lock * | cache_lock_ |
The lock that is used by the cache map. More... | |
CORBA::ULong | muxed_number_ |
Number of allowed muxed connections. More... | |
int | no_waiting_threads_ |
Number of threads waiting for connections. More... | |
TAO_Cache_ExtId * | last_entry_returned_ |
This is for optimization purposes. In a situation where number of threads are waiting for connections, the last connection that is put back is cached here. This should prevent all th threads trying to search for their required entry. More... |
This class provides interfaces associating a TAO_Cache_ExtId & TAO_Cache_IntId. This class is wrapper around the ACE_Hash_Map_Manager class which is used as a container to Cache the connections. This class protects the entries with a lock. The map is updated only by holding the lock. The more compelling reason to have the lock in this class and not in the Hash_Map is that, we do quite a bit of work in this class for which we need a lock.
|
|
|
|
|
|
|
|
|
|
|
Constructor.
|
|
Destructor.
|
|
Associate <ext_id> with <int_id>. Grabs the lock and calls the implementation function bind_i.
|
|
Non-Locking version and actual implementation of bind () call. Calls bind on the Hash_Map_Manager that it holds. If the bind succeeds, it adds the Hash_Map_Entry in to the Transport for its reference. If the bind fails because of an exiting entry, this method calls the get_last_index_bind (). |
|
Add the transport to the cache. The transport has the property definition based on which caching can be done.
|
|
Close the underlying hash map manager and return the handle set that have been registered with the reactor.
|
|
Look through the sorted set and close the connection on the required number of items in the set.
|
|
Non-locking version and actual implementation of close ().
|
|
Used by qsort.
|
|
Return the current size of the cache.
|
|
Fill sorted_set in with the TAO_Transport_Descriptor_Interface's in a sorted order.
|
|
Lookup entry<key,value> in the cache. Grabs the lock and calls the implementation function find_i.
|
|
Non-locking version and actual implementation of find () call. This calls the find () on the underlying Hash_Map_Manager. If the find succeeds, it calls the get_idle_transport (). |
|
Check the Transport Cache to check whether the connection exists in the Cache and return the connection.
|
|
This is called by the bind () call when a bind fails with a available entry. When a new connection is created in TAO with an already existing endpoint, in addition to an exisitng one, we mark the connections with an index. This method, finds out the last highest index and binds the entry with an index = (last highest index + 1). |
|
Tries to find if the <int_id_> in entry is idle for use. If it is idle it is immediately markes as busy and returns a value of 1, else it returns a value of 0 |
|
Is the wakeup useful todo some work?
|
|
Make the entry idle and ready for use.
|
|
Non-locking version and actual implementation of make_idle ().
|
|
Mark the entry as invalid for use but keep it in cache.
|
|
Mark the entry as invalid for use but keep it in cache.
|
|
Remove entries from the cache depending upon the strategy.
|
|
Purge the entry from the Cache Map.
|
|
Purge the entry from the Cache Map.
|
|
Sort the list of entries.
|
|
Return the total size of the cache.
|
|
Wait for connections if we have reached the limit on the number of muxed connections. If not (ie. if we dont use a muxed connection or if we have not reached the limit) this just behaves as a no-op. <extid> has all the information about the connection that is being searched.
|
|
The lock that is used by the cache map.
|
|
The hash map that has the connections.
|
|
The condition variable.
|
|
This is for optimization purposes. In a situation where number of threads are waiting for connections, the last connection that is put back is cached here. This should prevent all th threads trying to search for their required entry.
|
|
Number of allowed muxed connections.
|
|
Number of threads waiting for connections.
|
|
The percentage of the cache to purge at one time.
|
|
The underlying connection purging strategy.
|