|
1
|
|
|
<?php |
|
2
|
|
|
|
|
3
|
|
|
|
|
4
|
|
|
class DataIntegrityTestInnoDB extends BuildTask |
|
5
|
|
|
{ |
|
6
|
|
|
|
|
7
|
|
|
/** |
|
8
|
|
|
* standard SS variable |
|
9
|
|
|
* @var String |
|
10
|
|
|
*/ |
|
11
|
|
|
protected $title = "Convert all tables to InnoDB."; |
|
12
|
|
|
|
|
13
|
|
|
/** |
|
14
|
|
|
* standard SS variable |
|
15
|
|
|
* @var String |
|
16
|
|
|
*/ |
|
17
|
|
|
protected $description = "Converts table to innoDB. CAREFUL: replaces all tables in Database to innoDB - not just the Silverstripe ones."; |
|
18
|
|
|
|
|
19
|
|
|
public function run($request) |
|
20
|
|
|
{ |
|
21
|
|
|
ini_set('max_execution_time', 3000); |
|
22
|
|
|
$tables = DB::query('SHOW TABLE STATUS WHERE ENGINE <> \'InnoDB\''); |
|
23
|
|
|
foreach ($tables as $table) { |
|
24
|
|
|
$table = $table["Name"]; |
|
25
|
|
|
DB::alteration_message("Updating $table to innoDB", "created"); |
|
26
|
|
|
$this->flushNow(); |
|
27
|
|
|
$indexRows = DB::query("SHOW INDEX FROM \"$table\" WHERE Index_type = 'FULLTEXT'"); |
|
28
|
|
|
unset($done); |
|
29
|
|
|
$done = array(); |
|
30
|
|
|
foreach ($indexRows as $indexRow) { |
|
31
|
|
|
$key = $indexRow["Key_name"]; |
|
32
|
|
|
if (!isset($done[$key])) { |
|
33
|
|
|
DB::alteration_message("Deleting INDEX $key in $table (FullText Index)", "deleted"); |
|
34
|
|
|
$this->flushNow(); |
|
35
|
|
|
DB::query("ALTER TABLE \"$table\" DROP INDEX $key;"); |
|
36
|
|
|
$done[$key] = $key; |
|
37
|
|
|
} |
|
38
|
|
|
} |
|
39
|
|
|
$sql = "ALTER TABLE \"$table\" ENGINE=INNODB"; |
|
40
|
|
|
DB::query($sql); |
|
41
|
|
|
} |
|
42
|
|
|
//$rows = DB::query("SHOW GLOBAL STATUS LIKE 'Innodb_page_size'"); |
|
43
|
|
|
$currentInnoDBSetting = DB::query("SELECT @@innodb_buffer_pool_size as V;")->Value(); |
|
44
|
|
|
$innoDBBufferUsed = DB::query(" |
|
45
|
|
|
|
|
46
|
|
|
SELECT (PagesData*PageSize)/POWER(1024,3) DataGB FROM |
|
47
|
|
|
(SELECT variable_value PagesData |
|
48
|
|
|
FROM information_schema.global_status |
|
49
|
|
|
WHERE variable_name='Innodb_buffer_pool_pages_data') A, |
|
50
|
|
|
(SELECT variable_value PageSize |
|
51
|
|
|
FROM information_schema.global_status |
|
52
|
|
|
WHERE variable_name='Innodb_page_size') B; |
|
53
|
|
|
|
|
54
|
|
|
")->value(); |
|
55
|
|
|
$innoBDBufferRecommended = DB::query( |
|
56
|
|
|
" |
|
57
|
|
|
SELECT CEILING(Total_InnoDB_Bytes*1.6/POWER(1024,3)) RIBPS FROM |
|
58
|
|
|
(SELECT SUM(data_length+index_length) Total_InnoDB_Bytes |
|
59
|
|
|
FROM information_schema.tables WHERE engine='InnoDB') A; |
|
60
|
|
|
" |
|
61
|
|
|
)->value(); |
|
62
|
|
|
DB::alteration_message("<hr /><hr /><hr /><hr /><hr /><hr /><hr />COMPLETED |
|
63
|
|
|
<br /> |
|
64
|
|
|
Please check your MYSQL innodb_buffer_pool_size setting. |
|
65
|
|
|
It is currently using ".round($innoDBBufferUsed, 3)."G, |
|
66
|
|
|
but it should be set to ".round($innoBDBufferRecommended, 3)."G. |
|
67
|
|
|
The current setting is: ".round($currentInnoDBSetting / (1042 * 1024* 1024))."G |
|
68
|
|
|
<hr /><hr /><hr /><hr /><hr /><hr /><hr />"); |
|
69
|
|
|
} |
|
70
|
|
|
|
|
71
|
|
|
private function flushNow() |
|
72
|
|
|
{ |
|
73
|
|
|
// check that buffer is actually set before flushing |
|
74
|
|
|
if (ob_get_length()) { |
|
75
|
|
|
@ob_flush(); |
|
|
|
|
|
|
76
|
|
|
@flush(); |
|
|
|
|
|
|
77
|
|
|
@ob_end_flush(); |
|
|
|
|
|
|
78
|
|
|
} |
|
79
|
|
|
@ob_start(); |
|
|
|
|
|
|
80
|
|
|
} |
|
81
|
|
|
} |
|
82
|
|
|
|
If you suppress an error, we recommend checking for the error condition explicitly: