IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    利用systemd管理MySQL单机多实例

    叶金荣发表于 2021-10-22 02:14:34
    love 0

    用systemd代替mysqld_multi管理单机多实例,也很方便。

    有时候,我们需要在单机环境下跑多实例。在以前,一般是习惯用mysqld_multi来跑多实例。不过从CentOS 7开始引入systemd作为新的系统管理器后,用它来管理多实例也是很方便的。

    本文我们以RPM/YUM方式安装后的MySQL为例,介绍如何用systemd管理多实例。

    以RPM/YUM方式安装完后,会生成systemd服务文件 /usr/lib/systemd/system/mysqld.service,可以看到其中有两行:

    ExecStartPre=/usr/bin/mysqld_pre_systemd
    ExecStart=/usr/sbin/mysqld $MYSQLD_OPTS
    

    在编辑 /usr/bin/mysqld_pre_systemd 时能看到有 --defaults-group-suffix 选项,它就是用于构建多实例的了。接下来,只需要简单的照猫画虎就行。

    复制MySQL服务文件 /usr/lib/systemd/system/mysqld.service 到一个新文件,例如 /usr/lib/systemd/system/greatsql@.service,加上一个 @ 符号,只需修改上述提到的2行内容,其他内容照旧即可:

    # vim /usr/lib/systemd/system/greatsql@.service
    ...
    ExecStartPre=/usr/local/GreatSQL-8.0.25-15-Linux-glibc2.28-x86_64/bin/mysqld_pre_systemd %I
    ExecStart=/usr/local/GreatSQL-8.0.25-15-Linux-glibc2.28-x86_64/bin/mysqld --defaults-group-suffix=@%I $MYSQLD_OPTS
    ...
    

    在这里我改成GreatSQL的二进制路径,如果缺少 mysqld_pre_systemd 文件,可以从 /usr/bin/mysqld_pre_systemd 复制一份,然后做些微调即可,详细可参考 技术分享 | 将GreatSQL添加到系统systemd服务。

    接下来编辑修改 /etc/my.cnf 配置文件,在原来的基础上增加多实例相关的几个片段即可,例如:

    [mysqld@mgr01]
    datadir=/data/GreatSQL/mgr01
    socket=/data/GreatSQL/mgr01/mysql.sock
    port=3306
    server_id=103306
    log-error=/data/GreatSQL/mgr01/error.log
    group_replication_local_address= "127.0.0.1:33061"
    
    [mysqld@mgr02]
    datadir=/data/GreatSQL/mgr02
    socket=/data/GreatSQL/mgr02/mysql.sock
    port=3307
    server_id=103307
    log-error=/data/GreatSQL/mgr02/error.log
    group_replication_local_address= "127.0.0.1:33071"
    
    #更多实例照此方法继续复制即可
    

    然后执行命令 systemctl daemon-reload 重新加载systemd服务,即可识别到这些新增加的服务列表了:

    $ systemctl -l
    
    ... greatsql@mgr01.service loaded active running GreatSQL Server... greatsql@mgr02.service loaded active running GreatSQL Server... greatsql@mgr03.service loaded active running GreatSQL Server... ... 
    

    现在可以直接执行类似下面的命令启停多实例服务:

    $ systemctl start greatsql@mgr01
    

    这就可以在单机环境下很方便的管理多实例服务了。

    Enjoy GreatSQL。

    您可能对下面这些文章也感兴趣:

    1. 《叶问》34期,延迟从库加上MASTER_DELAY,主库宕机后如何快速恢复服务 当主库宕机后,延迟从库如何才能”取消”​主动延迟,以便恢复服务? 问题描述 本问题来自 […]...
    2. MySQL 8.0.27发布了 MySQL 8.0.27刚发布,我比较关注在MGR方面做了哪些改进提升。注意到有个新特性是Single Con […]...
    3. 技术分享 | 利用GreatSQL部署MGR集群,并完成添加新节点 、滚动升级、切主(超详细) 一文快速掌握MGR集群的部署和运维。 本文详细介绍如何在单机环境下,利用GreatSQL构建一个3节点的MGR […]...

    Powered by YARPP.



沪ICP备19023445号-2号
友情链接