Use SSL connection

CelerData clusters support secure connections encrypted by SSL. Unlike the traditional cleartext connections to DBMS, SSL connections provide endpoint verification and data encryption to ensure that the data transmitted between clients and CelerData clusters cannot be read by unauthorized users.

CelerData clusters uses SSL certificates provided by the Certificate Authority Let's Encrypt, and supports authentication of up to the VERIFY_IDENTITY level.

Connections to CelerData clusters via API are encrypted by HTTPS, which secures the data loaded via Stream Load and exported using Spark connector and Flink connector. In addition, loading data via HTTPS avoids extra processing and the security issues of BE connection.

Enable SSL connection for a CelerData cluster

Currently, you can enable SSL connection for a CelerData cluster only when creating it. See Create a CelerData cluster for more information.

(Optional) Prepare CA certificate

If you want to connect to your CelerData cluster using a CA certificate for verification, you can either download CelerData's CA certificate, or prepare your own CA certificate.

Connect to an SSL-enabled cluster

You can connect to an SSL-enabled CelerData cluster using a MySQL client:

mysql -h <cluster_endpoint> -P9030 --ssl-mode=<ssl_mode> \
    [--ssl-ca=<ca_certificate_file>] \
    -u <cluster_username> -p <cluster_password>
ParameterDescription
cluster_endpointThe endpoint of the CelerData cluster you want to connect to. You can view the endpoint of the cluster at the Connection properties section on the Overview tab of the cluster details page. See View CelerData clusters for more information.
ssl_modeThe SSL mode with which you want to connect to the CelerData cluster. CelerData clusters supports the following SSL modes:
  • REQUIRED: SSL connection is required.
  • VERIFY_CA: SSL connection is required. The cluster verifies the CA certificate.
  • VERIFY_IDENTITY: SSL connection is required. The CelerData cluster verifies the CA certificate and the hostname in the certificate.
ca_certificate_fileThe CA certificate file that you want to use for verification. You need to specify the CA certificate file if you have specified the ssl_mode parameter as VERIFY_CA or VERIFY_IDENTITY.
cluster_usernameThe username used to connect to the cluster.
cluster_passwordThe password used to connect to the cluster.

Load data into an SSL-enabled cluster using Stream Load

You can load data into an SSL-enabled cluster using Stream Load with the API encrypted by HTTPS.

curl -i -H "label:<label_name>" -H "column_separator:<column_separator>" \
    -u <cluster_username>:<cluster_password> -T <data_file_name> \
    -X PUT https://<cluster_endpoint>/api/<db_name>/<table_name>/_stream_load
ParameterDescription
label_nameThe label of the load job. This parameter is optional. The CelerData cluster automatically generates a label for the load job if you do not specify it. The cluster does not allow you to use one label to load a data batch multiple times. As such, the cluster prevents the same data from being repeatedly loaded. By default, the cluster retains the labels of load jobs that were successfully completed over the most recent three days.
column_separatorThe characters that are used in the data file to separate fields. If you do not specify this parameter, this parameter defaults to \t, which indicates tab. Make sure that the column separator you specify by using this parameter is the same as the column separator used in the data file.
NOTE
For CSV data, you can use a UTF-8 string, such as a comma (,), tab, or pipe (
cluster_usernameThe username used to connect to the cluster.
cluster_passwordThe password used to connect to the cluster.
data_file_nameThe name of the data file. You can optionally include the extension of the file name.
cluster_endpointThe endpoint of the cluster.
db_nameThe name of the destination database.
table_nameThe name of the destination table.