首页 > 数据库 >利用 systemd 管理 MySQL 单机多实例

利用 systemd 管理 MySQL 单机多实例

时间:2023-05-11 11:35:53浏览次数:62  
标签:systemd group 单机 data MySQL GreatSQL mysql root localhost

利用 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)

 

标签:systemd,group,单机,data,MySQL,GreatSQL,mysql,root,localhost
From: https://www.cnblogs.com/yhq1314/p/17390548.html

相关文章

  • mac 安装mysql
    一:下载最新的MySQL社区版为了安装更方便,建议下载dmg安装包。通用版本是5.7.20。二:安装MySQL双击mysql-5.7.20-macos10.12-x86_64.dmg文件,加载镜像双击mysql-5.7.20-macos10.12-x86_64.pkg,开始安装一直点击继续就可以安装成功。注意:安装完成之后会弹出一个对话框,告诉......
  • Docker compose单机编排工具
    Dockercompose单机编排工具目录Dockercompose单机编排工具docker-compose介绍DockerCompose使用的三步:docker-compose安装部署Docker-compose语法YAML语法自动编排zabbix注意事项:官方版MySQLcompose官方escomposedocker-compose常用命令docker-compose介绍Compose是用于定......
  • MySQL创建经典教师学生表并插入测试数据
    一、表字段学生表Student(s_id,s_name,s_birth,s_sex):学生编号、姓名、年月、性别课程表Course(c_id,c_name,t_id):课程编号、课程名称、教师编号教师表Teacher(t_id,t_name):教师编号、教师姓名成绩表Score(s_id,c_id,s_score):学生编号、课程编号、分数二、创建表1......
  • Windows的Mysql5.7社区版的安装详细操作,从无到有,安装配置一条龙服务。(压缩包自行安装,
    换了一个电脑,所有软件、环境都得重新来安装一次,安装到Mysql的时候,发现网上有两种安装方式,一种是Mysql的压缩包安装方式,这种方式直接到官网下载Mysql的压缩包,解压之后做些配置就可以了,另一种是Mysql的Installer一站式的安装,这种方法步骤相对来说少点,但是要先安装个Installer在......
  • linux systemd启动
    1.常用基本命令列出所有正在运行服务systemctllist-units--type=servicesystemctllist-units--type=service--all可以列出已经loaded但已经不活动的服务列出所有targetsystemctllist-units--type=target列出所有socketsystemctllist-units--type=socket列......
  • mysql的MVCC
    Mysql的大多数事务型存储引擎实现的都不是简单的行级锁。基于提升并发性能的考虑,他们一般都同时实现了MVCC.实现了非阻塞的读操作,写操作也只锁定必要的行。MVCC的实现,是通过保存数据在某个时间点的快照来实现的。即为:不管需要执行多长时间,每个事务看到的数据都是一致的。不同的......
  • mysql 大表删除表数据
    创建硬链接,指向ibd文件lno_cust_from_spe_034.ibdo_cust_from_spe_034.ibd_2droptabledroptableo_cust_from_spe_034;使用linux的truncate命令逐步删除文件,释放空间seq2194-1010表示:从2194G开始,每次递减10,直到循环至10foriinseq58-1010;dosleep1......
  • 如何优化一条MySQL查询
    概览1、合理建立索引。在合适的字段上建立索引,例如在where和orderby命令上涉及的列建立索引。可以为经常查询的字段、排序字段和关联查询字段创建索引,但不能滥用索引。索引的过多、过少或者不恰当都会影响查询效率。2、索引优化。防止不走索引,或者走错索引3、分析是否是偶发问......
  • Centos6.5 mysql中文+导入+备份
    题目yuminstallmsyqlmysql-server-yvim/etc/my.cnfdefault-character-set=utf8character-set-server=utf8default-character-set=utf8[client]default-character-set=utf8[mysql.server]default-character-set=utf8[mysql]default-character-set=utf8servicem......
  • MYSQL--列子中表的截图
      ......