Skip to main content
Version: release-0.8

ApeCloud MySQL Proxy

Before you start

  1. Install kbcli.

  2. Install KubeBlocks.

    You can run kbcli playground init to install a k3d cluster and KubeBlocks. For details, refer to Try KubeBlocks on your laptop or Try KubeBlocks on cloud.

    kbcli playground init

    # Use --version to specify a version
    kbcli playground init --version='x.x.x'

    Or if you already have a Kubernetes cluster, you can choose install KubeBlocks by Helm or kbcli.

  3. Prepare an ApeCloud MySQL RaftGroup named mycluster for demonstrating how to enable the proxy function for an existing cluster. Refer to Create a MySQL cluster for details.

Create a Proxy Cluster

It is recommended to use kbcli to create an ApeCloud MySQL Proxy Cluster.

kbcli cluster create mysql myproxy --mode raftGroup --availability-policy none --proxy-enabled true

Enable Proxy dynamically

As its name suggests, ApeCloud MySQL Proxy in nature is a database proxy. An ApeCloud MySQL RaftGroup Cluster can be switched to an ApeCloud MySQL Proxy Cluster by setting proxyEnabled=true.

Coming soon...

Connect Proxy Cluster

ApeCloud MySQL Proxy is routed through the vtgate component, and the way the MySQL Server accesses vtgate is similar to the way of accessing mysqld. The external SQL access address provided by ApeCloud MySQL Proxy is the vtgate address and port. The vtgate address created by KubeBlocks by default is myproxy-cluster-vtgate-headless, and the port number is 15306. You can visit ApeCloud MySQL Proxy through the MySQL Server in any pod under the same namespace as ApeCloud MySQL Proxy.

Connect Proxy Cluster by VTGate

Run the command below to connect to the Proxy Cluster.

kbcli cluster connect myproxy --component vtgate

Connect Proxy Cluster by MySQL Server

Run the command below to connect to the MySQL Server.

kbcli cluster connect myproxy
note

If you need to test the failover of MySQL, you need to delete the Pod first and continue to port-forward the port, and you can also write a shell script. Here are examples.

For VTGate,

while true; do date; kubectl port-forward svc/vt-vtgate-headless 15306:15306; sleep 0.5; done

For the MySQL Server,

while true; do date; kubectl port-forward svc/vt-mysql 3306:3306; sleep 0.5; done

Configure Proxy Cluster parameters

VTGate, VTConsensus, and VTTablet support parameter configuration. You can configure VTGate and VTConsensus by using --component to specify a component and configure VTTablet by using --component=mysql --config-specs=vttablet-config to specify both a component and a configuration file template since VTTablet is the sidecar of the MySQL component.

View parameter details

  • View the details of the current configuration file.

    # vtgate
    kbcli cluster describe-config myproxy --component vtgate --show-detai

    # vtcontroller
    kbcli cluster describe-config myproxy --component vtcontroller --show-detail

    # vttablet
    kbcli cluster describe-config myproxy --component mysql --show-detail --config-specs vttablet-config
  • View the parameter descriptions.

    # vtgate
    kbcli cluster explain-config myproxy --component vtgate

    # vttablet
    kbcli cluster explain-config myproxy --component mysql --config-specs=vttablet-config
  • View the definition of a specified parameter.

    kbcli cluster explain-config myproxy --component vtgate --param=healthcheck_timeout

Reconfigure parameters

  1. View the current values in the MySQL Server.

    kbcli cluster connect myproxy --component=vtgate
    mysql> show variables like '%healthcheck_timeout%';
    mysql> show variables like '%health_check_interval%';
  2. Configure the healthcheck_timeout for VTGate and the health_check_interval for VTTablet.

    You can use --set flag or edit the parameter configuration file to edit values.

    • By using --set flag

      # vtgate
      kbcli cluster configure myproxy --component vtgate --set=healthcheck_timeout=2s

      # vttablet
      kbcli cluster configure myproxy --set=health_check_interval=4s --component=mysql --config-spec=vttablet-config
    • By editing the parameter configuration file

      kbcli cluster edit-config myproxy --component vtgate
      note

      After the vtgate parameter values configuration command is executed, a new vtgate Pod is started and the old vtgate Pod is terminated. You can run the command below to monitor whether the old Pod is terminated.

      kubectl get pod <vtgate-pod-name> -w
  3. Use the output command to view the configuration status. For example,

    kbcli cluster describe-ops myproxy -reconfiguring-lth8d -n default
    note

    For more information about parameter configuration, refer to Configuration.

Log

You can view the log files of components, Pods, and containers by both kbcli and kubectl.

View the log of different components.

kbcli cluster list-logs myproxy
kbcli cluster list-logs myproxy --component vtgate
kbcli cluster list-logs myproxy --component vtcontroller
kbcli cluster list-logs myproxy --component mysql

View the log of a Pod.

kbcli cluster logs myproxy --instance myproxy-vtgate-85bdcf99df-wbmnl

View the log of a container in a Pod.

kbcli cluster logs myproxy --instance myproxy-mysql-0 -c vttablet

Monitoring

note

In the production environment, all monitoring add-ons are disabled by default when installing KubeBlocks. You can enable these add-ons but it is highly recommended to build your monitoring system or purchase a third-party monitoring service. For details, refer to Monitoring.

  1. Enable the monitoring function.

    kbcli cluster update myproxy --monitor=true
  2. View the add-on list and enable the Grafana add-on.

    kbcli addon list 

    kbcli addon enable grafana
  3. View the dashboard list.

    kbcli dashboard list
  4. Open the Grafana dashboard.

    kbcli dashboard open kubeblocks-grafana

Read-write splitting

You can enable the read-write splitting function.

kbcli cluster configure myproxy --component vtgate --set=read_write_splitting_policy=random

You can also set the ratio for read-write splitting and here is an example of directing 70% flow to the read-only node.

kbcli cluster configure myproxy --component vtgate --set=read_write_splitting_ratio=70

Moreover, you can use Grafana or run show workload to view the flow distribution.

show workload;

Transparent failover

Run the command below to implement transparent failover.

kbcli cluster configure myproxy --component vtgate --set=enable_buffer=true