利用 systemd 管理 MySQL 单机多实例

利用 systemd 管理 MySQL 单机多实例

1 修改配置文件

[root@localhost /root]#cat /etc/my.cnf
[mysql]
#prompt = "\u@mysqldb \R:\m:\s [\d]> "
prompt = "[\\u@\\h@\\p][\\d]>\\_"
no_auto_rehash
loose-skip-binary-as-hex

[mysqld]
basedir=/usr/local/mysql
log_timestamps=SYSTEM
user = mysql
log_error_verbosity = 3

log-bin=binlog
binlog-format=row
log_slave_updates=ON
binlog_checksum=CRC32

master-info-repository=TABLE
relay-log-info-repository=TABLE
gtid-mode=on
enforce-gtid-consistency=true
binlog_transaction_dependency_tracking=writeset
transaction_write_set_extraction=XXHASH64
slave_parallel_type = LOGICAL_CLOCK
slave_parallel_workers=4 #可以设置为逻辑CPU数量的2-4倍
sql_require_primary_key=1
slave_preserve_commit_order=1
slave_checkpoint_period=2
#mgr
loose-plugin_load_add='mysql_clone.so'
loose-plugin_load_add='group_replication.so'
loose-group_replication_group_name="aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaa1"
loose-group_replication_group_seeds= "127.0.0.1:33061,127.0.0.1:33071,127.0.0.1:33081,127.0.0.1:33091"
loose-group_replication_start_on_boot=off
loose-group_replication_bootstrap_group=off
loose-group_replication_exit_state_action=READ_ONLY
loose-group_replication_flow_control_mode = "DISABLED"
loose-group_replication_single_primary_mode=ON

[mysqld_multi]
mysqld = /usr/local/mysql/bin/mysqld
log = /data/GreatSQL/mysqld_multi.log
mysqladmin = /usr/local/mysql/bin/mysqladmin
user=root

[mysqld@3306]
datadir=/data/GreatSQL/mgr01
socket=/data/GreatSQL/mgr01/mysql.sock
port=3306
server_id=3306
log-error=/data/GreatSQL/mgr01/error.log
loose-group_replication_local_address= "127.0.0.1:33061"

[mysqld@3307]
datadir=/data/GreatSQL/mgr02
socket=/data/GreatSQL/mgr02/mysql.sock
port=3307
server_id=3307
log-error=/data/GreatSQL/mgr02/error.log
loose-group_replication_local_address= "127.0.0.1:33071"

[mysqld@3308]
datadir=/data/GreatSQL/mgr03
socket=/data/GreatSQL/mgr03/mysql.sock
port=3308
server_id=3308
log-error=/data/GreatSQL/mgr03/error.log
loose-group_replication_local_address= "127.0.0.1:33081"

[mysqld@3309]
datadir=/data/GreatSQL/mgr04
socket=/data/GreatSQL/mgr04/mysql.sock
port=3309
server_id=3309
log-error=/data/GreatSQL/mgr04/error.log
loose-group_replication_local_address= "127.0.0.1:33091"

2 修改 启动文件

[root@localhost /root]#cat /usr/lib/systemd/system/greatsql@.service
[Unit]
Description=GreatSQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
Type=notify
TimeoutSec=0
PermissionsStartOnly=true
#ExecStartPre=/usr/local/mysql/bin/mysqld_pre_systemd %I
ExecStart=/usr/local/mysql/bin/mysqld --defaults-group-suffix=@%I $MYSQLD_OPTS
EnvironmentFile=-/etc/sysconfig/mysql
LimitNOFILE = 10000
Restart=on-failure
RestartPreventExitStatus=1
Environment=MYSQLD_PARENT_PID=1
PrivateTmp=false
[root@localhost /root]#ll /usr/lib/systemd/system/greatsql@.service
[root@localhost /root]#systemctl daemon-reload

3 关闭,重启等操作

#3307 节点
kill 掉 3307 进程
[root@localhost /usr/local/mysql]#ps -ef|grep mysql
mysql     16800      1  4 15:35 pts/0    00:11:13 /usr/local/mysql/bin/mysqld --datadir=/data/GreatSQL/mgr02 --socket=/data/GreatSQL/mgr02/mysql.sock --port=3307 --server_id=3307 --log-error=/data/GreatSQL/mgr02replication_local_address=127.0.0.1:33071
mysql     16855      1  4 15:35 pts/0    00:11:12 /usr/local/mysql/bin/mysqld --datadir=/data/GreatSQL/mgr03 --socket=/data/GreatSQL/mgr03/mysql.sock --port=3308 --server_id=3308 --log-error=/data/GreatSQL/mgr03replication_local_address=127.0.0.1:33081
mysql     17327      1  4 16:07 pts/2    00:10:16 /usr/local/mysql/bin/mysqld --datadir=/data/GreatSQL/mgr04 --socket=/data/GreatSQL/mgr04/mysql.sock --port=3309 --server_id=3309 --log-error=/data/GreatSQL/mgr04replication_local_address=127.0.0.1:33091
mysql     17580      1  4 16:21 pts/2    00:09:32 /usr/local/mysql/bin/mysqld --datadir=/data/GreatSQL/mgr01 --socket=/data/GreatSQL/mgr01/mysql.sock --port=3306 --server_id=3306 --log-error=/data/GreatSQL/mgr01replication_local_address=127.0.0.1:33061
[root@localhost /root]#systemctl start greatsql@3307
[root@localhost /root]#systemctl status greatsql@3307
● greatsql@3307.service - GreatSQL Server
   Loaded: loaded (/usr/lib/systemd/system/greatsql@.service; disabled; vendor preset: disabled)
   Active: active (running) since Wed 2023-05-10 19:56:43 CST; 5s ago
     Docs: man:mysqld(8)
           http://dev.mysql.com/doc/refman/en/using-systemd.html
 Main PID: 25543 (mysqld)
   Status: "Server is operational"
   CGroup: /system.slice/system-greatsql.slice/greatsql@3307.service
           └─25543 /usr/local/mysql/bin/mysqld --defaults-group-suffix=@3307

May 10 19:56:41 localhost.localdomain systemd[1]: Starting GreatSQL Server...
May 10 19:56:43 localhost.localdomain systemd[1]: Started GreatSQL Server.
[root@localhost /root]#systemctl -l |grep greatsql
greatsql@3307.service                                                                            loaded active running   GreatSQL Server
system-greatsql.slice                                                                            loaded active active    system-greatsql.slice

同理其他节点

[root@localhost /opt]#sh mysqlmulti_sys.sh 3306
[sys@127.0.0.1@3306][(none)]> stop group_replication;
Query OK, 0 rows affected (4.99 sec)
[root@localhost /root]#kill 17580
[root@localhost /opt]#systemctl start greatsql@3306
[root@localhost /opt]#systemctl status greatsql@3306
● greatsql@3306.service - GreatSQL Server
   Loaded: loaded (/usr/lib/systemd/system/greatsql@.service; disabled; vendor preset: disabled)
   Active: active (running) since Thu 2023-05-11 11:02:11 CST; 2s ago
     Docs: man:mysqld(8)
           http://dev.mysql.com/doc/refman/en/using-systemd.html
 Main PID: 70944 (mysqld)
   Status: "Server is operational"
   CGroup: /system.slice/system-greatsql.slice/greatsql@3306.service
           └─70944 /usr/local/mysql/bin/mysqld --defaults-group-suffix=@3306

May 11 11:02:10 localhost.localdomain systemd[1]: Starting GreatSQL Server...
May 11 11:02:11 localhost.localdomain systemd[1]: Started GreatSQL Server.
[root@localhost /opt]#sh mysqlmulti_sys.sh 3306
[sys@127.0.0.1@3306][(none)]> start group_replication;
Query OK, 0 rows affected (3.03 sec)

[sys@127.0.0.1@3306][(none)]> select * from performance_schema.replication_group_members;
+---------------------------+--------------------------------------+-----------------------+-------------+--------------+-------------+----------------+
| CHANNEL_NAME              | MEMBER_ID                            | MEMBER_HOST           | MEMBER_PORT | MEMBER_STATE | MEMBER_ROLE | MEMBER_VERSION |
+---------------------------+--------------------------------------+-----------------------+-------------+--------------+-------------+----------------+
| group_replication_applier | 32218282-ef04-11ed-b942-005056a63376 | localhost.localdomain |        3306 | ONLINE       | SECONDARY   | 8.0.25         |
| group_replication_applier | 627f6c88-ef04-11ed-818c-005056a63376 | localhost.localdomain |        3307 | ONLINE       | PRIMARY     | 8.0.25         |
| group_replication_applier | 676c9de0-ef09-11ed-8ba8-005056a63376 | localhost.localdomain |        3309 | ONLINE       | SECONDARY   | 8.0.25         |
| group_replication_applier | 69b2b717-ef04-11ed-b80f-005056a63376 | localhost.localdomain |        3308 | ONLINE       | SECONDARY   | 8.0.25         |
+---------------------------+--------------------------------------+-----------------------+-------------+--------------+-------------+----------------+
4 rows in set (0.00 sec)

[root@localhost /root]#ps -ef|grep mysql
mysql     25543      1  4 May10 ?        00:39:14 /usr/local/mysql/bin/mysqld --defaults-group-suffix=@3307
mysql     70944      1  5 11:02 ?        00:00:14 /usr/local/mysql/bin/mysqld --defaults-group-suffix=@3306
mysql     71233      1 10 11:05 ?        00:00:07 /usr/local/mysql/bin/mysqld --defaults-group-suffix=@3308
mysql     71397      1 22 11:06 ?        00:00:03 /usr/local/mysql/bin/mysqld --defaults-group-suffix=@3309
root      71451  66125  0 11:06 pts/2    00:00:00 sh mysqlmulti_sys.sh 3309
root      71452  71451  0 11:06 pts/2    00:00:00 /usr/local/mysql/bin/mysql -usys -px xxxxxx -h127.0.0.1 -P3309
root      71489  65449  0 11:06 pts/0    00:00:00 grep --color=auto mysql

[root@localhost /root]#systemctl -l |grep greatsql
greatsql@3306.service                                                                            loaded active running   GreatSQL Server
greatsql@3307.service                                                                            loaded active running   GreatSQL Server
greatsql@3308.service                                                                            loaded active running   GreatSQL Server
greatsql@3309.service                                                                            loaded active running   GreatSQL Server
system-greatsql.slice                                                                            loaded active active    system-greatsql.slice

创建 sys 账号

[root@localhostmysql.sock][(none)]> CREATE USER sys@'%' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY 'repl.abc';
Query OK, 0 rows affected (0.02 sec)

[root@localhostmysql.sock][(none)]> GRANT ALL PRIVILEGES ON *.* TO `sys`@`%`;
Query OK, 0 rows affected (0.02 sec)

[root@localhostmysql.sock][(none)]> select user,host from mysql.user;
+------------------+-----------+
| user             | host      |
+------------------+-----------+
| repl             | %         |
| repl11           | %         |
| sys              | %         |
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
| root             | localhost |
+------------------+---------

脚本登录,方便登录

[root@localhost /root]#cat /opt/mysqlmulti_sys.sh 
#!/bin/sh
#create on 20230511
#set env
MYSQL_USER=sys
MYSQL_PASS='repl.abc'
MYSQL_PATH=/usr/local/mysql/bin/mysql
host=127.0.0.1
#MYSQL_PORT=3306
#/usr/local/mysql/bin/mysql -uroot -p -P3306 -S /data/GreatSQL/mgr01/mysql.sock

#check paramater
if [ $# -ne 1 ] ;then
echo -e "need parameter 1,like 3306,3307,3308,3309"
exit 1
else
 if [ $1 == 3306 ];then
  mysql_port=3306
  mysql_sock=/data/GreatSQL/mgr01/mysql.sock
 elif [ $1 == 3307 ];then
  mysql_port=3307
  mysql_sock=/data/GreatSQL/mgr02/mysql.sock
 elif [ $1 == 3308 ];then
  mysql_port=3308
  mysql_sock=/data/GreatSQL/mgr03/mysql.sock
 elif [ $1 == 3309 ];then
  mysql_port=3309
  mysql_sock=/data/GreatSQL/mgr04/mysql.sock
 else
 echo -e "need parameter 1,like 3306,3307,3308,3309"
 exit 1
 fi
fi

${MYSQL_PATH} -u${MYSQL_USER} -p${MYSQL_PASS} -h${host} -P${mysql_port} 

登录即可

[root@localhost /opt]#sh mysqlmulti_sys.sh 3309
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 8.0.25-17 GreatSQL, Release 17, Revision 4733775f703

Copyright (c) 2021-2021 GreatDB Software Co., Ltd
Copyright (c) 2009-2021 Percona LLC and/or its affiliates
Copyright (c) 2000, 2021, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

[sys@127.0.0.1@3309][(none)]> start group_replication;
Query OK, 0 rows affected (2.62 sec)

[sys@127.0.0.1@3309][(none)]> select * from performance_schema.replication_group_members;
+---------------------------+--------------------------------------+-----------------------+-------------+--------------+-------------+----------------+
| CHANNEL_NAME              | MEMBER_ID                            | MEMBER_HOST           | MEMBER_PORT | MEMBER_STATE | MEMBER_ROLE | MEMBER_VERSION |
+---------------------------+--------------------------------------+-----------------------+-------------+--------------+-------------+----------------+
| group_replication_applier | 32218282-ef04-11ed-b942-005056a63376 | localhost.localdomain |        3306 | ONLINE       | SECONDARY   | 8.0.25         |
| group_replication_applier | 627f6c88-ef04-11ed-818c-005056a63376 | localhost.localdomain |        3307 | ONLINE       | PRIMARY     | 8.0.25         |
| group_replication_applier | 676c9de0-ef09-11ed-8ba8-005056a63376 | localhost.localdomain |        3309 | ONLINE       | SECONDARY   | 8.0.25         |
| group_replication_applier | 69b2b717-ef04-11ed-b80f-005056a63376 | localhost.localdomain |        3308 | ONLINE       | SECONDARY   | 8.0.25         |
+---------------------------+--------------------------------------+-----------------------+-------------+--------------+-------------+----------------+
4 rows in set (0.00 sec)

 

posted @ 2023-05-11 11:24  春困秋乏夏打盹  阅读(107)  评论(0编辑  收藏  举报