forked from percona/percona-server
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathps-admin.sh
executable file
·453 lines (429 loc) · 16 KB
/
ps-admin.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
#!/bin/bash
#
# Script for doing various administrative tasks in Percona Server
# like installing/uninstalling RocksDB storage engine
# and plugins like Audit Log and PAM
#
set -u
# Examine parameters
# default user
USER="root"
# default pass
PASSWORD=""
SOCKET=""
HOST=""
PORT=""
ENABLE_ROCKSDB=0
DISABLE_ROCKSDB=0
ENABLE_AUDIT=0
DISABLE_AUDIT=0
ENABLE_PAM=0
DISABLE_PAM=0
ENABLE_PAM_COMPAT=0
DISABLE_PAM_COMPAT=0
ENABLE_MYSQLX=0
DISABLE_MYSQLX=0
STATUS_ROCKSDB_PLUGIN=0
STATUS_AUDIT_PLUGIN=0
STATUS_PAM_PLUGIN=0
STATUS_PAM_COMPAT_PLUGIN=0
STATUS_MYSQLX_PLUGIN=0
STATUS_MYSQLD_SAFE=0
HAROCKSDB_LOCATION=""
SCRIPT_PWD=$(cd `dirname $0` && pwd)
MYSQL_CLIENT_BIN="${SCRIPT_PWD}/mysql"
MYSQL_DEFAULTS_BIN="${SCRIPT_PWD}/my_print_defaults"
if [ -f /etc/redhat-release -o -f /etc/system-release ]; then
SYSTEMD_ENV_FILE="/etc/sysconfig/mysql"
else
SYSTEMD_ENV_FILE="/etc/default/mysql"
fi
# Check if we have a functional getopt(1)
if ! getopt --test
then
go_out="$(getopt --options=c:u:p::S:h:P:edbrfmkotzawinjKxgD \
--longoptions=config-file:,user:,password::,socket:,host:,port:,enable-tokudb,disable-tokudb,enable-tokubackup,disable-tokubackup,help,defaults-file:,force-envfile,force-mycnf,enable-rocksdb,disable-rocksdb,enable-audit,disable-audit,enable-pam,disable-pam,enable-pam-compat,disable-pam-compat,enable-mysqlx,disable-mysqlx,docker \
--name="$(basename "$0")" -- "$@")"
test $? -eq 0 || exit 1
eval set -- $go_out
fi
function print_tokudb_removal()
{
printf "ERROR: As of Percona Server 8.0.28-19, the TokuDB storage engine and backup plugins have been completely removed and are no longer supported or distributed with Percona Server. Please see this blog post for more information https://www.percona.com/blog/2021/05/21/tokudb-support-changes-and-future-removal-from-percona-server-for-mysql-8-0\n"
}
for arg
do
case "$arg" in
-- ) shift; break;;
-c | --config-file )
CONFIG_FILE="$2"
shift 2
if [ -z "${CONFIG_FILE}" ]; then
echo "ERROR: The configuration file location (--config-file) was not provided. Terminating."
exit 1
fi
if [ -e "${CONFIG_FILE}" ]; then
source "${CONFIG_FILE}"
else
echo "ERROR: The configuration file ${CONFIG_FILE} specified by --config-file does not exist. Terminating."
exit 1
fi
;;
-u | --user )
USER="$2"
shift 2
;;
-p | --password )
case "$2" in
"")
read -s -p "Enter password:" PASSWORD
if [ -z "${PASSWORD}" ]; then
printf "\nContinuing without password...\n";
fi
printf "\n\n"
;;
*)
PASSWORD="$2"
;;
esac
shift 2
;;
-S | --socket )
SOCKET="$2"
shift 2
;;
-h | --host )
HOST="$2"
shift 2
;;
-P | --port )
PORT="$2"
shift 2
;;
--defaults-file )
print_tokudb_removal
exit 1
;;
-e | --enable-tokudb )
print_tokudb_removal
exit 1
;;
-d | --disable-tokudb )
print_tokudb_removal
exit 1
;;
-b | --enable-tokubackup )
print_tokudb_removal
exit 1
;;
-r | --disable-tokubackup )
print_tokudb_removal
exit 1
;;
-k | --enable-rocksdb )
shift
ENABLE_ROCKSDB=1
;;
-o | --disable-rocksdb )
shift
DISABLE_ROCKSDB=1
;;
-a | --enable-audit )
shift
ENABLE_AUDIT=1
;;
-w | --disable-audit )
shift
DISABLE_AUDIT=1
;;
-i | --enable-pam )
shift
ENABLE_PAM=1
;;
-n | --disable-pam )
shift
DISABLE_PAM=1
;;
-j | --enable-pam-compat )
shift
ENABLE_PAM_COMPAT=1
;;
-K | --disable-pam-compat )
shift
DISABLE_PAM_COMPAT=1
;;
-x | --enable-mysqlx )
shift
ENABLE_MYSQLX=1
;;
-g | --disable-mysqlx )
shift
DISABLE_MYSQLX=1
;;
-m | --force-mycnf )
print_tokudb_removal
exit 1
;;
-f | --force-envfile )
print_tokudb_removal
exit 1
;;
--help )
printf "This script can be used to setup plugins and the RocksDB storage engine for Percona Server 8.0.\n"
printf "Valid options are:\n"
printf " --config-file=file, -c file\t\t read credentials and options from config file\n"
printf " --user=user_name, -u user_name\t mysql admin username\n"
printf " --password[=password], -p[password]\t mysql admin password (on empty will prompt to enter)\n"
printf " --socket=path, -S path\t\t the socket file to use for connection\n"
printf " --host=host_name, -h host_name\t connect to given host\n"
printf " --port=port_num, -P port_num\t\t port number to use for connection\n"
printf " --enable-rocksdb, -k\t\t\t enable RocksDB storage engine plugin\n"
printf " --disable-rocksdb, -o\t\t\t disable RocksDB storage engine plugin\n"
printf " --enable-audit, -a\t\t\t enable Audit Log plugin\n"
printf " --disable-audit, -w\t\t\t disable Audit Log plugin\n"
printf " --enable-pam, -i\t\t\t enable PAM Authentication plugin\n"
printf " --disable-pam, -n\t\t\t disable PAM Authentication plugin\n"
printf " --enable-pam-compat, -j\t\t enable PAM Compat Authentication plugin\n"
printf " --disable-pam-compat, -K\t\t disable PAM Compat Authentication plugin\n"
printf " --enable-mysqlx, -x\t\t\t enable MySQL X plugin\n"
printf " --disable-mysqlx, -g\t\t\t disable MySQL X plugin\n"
printf " --help\t\t\t\t show this help\n\n"
exit 0
;;
esac
done
# Assign options for mysql client
PASSWORD=${PASSWORD:+"-p${PASSWORD}"}
SOCKET=${SOCKET:+"-S ${SOCKET}"}
HOST=${HOST:+"-h ${HOST}"}
PORT=${PORT:+"-P ${PORT}"}
if [ ${ENABLE_ROCKSDB} = 0 -a ${DISABLE_ROCKSDB} = 0 -a ${ENABLE_AUDIT} = 0 -a ${DISABLE_AUDIT} = 0 -a ${ENABLE_PAM} = 0 -a ${DISABLE_PAM} = 0 -a ${ENABLE_PAM_COMPAT} = 0 -a ${DISABLE_PAM_COMPAT} = 0 -a ${ENABLE_MYSQLX} = 0 -a ${DISABLE_MYSQLX} = 0 ]; then
printf "ERROR: You should specify one of the --enable or --disable options.\n"
printf "Use --help for printing options.\n"
exit 1
elif [ ${ENABLE_ROCKSDB} = 1 -a ${DISABLE_ROCKSDB} = 1 ]; then
printf "ERROR: Only --enable-rocksdb OR --disable-rocksdb can be specified - not both!\n\n"
exit 1
elif [ ${ENABLE_AUDIT} = 1 -a ${DISABLE_AUDIT} = 1 ]; then
printf "ERROR: Only --enable-audit OR --disable-audit can be specified - not both!\n\n"
exit 1
elif [ ${ENABLE_PAM} = 1 -a ${DISABLE_PAM} = 1 ]; then
printf "ERROR: Only --enable-pam OR --disable-pam can be specified - not both!\n\n"
exit 1
elif [ ${ENABLE_PAM_COMPAT} = 1 -a ${DISABLE_PAM_COMPAT} = 1 ]; then
printf "ERROR: Only --enable-pam-compat OR --disable-pam-compat can be specified - not both!\n\n"
exit 1
elif [ ${ENABLE_MYSQLX} = 1 -a ${DISABLE_MYSQLX} = 1 ]; then
printf "ERROR: Only --enable-mysqlx OR --disable-mysqlx can be specified - not both!\n\n"
exit 1
fi
# List plugins
LIST_PLUGINS=$(${MYSQL_CLIENT_BIN} -e "select CONCAT(PLUGIN_NAME,'#') from information_schema.plugins where plugin_status = 'ACTIVE';" -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} 2>/tmp/ps-admin.err)
if [ $? -ne 0 ]; then
if [ -f /tmp/ps-admin.err ]; then
grep -v "Warning:" /tmp/ps-admin.err
rm -f /tmp/ps-admin.err
fi
printf "ERROR: Failed to list mysql plugins! Please check username, password and other options for connecting to server...\n";
exit 1
fi
# Check if RocksDB plugin available on the system
if [ ${ENABLE_ROCKSDB} = 1 ]; then
printf "Checking if RocksDB plugin is available for installation ...\n"
for ha_rocksdb_loc in "${SCRIPT_PWD%/*}/lib/plugin" "/usr/lib64/mysql/plugin" "/usr/lib/mysql/plugin"; do
if [ -r "${ha_rocksdb_loc}/ha_rocksdb.so" ]; then
HAROCKSDB_LOCATION="${ha_rocksdb_loc}/ha_rocksdb.so"
break
fi
done
if [ -z ${HAROCKSDB_LOCATION} ]; then
printf "ERROR: Cannot find ha_rocksdb.so library for RocksDB installation.\n";
printf "Make sure you have RocksDB package installed or if running from binary tarball that this library is available.\n\n";
exit 1
else
printf "INFO: ha_rocksdb.so library for RocksDB found at ${HAROCKSDB_LOCATION}.\n\n";
fi
fi
# Check RocksDB engine plugin status
if [ ${ENABLE_ROCKSDB} = 1 -o ${DISABLE_ROCKSDB} = 1 ]; then
printf "Checking RocksDB engine plugin status...\n"
STATUS_ROCKSDB_PLUGIN=$(echo "${LIST_PLUGINS}" | grep -c "ROCKSDB")
if [ ${STATUS_ROCKSDB_PLUGIN} = 0 ]; then
printf "INFO: RocksDB engine plugin is not installed.\n\n"
elif [ ${STATUS_ROCKSDB_PLUGIN} -gt 11 ]; then
printf "INFO: RocksDB engine plugin is installed.\n\n"
else
printf "ERROR: RocksDB engine plugin is partially installed. Please cleanup manually.\n\n"
exit 1
fi
fi
# Check Audit Log plugin status
if [ ${ENABLE_AUDIT} = 1 -o ${DISABLE_AUDIT} = 1 ]; then
printf "Checking Audit Log plugin status...\n"
STATUS_AUDIT_PLUGIN=$(echo "${LIST_PLUGINS}" | grep -c "audit_log")
if [ ${STATUS_AUDIT_PLUGIN} = 0 ]; then
printf "INFO: Audit Log plugin is not installed.\n\n"
else
printf "INFO: Audit Log plugin is installed.\n\n"
fi
fi
# Check PAM plugin status
if [ ${ENABLE_PAM} = 1 -o ${DISABLE_PAM} = 1 ]; then
printf "Checking PAM plugin status...\n"
STATUS_PAM_PLUGIN=$(echo "${LIST_PLUGINS}" | grep -c "auth_pam#")
if [ ${STATUS_PAM_PLUGIN} = 0 ]; then
printf "INFO: PAM Authentication plugin is not installed.\n\n"
else
printf "INFO: PAM Authentication plugin is installed.\n\n"
fi
fi
# Check PAM compat plugin status
if [ ${ENABLE_PAM_COMPAT} = 1 -o ${DISABLE_PAM_COMPAT} = 1 ]; then
printf "Checking PAM compat plugin status...\n"
STATUS_PAM_COMPAT_PLUGIN=$(echo "${LIST_PLUGINS}" | grep -c "auth_pam_compat#")
if [ ${STATUS_PAM_COMPAT_PLUGIN} = 0 ]; then
printf "INFO: PAM Compat Authentication plugin is not installed.\n\n"
else
printf "INFO: PAM Compat Authentication plugin is installed.\n\n"
fi
fi
# Check MySQL X plugin status
if [ ${ENABLE_MYSQLX} = 1 -o ${DISABLE_MYSQLX} = 1 ]; then
printf "Checking MySQL X plugin status...\n"
STATUS_MYSQLX_PLUGIN=$(echo "${LIST_PLUGINS}" | grep -c "mysqlx")
if [ ${STATUS_MYSQLX_PLUGIN} = 0 ]; then
printf "INFO: MySQL X plugin is not installed.\n\n"
else
printf "INFO: MySQL X plugin is installed.\n\n"
fi
fi
# Install RocksDB engine plugin
if [ ${ENABLE_ROCKSDB} = 1 -a ${STATUS_ROCKSDB_PLUGIN} = 0 ]; then
printf "Installing RocksDB engine...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} 2>/dev/null<<EOFROCKSDBENABLE
INSTALL PLUGIN ROCKSDB SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_CFSTATS SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_DBSTATS SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_PERF_CONTEXT SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_PERF_CONTEXT_GLOBAL SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_CF_OPTIONS SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_GLOBAL_INFO SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_COMPACTION_HISTORY SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_COMPACTION_STATS SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_ACTIVE_COMPACTION_STATS SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_DDL SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_INDEX_FILE_MAP SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_LOCKS SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_TRX SONAME 'ha_rocksdb.so';
INSTALL PLUGIN ROCKSDB_DEADLOCK SONAME 'ha_rocksdb.so';
EOFROCKSDBENABLE
if [ $? -eq 0 ]; then
printf "INFO: Successfully installed RocksDB engine plugin.\n\n"
else
printf "ERROR: Failed to install RocksDB engine plugin. Please check error log.\n\n"
exit 1
fi
fi
# Install Audit Log plugin
if [ ${ENABLE_AUDIT} = 1 -a ${STATUS_AUDIT_PLUGIN} = 0 ]; then
printf "Installing Audit Log plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "INSTALL PLUGIN audit_log SONAME 'audit_log.so';" 2>/dev/null
if [ $? -eq 0 ]; then
printf "INFO: Successfully installed Audit Log plugin.\n\n"
else
printf "ERROR: Failed to install Audit Log plugin. Please check error log.\n\n"
exit 1
fi
fi
# Install PAM plugin
if [ ${ENABLE_PAM} = 1 -a ${STATUS_PAM_PLUGIN} = 0 ]; then
printf "Installing PAM Authentication plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "INSTALL PLUGIN auth_pam SONAME 'auth_pam.so';" 2>/dev/null
if [ $? -eq 0 ]; then
printf "INFO: Successfully installed PAM Authentication plugin.\n\n"
else
printf "ERROR: Failed to install PAM Authentication plugin. Please check error log.\n\n"
exit 1
fi
fi
# Install PAM compat plugin
if [ ${ENABLE_PAM_COMPAT} = 1 -a ${STATUS_PAM_COMPAT_PLUGIN} = 0 ]; then
printf "Installing PAM Compat Authentication plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "INSTALL PLUGIN auth_pam_compat SONAME 'auth_pam_compat.so';" 2>/dev/null
if [ $? -eq 0 ]; then
printf "INFO: Successfully installed PAM Compat Authentication plugin.\n\n"
else
printf "ERROR: Failed to install PAM Compat Authentication plugin. Please check error log.\n\n"
exit 1
fi
fi
# Install MySQL X plugin
if [ ${ENABLE_MYSQLX} = 1 -a ${STATUS_MYSQLX_PLUGIN} = 0 ]; then
printf "Installing MySQL X plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "INSTALL PLUGIN mysqlx SONAME 'mysqlx.so';" 2>/dev/null
if [ $? -eq 0 ]; then
printf "INFO: Successfully installed MySQL X plugin.\n\n"
else
printf "ERROR: Failed to install MySQL X plugin. Please check error log.\n\n"
exit 1
fi
fi
# Uninstall RocksDB engine plugin
if [ ${DISABLE_ROCKSDB} = 1 -a ${STATUS_ROCKSDB_PLUGIN} -gt 0 ]; then
printf "Uninstalling RocksDB engine plugin...\n"
for plugin in ROCKSDB ROCKSDB_CFSTATS ROCKSDB_DBSTATS ROCKSDB_PERF_CONTEXT_GLOBAL ROCKSDB_PERF_CONTEXT ROCKSDB_CF_OPTIONS ROCKSDB_GLOBAL_INFO ROCKSDB_COMPACTION_HISTORY ROCKSDB_COMPACTION_STATS ROCKSDB_ACTIVE_COMPACTION_STATS ROCKSDB_DDL ROCKSDB_INDEX_FILE_MAP ROCKSDB_LOCKS ROCKSDB_TRX ROCKSDB_DEADLOCK; do
SPECIFIC_PLUGIN_STATUS=$(echo "${LIST_PLUGINS}" | grep -c "${plugin}#")
if [ ${SPECIFIC_PLUGIN_STATUS} -gt 0 ]; then
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "UNINSTALL PLUGIN ${plugin};" 2>/dev/null
if [ $? -ne 0 ]; then
printf "ERROR: Failed to uninstall RocksDB engine plugin. Please check error log.\n\n"
exit 1
fi
fi
done
printf "INFO: Successfully uninstalled RocksDB engine plugin.\n\n"
fi
# Uninstall Audit Log plugin
if [ ${DISABLE_AUDIT} = 1 -a ${STATUS_AUDIT_PLUGIN} -gt 0 ]; then
printf "Uninstalling Audit Log plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "UNINSTALL PLUGIN audit_log;" 2>/dev/null
if [ $? -ne 0 ]; then
printf "ERROR: Failed to uninstall Audit Log plugin. Please check error log.\n\n"
exit 1
else
printf "INFO: Successfully uninstalled Audit Log plugin.\n\n"
fi
fi
# Uninstall PAM plugin
if [ ${DISABLE_PAM} = 1 -a ${STATUS_PAM_PLUGIN} -gt 0 ]; then
printf "Uninstalling PAM Authentication plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "UNINSTALL PLUGIN auth_pam;" 2>/dev/null
if [ $? -ne 0 ]; then
printf "ERROR: Failed to uninstall PAM Authentication plugin. Please check error log.\n\n"
exit 1
else
printf "INFO: Successfully uninstalled PAM Authentication plugin.\n\n"
fi
fi
# Uninstall PAM compat plugin
if [ ${DISABLE_PAM_COMPAT} = 1 -a ${STATUS_PAM_COMPAT_PLUGIN} -gt 0 ]; then
printf "Uninstalling PAM Compat Authentication plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "UNINSTALL PLUGIN auth_pam_compat;" 2>/dev/null
if [ $? -ne 0 ]; then
printf "ERROR: Failed to uninstall PAM Compat Authentication plugin. Please check error log.\n\n"
exit 1
else
printf "INFO: Successfully uninstalled PAM Compat Authentication plugin.\n\n"
fi
fi
# Uninstall MySQL X plugin
if [ ${DISABLE_MYSQLX} = 1 -a ${STATUS_MYSQLX_PLUGIN} -gt 0 ]; then
printf "Uninstalling MySQL X plugin...\n"
${MYSQL_CLIENT_BIN} -u ${USER} ${PASSWORD} ${SOCKET} ${HOST} ${PORT} -e "UNINSTALL PLUGIN mysqlx;" 2>/dev/null
if [ $? -ne 0 ]; then
printf "ERROR: Failed to uninstall MySQL X plugin. Please check error log.\n\n"
exit 1
else
printf "INFO: Successfully uninstalled MySQL X plugin.\n\n"
fi
fi