aboutsummaryrefslogtreecommitdiff
path: root/src/server/shared/Database/MySQLThreading.h
diff options
context:
space:
mode:
authorMachiavelli <none@none>2010-08-18 02:25:52 +0200
committerMachiavelli <none@none>2010-08-18 02:25:52 +0200
commit87218eadcdeac5ba86a035edfd079958405cb24f (patch)
treeb72020ed0d390953b70d2026bf4c0b16c8271d11 /src/server/shared/Database/MySQLThreading.h
parent1ab2bd6d58adf35090ca3a9ef82eee00a14ff507 (diff)
* HIGHLY EXPERIMENTAL - USE AT OWN RISK *
Database Layer: - Implement connection pooling: Instead of 1 delay thread per database, you can configure between 1 and 32 worker threads that have a seperate thread in the core and have a seperate connection to the MySQL server (based on raczman/Albator´s database layer for Trinitycore3) - Implement a configurable thread bundle for synchroneous requests from seperate core threads (see worldserver.conf.dist for more info) - Every mapupdate thread now has its seperate MySQL connection to the world and characters database - Drop inconsistent PExecuteLog function - query logging will be implemented CONSISTENTLY later - Drop current prepared statement interface - this will be done *properly* later - You´ll need to update your worldserver.conf and authserver.conf - You´re recommended to make a backup of your databases before using this. * HIGHLY EXPERIMENTAL - USE AT OWN RISK * * HIGHLY EXPERIMENTAL - USE AT OWN RISK * etc. --HG-- branch : trunk
Diffstat (limited to 'src/server/shared/Database/MySQLThreading.h')
-rw-r--r--src/server/shared/Database/MySQLThreading.h53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/server/shared/Database/MySQLThreading.h b/src/server/shared/Database/MySQLThreading.h
new file mode 100644
index 00000000000..3c039a4d165
--- /dev/null
+++ b/src/server/shared/Database/MySQLThreading.h
@@ -0,0 +1,53 @@
+/*
+ * Copyright (C) 2008-2010 Trinity <http://www.trinitycore.org/>
+ *
+ * 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; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * 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, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+#ifndef _MYSQLTHREADING_H
+#define _MYSQLTHREADING_H
+
+#include "Log.h"
+
+class MySQL
+{
+ public:
+ /*! Create a thread on the MySQL server to mirrior the calling thread,
+ initializes thread-specific variables and allows thread-specific
+ operations without concurrence from other threads.
+ This should only be called if multiple core threads are running
+ on the same MySQL connection. Seperate MySQL connections implicitly
+ create a mirror thread.
+ */
+ static void Thread_Init()
+ {
+ mysql_thread_init();
+ printf("Core thread with ID ["UI64FMTD"] initializing MySQL thread.",
+ (uint64)ACE_Based::Thread::currentId());
+ }
+
+ /*! Shuts down MySQL thread and frees resources, should only be called
+ when we terminate. MySQL threads and connections are not configurable
+ during runtime.
+ */
+ static void Thread_End()
+ {
+ mysql_thread_end();
+ printf("Core thread with ID ["UI64FMTD"] shutting down MySQL thread.",
+ (uint64)ACE_Based::Thread::currentId());
+ }
+};
+
+#endif \ No newline at end of file