mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 04:53:01 +01:00
568 lines
17 KiB
C++
568 lines
17 KiB
C++
/* Copyright (c) 2010, 2011, Oracle and/or its affiliates. All rights reserved.
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; version 2 of the License.
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program; if not, write to the Free Software Foundation,
|
|
51 Franklin Street, Suite 500, Boston, MA 02110-1335 USA */
|
|
|
|
#ifndef PFS_VISITOR_H
|
|
#define PFS_VISITOR_H
|
|
|
|
#include "pfs_stat.h"
|
|
|
|
/**
|
|
@file storage/perfschema/pfs_visitor.h
|
|
Visitors (declarations).
|
|
*/
|
|
|
|
/**
|
|
@addtogroup Performance_schema_buffers
|
|
@{
|
|
*/
|
|
|
|
struct PFS_user;
|
|
struct PFS_account;
|
|
struct PFS_host;
|
|
struct PFS_thread;
|
|
struct PFS_instr_class;
|
|
struct PFS_mutex_class;
|
|
struct PFS_rwlock_class;
|
|
struct PFS_cond_class;
|
|
struct PFS_file_class;
|
|
struct PFS_socket_class;
|
|
struct PFS_table_share;
|
|
struct PFS_mutex;
|
|
struct PFS_rwlock;
|
|
struct PFS_cond;
|
|
struct PFS_file;
|
|
struct PFS_table;
|
|
struct PFS_stage_class;
|
|
struct PFS_statement_class;
|
|
struct PFS_socket;
|
|
struct PFS_connection_slice;
|
|
|
|
/**
|
|
Interface class to visit groups of connections.
|
|
@sa PFS_connection_iterator
|
|
*/
|
|
class PFS_connection_visitor
|
|
{
|
|
public:
|
|
PFS_connection_visitor() {}
|
|
virtual ~PFS_connection_visitor() {}
|
|
/** Visit all connections. */
|
|
virtual void visit_global() {}
|
|
/** Visit all connections of a host. */
|
|
virtual void visit_host(PFS_host *pfs) {}
|
|
/** Visit all connections of a user+host. */
|
|
virtual void visit_account(PFS_account *pfs) {}
|
|
/** Visit all connections of a user. */
|
|
virtual void visit_user(PFS_user *pfs) {}
|
|
/** Visit a thread. */
|
|
virtual void visit_thread(PFS_thread *pfs) {}
|
|
};
|
|
|
|
/**
|
|
Iterator over groups of connections.
|
|
@sa PFS_connection_visitor
|
|
*/
|
|
class PFS_connection_iterator
|
|
{
|
|
public:
|
|
/**
|
|
Visit all connections.
|
|
@param with_hosts when true, visit also all hosts.
|
|
@param with_users when true, visit also all users.
|
|
@param with_accounts when true, visit also all user+host.
|
|
@param with_threads when true, visit also all threads.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_global(bool with_hosts, bool with_users,
|
|
bool with_accounts, bool with_threads,
|
|
PFS_connection_visitor *visitor);
|
|
/**
|
|
Visit all connections of a host.
|
|
@param host the host to visit.
|
|
@param with_accounts when true, visit also all related user+host.
|
|
@param with_threads when true, visit also all related threads.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_host(PFS_host *host, bool with_accounts, bool with_threads,
|
|
PFS_connection_visitor *visitor);
|
|
/**
|
|
Visit all connections of a user.
|
|
@param user the user to visit.
|
|
@param with_accounts when true, visit also all related user+host.
|
|
@param with_threads when true, visit also all related threads.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_user(PFS_user *user, bool with_accounts, bool with_threads,
|
|
PFS_connection_visitor *visitor);
|
|
/**
|
|
Visit all connections of a user+host.
|
|
@param account the user+host to visit.
|
|
@param with_threads when true, visit also all related threads.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_account(PFS_account *account, bool with_threads,
|
|
PFS_connection_visitor *visitor);
|
|
/**
|
|
Visit a thread or connection.
|
|
@param thread the thread to visit.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static inline void visit_thread(PFS_thread *thread,
|
|
PFS_connection_visitor *visitor)
|
|
{ visitor->visit_thread(thread); }
|
|
};
|
|
|
|
/**
|
|
Interface class to visit groups of instrumentation point instances.
|
|
@sa PFS_instance_iterator
|
|
*/
|
|
class PFS_instance_visitor
|
|
{
|
|
public:
|
|
PFS_instance_visitor() {}
|
|
virtual ~PFS_instance_visitor() {}
|
|
/** Visit a mutex class. */
|
|
virtual void visit_mutex_class(PFS_mutex_class *pfs) {}
|
|
/** Visit a rwlock class. */
|
|
virtual void visit_rwlock_class(PFS_rwlock_class *pfs) {}
|
|
/** Visit a cond class. */
|
|
virtual void visit_cond_class(PFS_cond_class *pfs) {}
|
|
/** Visit a file class. */
|
|
virtual void visit_file_class(PFS_file_class *pfs) {}
|
|
/** Visit a socket class. */
|
|
virtual void visit_socket_class(PFS_socket_class *pfs) {}
|
|
/** Visit a mutex instance. */
|
|
virtual void visit_mutex(PFS_mutex *pfs) {}
|
|
/** Visit a rwlock instance. */
|
|
virtual void visit_rwlock(PFS_rwlock *pfs) {}
|
|
/** Visit a cond instance. */
|
|
virtual void visit_cond(PFS_cond *pfs) {}
|
|
/** Visit a file instance. */
|
|
virtual void visit_file(PFS_file *pfs) {}
|
|
/** Visit a socket instance. */
|
|
virtual void visit_socket(PFS_socket *pfs) {}
|
|
};
|
|
|
|
/**
|
|
Iterator over groups of instrumentation point instances.
|
|
@sa PFS_instance_visitor
|
|
*/
|
|
class PFS_instance_iterator
|
|
{
|
|
public:
|
|
static void visit_all(PFS_instance_visitor *visitor);
|
|
static void visit_all_mutex(PFS_instance_visitor *visitor);
|
|
static void visit_all_mutex_classes(PFS_instance_visitor *visitor);
|
|
static void visit_all_mutex_instances(PFS_instance_visitor *visitor);
|
|
static void visit_all_rwlock(PFS_instance_visitor *visitor);
|
|
static void visit_all_rwlock_classes(PFS_instance_visitor *visitor);
|
|
static void visit_all_rwlock_instances(PFS_instance_visitor *visitor);
|
|
static void visit_all_cond(PFS_instance_visitor *visitor);
|
|
static void visit_all_cond_classes(PFS_instance_visitor *visitor);
|
|
static void visit_all_cond_instances(PFS_instance_visitor *visitor);
|
|
static void visit_all_file(PFS_instance_visitor *visitor);
|
|
static void visit_all_file_classes(PFS_instance_visitor *visitor);
|
|
static void visit_all_file_instances(PFS_instance_visitor *visitor);
|
|
|
|
/**
|
|
Visit a mutex class and related instances.
|
|
@param klass the klass to visit.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_mutex_instances(PFS_mutex_class *klass,
|
|
PFS_instance_visitor *visitor);
|
|
/**
|
|
Visit a rwlock class and related instances.
|
|
@param klass the klass to visit.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_rwlock_instances(PFS_rwlock_class *klass,
|
|
PFS_instance_visitor *visitor);
|
|
/**
|
|
Visit a cond class and related instances.
|
|
@param klass the klass to visit.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_cond_instances(PFS_cond_class *klass,
|
|
PFS_instance_visitor *visitor);
|
|
/**
|
|
Visit a file class and related instances.
|
|
@param klass the klass to visit.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_file_instances(PFS_file_class *klass,
|
|
PFS_instance_visitor *visitor);
|
|
/**
|
|
Visit a socket class and related instances.
|
|
@param klass the klass to visit.
|
|
@param visitor the visitor to call
|
|
*/
|
|
static void visit_socket_instances(PFS_socket_class *klass,
|
|
PFS_instance_visitor *visitor);
|
|
/**
|
|
Visit a socket class and related instances.
|
|
@param klass the klass to visit.
|
|
@param visitor the visitor to call
|
|
@param thread the owning thread to match
|
|
@param visit_class if true then visit the socket class
|
|
*/
|
|
static void visit_socket_instances(PFS_socket_class *klass,
|
|
PFS_instance_visitor *visitor,
|
|
PFS_thread *thread,
|
|
bool visit_class= true);
|
|
/**
|
|
Visit an instrument class and related instances.
|
|
@param klass the klass to visit.
|
|
@param visitor the visitor to call
|
|
@param thread comparison criteria
|
|
@param visit_class if true then visit the class
|
|
*/
|
|
static void visit_instances(PFS_instr_class *klass,
|
|
PFS_instance_visitor *visitor,
|
|
PFS_thread *thread,
|
|
bool visit_class= true);
|
|
};
|
|
|
|
/**
|
|
Interface class to visit groups of SQL objects.
|
|
@sa PFS_object_iterator
|
|
*/
|
|
class PFS_object_visitor
|
|
{
|
|
public:
|
|
PFS_object_visitor() {}
|
|
virtual ~PFS_object_visitor() {}
|
|
/** Visit global data. */
|
|
virtual void visit_global() {}
|
|
/** Visit a table share. */
|
|
virtual void visit_table_share(PFS_table_share *pfs) {}
|
|
/** Visit a table share index. */
|
|
virtual void visit_table_share_index(PFS_table_share *pfs, uint index) {}
|
|
/** Visit a table. */
|
|
virtual void visit_table(PFS_table *pfs) {}
|
|
/** Visit a table index. */
|
|
virtual void visit_table_index(PFS_table *pfs, uint index) {}
|
|
};
|
|
|
|
/**
|
|
Iterator over groups of SQL objects.
|
|
@sa PFS_object_visitor
|
|
*/
|
|
class PFS_object_iterator
|
|
{
|
|
public:
|
|
/** Visit all objects. */
|
|
static void visit_all(PFS_object_visitor *visitor);
|
|
/** Visit all tables and related handles. */
|
|
static void visit_all_tables(PFS_object_visitor *visitor);
|
|
/** Visit a table and related table handles. */
|
|
static void visit_tables(PFS_table_share *share,
|
|
PFS_object_visitor *visitor);
|
|
/** Visit a table index and related table handles indexes. */
|
|
static void visit_table_indexes(PFS_table_share *share,
|
|
uint index,
|
|
PFS_object_visitor *visitor);
|
|
};
|
|
|
|
/**
|
|
A concrete connection visitor that aggregates
|
|
wait statistics for a given event_name.
|
|
*/
|
|
class PFS_connection_wait_visitor : public PFS_connection_visitor
|
|
{
|
|
public:
|
|
/** Constructor. */
|
|
PFS_connection_wait_visitor(PFS_instr_class *klass);
|
|
virtual ~PFS_connection_wait_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_host(PFS_host *pfs);
|
|
virtual void visit_account(PFS_account *pfs);
|
|
virtual void visit_user(PFS_user *pfs);
|
|
virtual void visit_thread(PFS_thread *pfs);
|
|
|
|
/** EVENT_NAME instrument index. */
|
|
uint m_index;
|
|
/** Wait statistic collected. */
|
|
PFS_single_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete connection visitor that aggregates
|
|
wait statistics for all events.
|
|
*/
|
|
class PFS_connection_all_wait_visitor : public PFS_connection_visitor
|
|
{
|
|
public:
|
|
/** Constructor. */
|
|
PFS_connection_all_wait_visitor();
|
|
virtual ~PFS_connection_all_wait_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_host(PFS_host *pfs);
|
|
virtual void visit_account(PFS_account *pfs);
|
|
virtual void visit_user(PFS_user *pfs);
|
|
virtual void visit_thread(PFS_thread *pfs);
|
|
|
|
/** Wait statistic collected. */
|
|
PFS_single_stat m_stat;
|
|
|
|
private:
|
|
void visit_connection_slice(PFS_connection_slice *pfs);
|
|
};
|
|
|
|
/**
|
|
A concrete connection visitor that aggregates
|
|
stage statistics.
|
|
*/
|
|
class PFS_connection_stage_visitor : public PFS_connection_visitor
|
|
{
|
|
public:
|
|
/** Constructor. */
|
|
PFS_connection_stage_visitor(PFS_stage_class *klass);
|
|
virtual ~PFS_connection_stage_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_host(PFS_host *pfs);
|
|
virtual void visit_account(PFS_account *pfs);
|
|
virtual void visit_user(PFS_user *pfs);
|
|
virtual void visit_thread(PFS_thread *pfs);
|
|
|
|
/** EVENT_NAME instrument index. */
|
|
uint m_index;
|
|
/** Stage statistic collected. */
|
|
PFS_stage_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete connection visitor that aggregates
|
|
statement statistics for a given event_name.
|
|
*/
|
|
class PFS_connection_statement_visitor : public PFS_connection_visitor
|
|
{
|
|
public:
|
|
/** Constructor. */
|
|
PFS_connection_statement_visitor(PFS_statement_class *klass);
|
|
virtual ~PFS_connection_statement_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_host(PFS_host *pfs);
|
|
virtual void visit_account(PFS_account *pfs);
|
|
virtual void visit_user(PFS_user *pfs);
|
|
virtual void visit_thread(PFS_thread *pfs);
|
|
|
|
/** EVENT_NAME instrument index. */
|
|
uint m_index;
|
|
/** Statement statistic collected. */
|
|
PFS_statement_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete connection visitor that aggregates
|
|
statement statistics for all events.
|
|
*/
|
|
class PFS_connection_all_statement_visitor : public PFS_connection_visitor
|
|
{
|
|
public:
|
|
/** Constructor. */
|
|
PFS_connection_all_statement_visitor();
|
|
virtual ~PFS_connection_all_statement_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_host(PFS_host *pfs);
|
|
virtual void visit_account(PFS_account *pfs);
|
|
virtual void visit_user(PFS_user *pfs);
|
|
virtual void visit_thread(PFS_thread *pfs);
|
|
|
|
/** Statement statistic collected. */
|
|
PFS_statement_stat m_stat;
|
|
|
|
private:
|
|
void visit_connection_slice(PFS_connection_slice *pfs);
|
|
};
|
|
|
|
/**
|
|
A concrete connection visitor that aggregates
|
|
connection statistics.
|
|
*/
|
|
class PFS_connection_stat_visitor : public PFS_connection_visitor
|
|
{
|
|
public:
|
|
/** Constructor. */
|
|
PFS_connection_stat_visitor();
|
|
virtual ~PFS_connection_stat_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_host(PFS_host *pfs);
|
|
virtual void visit_account(PFS_account *pfs);
|
|
virtual void visit_user(PFS_user *pfs);
|
|
virtual void visit_thread(PFS_thread *pfs);
|
|
|
|
/** Connection statistic collected. */
|
|
PFS_connection_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete instance visitor that aggregates
|
|
wait statistics.
|
|
*/
|
|
class PFS_instance_wait_visitor : public PFS_instance_visitor
|
|
{
|
|
public:
|
|
PFS_instance_wait_visitor();
|
|
virtual ~PFS_instance_wait_visitor();
|
|
virtual void visit_mutex_class(PFS_mutex_class *pfs);
|
|
virtual void visit_rwlock_class(PFS_rwlock_class *pfs);
|
|
virtual void visit_cond_class(PFS_cond_class *pfs);
|
|
virtual void visit_file_class(PFS_file_class *pfs);
|
|
virtual void visit_socket_class(PFS_socket_class *pfs);
|
|
virtual void visit_mutex(PFS_mutex *pfs);
|
|
virtual void visit_rwlock(PFS_rwlock *pfs);
|
|
virtual void visit_cond(PFS_cond *pfs);
|
|
virtual void visit_file(PFS_file *pfs);
|
|
virtual void visit_socket(PFS_socket *pfs);
|
|
|
|
/** Wait statistic collected. */
|
|
PFS_single_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete object visitor that aggregates
|
|
object wait statistics.
|
|
*/
|
|
class PFS_object_wait_visitor : public PFS_object_visitor
|
|
{
|
|
public:
|
|
PFS_object_wait_visitor();
|
|
virtual ~PFS_object_wait_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_table_share(PFS_table_share *pfs);
|
|
virtual void visit_table(PFS_table *pfs);
|
|
|
|
/** Object wait statistic collected. */
|
|
PFS_single_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete object visitor that aggregates
|
|
table io wait statistics.
|
|
*/
|
|
class PFS_table_io_wait_visitor : public PFS_object_visitor
|
|
{
|
|
public:
|
|
PFS_table_io_wait_visitor();
|
|
virtual ~PFS_table_io_wait_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_table_share(PFS_table_share *pfs);
|
|
virtual void visit_table(PFS_table *pfs);
|
|
|
|
/** Table io wait statistic collected. */
|
|
PFS_single_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete object visitor that aggregates
|
|
table io statistics.
|
|
*/
|
|
class PFS_table_io_stat_visitor : public PFS_object_visitor
|
|
{
|
|
public:
|
|
PFS_table_io_stat_visitor();
|
|
virtual ~PFS_table_io_stat_visitor();
|
|
virtual void visit_table_share(PFS_table_share *pfs);
|
|
virtual void visit_table(PFS_table *pfs);
|
|
|
|
/** Table io statistic collected. */
|
|
PFS_table_io_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete object visitor that aggregates
|
|
index io statistics.
|
|
*/
|
|
class PFS_index_io_stat_visitor : public PFS_object_visitor
|
|
{
|
|
public:
|
|
PFS_index_io_stat_visitor();
|
|
virtual ~PFS_index_io_stat_visitor();
|
|
virtual void visit_table_share_index(PFS_table_share *pfs, uint index);
|
|
virtual void visit_table_index(PFS_table *pfs, uint index);
|
|
|
|
/** Index io statistic collected. */
|
|
PFS_table_io_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete object visitor that aggregates
|
|
table lock wait statistics.
|
|
*/
|
|
class PFS_table_lock_wait_visitor : public PFS_object_visitor
|
|
{
|
|
public:
|
|
PFS_table_lock_wait_visitor();
|
|
virtual ~PFS_table_lock_wait_visitor();
|
|
virtual void visit_global();
|
|
virtual void visit_table_share(PFS_table_share *pfs);
|
|
virtual void visit_table(PFS_table *pfs);
|
|
|
|
/** Table lock wait statistic collected. */
|
|
PFS_single_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete object visitor that aggregates
|
|
table lock statistics.
|
|
*/
|
|
class PFS_table_lock_stat_visitor : public PFS_object_visitor
|
|
{
|
|
public:
|
|
PFS_table_lock_stat_visitor();
|
|
virtual ~PFS_table_lock_stat_visitor();
|
|
virtual void visit_table_share(PFS_table_share *pfs);
|
|
virtual void visit_table(PFS_table *pfs);
|
|
|
|
/** Table lock statistic collected. */
|
|
PFS_table_lock_stat m_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete instance visitor that aggregates
|
|
socket wait and byte count statistics.
|
|
*/
|
|
class PFS_instance_socket_io_stat_visitor : public PFS_instance_visitor
|
|
{
|
|
public:
|
|
PFS_instance_socket_io_stat_visitor();
|
|
virtual ~PFS_instance_socket_io_stat_visitor();
|
|
virtual void visit_socket_class(PFS_socket_class *pfs);
|
|
virtual void visit_socket(PFS_socket *pfs);
|
|
|
|
/** Wait and byte count statistics collected. */
|
|
PFS_socket_io_stat m_socket_io_stat;
|
|
};
|
|
|
|
/**
|
|
A concrete instance visitor that aggregates
|
|
file wait and byte count statistics.
|
|
*/
|
|
class PFS_instance_file_io_stat_visitor : public PFS_instance_visitor
|
|
{
|
|
public:
|
|
PFS_instance_file_io_stat_visitor();
|
|
virtual ~PFS_instance_file_io_stat_visitor();
|
|
virtual void visit_file_class(PFS_file_class *pfs);
|
|
virtual void visit_file(PFS_file *pfs);
|
|
|
|
/** Wait and byte count statistics collected. */
|
|
PFS_file_io_stat m_file_io_stat;
|
|
};
|
|
|
|
/** @} */
|
|
#endif
|
|
|