Create Universe - Multi-Zone

AttentionThis page documents an earlier version. Go to the latest (v2.1)version.

This section will describe how to create a universe in one geographic region across multiple zones. We will examine the various nodes created by YugaWare, run some workloads against this universe and take a look at the metrics against the running universe.

1. Create the universe

If there are no universes created yet, the Dashboard page will look like the following. Click on “Create Universe” to create the universe.

Dashboard with No Universes

Enter your intent

The Provider, Regions and Instance Type fields were initialized based on the cloud providers configured. As soon as Provider, Regions and Nodes are entered, an intelligent Node Placement Policy kicks in to specify how the nodes should be placed across all the Availability Zones so that maximum availability is guaranteed.

We are going to enter the following values to create a multi-zone universe on GCP cloud provider:

  • Enter a universe name (helloworld1)
  • Enter the region (Oregon)
  • Change instance type (n1-standard-8)

All other options as set to the default values (replication factor = 3, number of nodes = 3). Click on create.

Create Universe on GCP

Here’s how a Universe in Pending state looks like.

Dashboard with Pending Universe

2. Examine the universe

Universe overview

The overview tab has a lot of information at a glance about the universe.

Detail for a Pending Universe

Tasks level tracking for a Universe

The tasks tab shows the state of tasks currently running, as well as the tasks that have run in the past against this universe.

Tasks for a Pending Universe

Nodes underlying a universe

You can browse to the nodes tab for the universe to see a list of nodes - in the screenshot below the cloud provider instances are still being created.

Nodes for a Pending Universe

Cloud Provider instances for the universe

Browse to the cloud provider’s instances page. In this example, since we are using Google Cloud Platform as the cloud provider, browse to Compute Engine -> VM Instances and search for instances that have helloworld1 in their name. You should see something as follows.

Instances for a Pending Universe

3. Connect to a database node

Once the universe is ready, the overview tab should look as follows.

Multi-zone universe ready

Browse to the nodes tab to find the nodes. This lists the ip addresses of the nodes once they are created and configured. Click on the Connect button as shown below.

Multi-zone universe nodes

This should bring up a dialog showing how to connect to the nodes.

Multi-zone universe nodes

Copy the first command (highlighted above) and run it from the YugaWare machine. This will connect us to the first node, yb-dev-helloworld1-n1.

  1. [email protected]:~$ sudo ssh -i /opt/yugabyte/yugaware/data/keys/b933ff7a-be8a-429a-acc1-145882d90dc0/yb-dev-google-compute-key.pem [email protected] -p 54422
  2. Are you sure you want to continue connecting (yes/no)? yes
  3. [[email protected] ~]$

4. Running workloads

YugaWare comes with a pre-packaged set of sample applications. We will run a simple key-value workload against the Cassandra API and the Redis API.

Pre-requisites

  • Install Java
  1. $ sudo yum install java-1.8.0-openjdk.x86_64 -y
  • Switch to the yugabyte user
  1. $ sudo su - yugabyte
  • Export the YCQL_ENDPOINTS env variable

Export an environment variable telling us the IP addresses for nodes in the cluster. Browse to the universe overview tab in YugaWare and click on the YCQL Endpoints link. This should open a new tab with a list of IP addresses.

YCQL end points

Export this into a shell variable on the database node yb-dev-helloworld1-n1 we had connected to. Remember to replace the ip addresses below with those shown by YugaWare.

  1. $ export YCQL_ENDPOINTS="10.138.0.3:9042,10.138.0.4:9042,10.138.0.5:9042"
  • Export the YEDIS_ENDPOINTS env variable

Repeat the same process for the YEDIS endpoints.

YCQL end points

Export an environment variable for the YEDIS endpoints.

  1. $ export YEDIS_ENDPOINTS="10.138.0.3:6379,10.138.0.4:6379,10.138.0.5:6379"

Run the CassandraKeyValue workload

To start the workload, run the following command.

  1. $ java -jar /home/yugabyte/tserver/java/yb-sample-apps.jar \
  2. --workload CassandraKeyValue \
  3. --nodes $YCQL_ENDPOINTS \
  4. --num_threads_write 2 \
  5. --num_threads_read 32 \
  6. --value_size 128 \
  7. --num_unique_keys 10000000 \
  8. --nouuid

The sample app will print some output and settle into reporting some stats in the steady state.

  1. Created table: [CREATE TABLE IF NOT EXISTS CassandraKeyValue (k varchar, v blob, primary key (k));]
  2. ...
  3. Read: 47388.10 ops/sec (0.67 ms/op), 816030 total ops | Write: 1307.80 ops/sec (1.53 ms/op), 22900 total ops
  4. Read: 47419.99 ops/sec (0.67 ms/op), 1053156 total ops | Write: 1303.85 ops/sec (1.53 ms/op), 29420 total ops
  5. Read: 47220.98 ops/sec (0.68 ms/op), 1289285 total ops | Write: 1311.67 ops/sec (1.52 ms/op), 35979 total ops

Browse to the metrics tab of the universe in YugaWare. You should be able to see the metrics show up. The metrics tab displays a variety of metrics, a few are shown in the screenshot below. Note that these numbers (server side metrics) tally with what the load tester reports (client side metrics).

YCQL Load Metrics

It is also possible to view the metrics at a per-node level as shown below.

YCQL Load Metrics Per Node

Let us stop the load tester and run a yedis workload.

Run the RedisKeyValue workload

To start the workload, run the following command.

  1. $ java -jar /home/yugabyte/tserver/java/yb-sample-apps.jar \
  2. --workload RedisKeyValue \
  3. --nodes $YEDIS_ENDPOINTS \
  4. --num_threads_write 2 \
  5. --num_threads_read 32 \
  6. --value_size 128 \
  7. --num_unique_keys 10000000 \
  8. --nouuid

The sample app will print some output and settle into reporting some stats in the steady state.

  1. Read: 50069.15 ops/sec (0.64 ms/op), 657550 total ops | Write: 1470.87 ops/sec (1.36 ms/op), 18849 total ops
  2. Read: 50209.09 ops/sec (0.64 ms/op), 908653 total ops | Write: 1454.87 ops/sec (1.37 ms/op), 26125 total ops
  3. Read: 50016.18 ops/sec (0.64 ms/op), 1158794 total ops | Write: 1463.26 ops/sec (1.37 ms/op), 33443 total ops

Browse to the metrics tab of the universe in YugaWare. You should be able to see the metrics show up. The metrics tab displays a variety of metrics, a few are shown in the screenshot below. Note that these numbers (server side metrics) tally with what the load tester reports (client side metrics).

YEDIS Load Metrics Per Node

Stop the sample app.

5. Examine the data

You can connect to the YCQL service by running the following command.

  1. $ /home/yugabyte/tserver/bin/cqlsh <ip address of the node>

You can view the table schema as well as the data entered as shown below.

  1. cqlsh> DESCRIBE ybdemo_keyspace.cassandrakeyvalue;

CREATE TABLE ybdemo_keyspace.cassandrakeyvalue (k text PRIMARY KEY,v blob) WITH default_time_to_live = 0;

sqlcqlsh> SELECT * FROM ybdemo_keyspace.cassandrakeyvalue LIMIT 5;

k | v——————+————————————————————-key:101323 | 0x4276616c3a3130313332336be1dd6597e2…key:159968 | 0x4276616c3a3135393936381ed99587c08f…key:24879 | 0x4276616c3a3234383739054071b34c3fb6…key:294799 | 0x4276616c3a3239343739398b312748e80e…key:297045 | 0x4276616c3a32393730343525764eedee94…

(5 rows)

  1. You can connect to the YEDIS service by running the following command.

sh$ /home/yugabyte/tserver/bin/redis-cli -h

  1. You can view the data by running the following commands.

10.138.0.4:6379> GET key:0“Bval:0\x1b\x942\xea\xf0Q\xd1O\xdb\xf8…=V”10.138.0.4:6379> GET key:1“Bval:1\t\x1e\xa0=\xb66\x8b\x8eV\x82…,c”10.138.0.4:6379>```