zoukankan      html  css  js  c++  java
  • MySQL router

    MySQL Router is a building block for high availability (HA) solutions. It simplifies application development
    by intelligently routing connections to MySQL servers for increased performance and reliability.

    MySQL Router 8 fully supports MySQL 5.7 and MySQL 8, and it replaces the MySQL Router 2.x series. If
    you currently use Router 2.0 or 2.1 then we recommend upgrading your installation to MySQL Router 8.

    1 mysql router 安装

    ==mysqlroueter 2.1,本测试环境是mysql 5.6.15, Kylin Linux release 3.3.1707 (Core)
    [root@mysqlhq soft]# rpm -ivh mysql-router-2.1.6-1.el6.x86_64.rpm 
    warning: mysql-router-2.1.6-1.el6.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
    Preparing...                          ################################# [100%]
    Updating / installing...
       1:mysql-router-2.1.6-1.el6         ################################# [100%]
    [root@mysqlhq soft]# whereis mysqlrouter
    mysqlrouter: /usr/bin/mysqlrouter /usr/lib64/mysqlrouter /etc/mysqlrouter
    [root@mysqlhq soft]# ll /usr/bin/mysqlrouter 
    -rwxr-xr-x 1 root root 23592 Feb 21  2018 /usr/bin/mysqlrouter
    [root@mysqlhq soft]# which mysqlrouter
    /usr/bin/mysqlrouter
    [root@mysqlhq soft]# rpm -qa|grep mysql-router
    mysql-router-2.1.6-1.el6.x86_64
    [root@mysqlhq soft]# ll /etc/mysqlrouter/
    total 4
    -rw-r--r-- 1 root root 1231 Feb 21  2018 mysqlrouter.conf
    [root@mysqlhq soft]# ll /etc/init.d/mysqlrouter
    -rwxr-xr-x 1 root root 2879 Feb 21  2018 /etc/init.d/mysqlrouter
    [root@mysqlhq ~]# ll /usr/lib64/mysqlrouter
    total 2592
    -rwxr-xr-x 1 root root    9424 Feb 21  2018 keepalive.so
    -rwxr-xr-x 1 root root   24136 Feb 21  2018 logger.so
    -rwxr-xr-x 1 root root  124416 Feb 21  2018 metadata_cache.so
    -rwxr-xr-x 1 root root   30096 Feb 21  2018 mysql_protocol.so
    -rwxr-xr-x 1 root root  210504 Feb 21  2018 routing.so
    -rwxr-xr-x 1 root root 2241288 Feb 21  2018 x_protocol.so
    
    #m-s架构
    #m 192.168.19.145
    #s 192.168.19.227
    [root
    @mysqlhq mysqlrouter]# vim mysqlrouter.conf [DEFAULT] logging_folder = /var/log/mysqlrouter/ plugin_folder = /usr/lib64/mysqlrouter runtime_folder = /var/run/mysqlrouter config_folder = /etc/mysqlrouter [logger] level = info [routing:read_write] bind_address = 192.168.19.145 bind_port = 7001 mode = read-write destinations = 192.168.19.145:3306,192.168.19.227:3306 max_connections = 1024 max_connect_errors = 100 client_connect_timeout = 6 connect_timeout=3 # If no plugin is configured which starts a service, keepalive # will make sure MySQL Router will not immediately exit. It is # safe to remove once Router is configured. [routing:read_only] bind_address = 192.168.19.145 bind_port = 7002 mode = read-only destinations = 192.168.19.145:3306,192.168.19.227:3306 max_connections = 1024 max_connect_errors = 100 client_connect_timeout = 6 connect_timeout=3 [keepalive] interval = 60 [root@mysqlhq mysqlrouter]# mysqlrouter -v MySQL Router v2.1.6 on Linux (64-bit) (GPL community edition) [root@mysqlhq mysqlrouter]# groupadd mysqlrouter groupadd: group 'mysqlrouter' already exists [root@mysqlhq mysqlrouter]# useradd -g mysqlrouter mysqlrouter useradd: user 'mysqlrouter' already exists [root@mysqlhq mysqlrouter]# id mysqlrouter uid=989(mysqlrouter) gid=984(mysqlrouter) groups=984(mysqlrouter) [root@mysqlhq mysqlrouter]# chown -R mysqlrouter:mysqlrouter /etc/mysqlrouter [root@mysqlhq mysqlrouter]# /usr/bin/mysqlrouter -c /etc/mysqlrouter/mysqlrouter.conf & [1] 3577 [root@mysqlhq mysqlrouter]# ps -ef|grep mysqlrouter root 3577 831 0 16:57 pts/0 00:00:00 /usr/bin/mysqlrouter -c /etc/mysqlrouter/mysqlrouter.conf root 3588 831 0 16:57 pts/0 00:00:00 grep --color=auto mysqlrouter [root@mysqlhq mysqlrouter]# netstat -lnt|grep 7001 tcp 0 0 192.168.19.145:7001 0.0.0.0:* LISTEN [root@mysqlhq ~]# cd /var/log/mysqlrouter/ [root@mysqlhq mysqlrouter]# vim mysqlrouter.log 2019-01-14 16:57:10 WARNING [7f266a1d1700] [routing:read_only] setup_tcp_service() error from bind(): Cannot assign requested address 2019-01-14 16:57:10 ERROR [7f266a1d1700] routing:read_only: Setting up TCP service using 192.168.20.118:7002: [routing:read_only] Failed to setup service socket: Cannot assign requested address 2019-01-14 16:57:10 INFO [7f26699d0700] [routing:read_write] started: listening on 192.168.19.145:7001; read-write 2019-01-14 16:57:10 INFO [7f266a9d2700] keepalive started with interval 60 2019-01-14 16:57:10 INFO [7f266a9d2700] keepalive 2019-01-14 16:58:10 INFO [7f266a9d2700] keepalive

    2 启动,测试mysql router

    [mysql@mysqlhq ~]$ mysql  -h 192.168.19.145  -u system -p*** -P 7001
    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 312548
    Server version: 5.6.15-log MySQL Community Server - (GPL)
    
    Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved.
    
    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.
    
    (system@192.168.19.145:7001) [(none)]> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | information_schema |
    | mysql              |
    | performance_schema |
    | test               |
    | zabbix             |
    +--------------------+
    (system@192.168.19.145:7001) [(none)]> show variables like '%read_only%';
    +------------------+-------+
    | Variable_name    | Value |
    +------------------+-------+
    | innodb_read_only | OFF   |
    | read_only        | OFF   |
    | tx_read_only     | OFF   |
    +------------------+-------+
    
    [mysql@mysqlhq ~]$ mysql  -h 192.168.19.145  -u system -p*** -P 7001 -e "select @@hostname;"
    Warning: Using a password on the command line interface can be insecure.
    +------------+
    | @@hostname |
    +------------+
    | mysqlhq    |
    +------------+
    
    [root@mysqlhq mysqlrouter]# netstat -lnt|grep 7002  #7002端口没有启动起来,log中没有报错信息
    检查配置文件,发现ip写错了
    [routing:read_only]
    bind_address = 192.168.20.118 #此处修改为192.168.19.145
    重新启动mysqlrouter
    [root@mysqlhq mysqlrouter]# /usr/bin/mysqlrouter --help
    [root@mysqlhq mysqlrouter]# ps -ef|grep mysqlrouter
    root      3577   831  0 16:57 pts/0    00:00:00 /usr/bin/mysqlrouter -c /etc/mysqlrouter/mysqlrouter.conf
    root      4266  4138  0 17:04 pts/2    00:00:00 tail -f mysqlrouter.log
    root      5544   831  0 17:18 pts/0    00:00:00 grep --color=auto mysqlrouter
    [root@mysqlhq mysqlrouter]# kill 3577
    [root@mysqlhq mysqlrouter]#  /usr/bin/mysqlrouter -c /etc/mysqlrouter/mysqlrouter.conf &
    [root@mysqlhq mysqlrouter]# netstat -lnt|grep 7001
    tcp        0      0 192.168.19.145:7001     0.0.0.0:*               LISTEN     
    [root@mysqlhq mysqlrouter]# netstat -lnt|grep 7002
    tcp        0      0 192.168.19.145:7002     0.0.0.0:*               LISTEN  
    日志信息
    2019-01-14 17:18:13 INFO    [7faef06c7700] keepalive started with interval 60
    2019-01-14 17:18:13 INFO    [7faef06c7700] keepalive
    2019-01-14 17:18:13 INFO    [7faeefec6700] [routing:read_only] started: listening on 192.168.19.145:7002; read-only
    2019-01-14 17:18:13 INFO    [7faeef6c5700] [routing:read_write] started: listening on 192.168.19.145:7001; read-write
    在2个port上进行查询
    [mysql@mysqlhq scripts]$ mysql  -h 192.168.19.145  -u system -p*** -P 7001 -e "select @@hostname;"
    Warning: Using a password on the command line interface can be insecure.
    +------------+
    | @@hostname |
    +------------+
    | mysqlhq    |
    +------------+
    [mysql@mysqlhq scripts]$ mysql  -h 192.168.19.145  -u system -p*** -P 7002 -e "select @@hostname;"
    Warning: Using a password on the command line interface can be insecure.
    +------------+
    | @@hostname |
    +------------+
    | mysqlhq    |
    +------------+

    (system@192.168.19.145:7001) [(none)]> select @@port;
    +--------+
    | @@port |
    +--------+
    | 3306 |
    +--------+

     

    3 性能--

    Deploying MySQL Router
    Performance Recommendations
    For best performance, MySQL Router is typically installed on the same host as the application that uses it. Possible reasons include:
    为了获得更好的性能,建议把mysql router安装在application的主机上
      To allow local UNIX domain socket connections to the application, instead of TCP/IP. 允许本地UNIX域套接字连接到应用程序,替代TCP/IP
      To decrease network latency. 减少网络的潜在因素
      To allow MySQL Router to connect to MySQL without requiring extra accounts for the Router's host, for MySQL accounts that are created specifically
      for application hosts, such as myapp@198.51.100.45 instead of a value like myapp@%. 账号安全
      Typically application servers are easiest to scale. 通常,应用服务器是最容易伸缩的
      You can run several instances of MySQL Router on your network, and do not need to isolate the router to a single machine or even a single
      Router instance. This is because MySQL Router has no affinity for any particular server or host.

    https://dev.mysql.com/doc/mysql-router/2.1/en/mysql-router-preface.html

  • 相关阅读:
    函数
    文件处理及处理模式
    字符编码
    元组,字典和集合的用法
    数字类型、字符串和列表
    计算机硬件介绍
    数据类型及语法介绍
    初识python
    设计模式
    最近的时候
  • 原文地址:https://www.cnblogs.com/yhq1314/p/10270524.html
Copyright © 2011-2022 走看看