Skip to content

Latest commit

 

History

History
662 lines (401 loc) · 47.7 KB

09_BigDataClusters.md

File metadata and controls

662 lines (401 loc) · 47.7 KB

Workshop: SQL Server 2019 Workshop

A Microsoft workshop from the SQL Server team

Big Data Clusters

SQL Server Big Data Clusters provide a solution for Intelligence over all of your Data through Data Virtualization with Polybase, built-in HDFS and Spark, and a end-to-end Machine Learning Platform.

BDC Intelligence

Big Data Clusters are deployed using Kubernetes nodes, pods, and services. Big Data Clusters provides these services to provide solutions for intelligence over all of your data including:

Balzano is a company using SQL Server 2019 Big Data Clusters to transform and effectively use machine learning.

SQL 2019 BDC

You can read more SQL Server Big Data Clusters at https://docs.microsoft.com/en-us/sql/big-data-cluster/big-data-cluster-overview.

This module provides a fundamental look and usage of SQL Server 2019 Big Data Clusters as part of the overall SQL Server 2019 product. Use the following workshop for a detailed look at SQL Server 2019 Big Data Clusters at https://github.com/Microsoft/sqlworkshops/tree/master/sqlserver2019bigdataclusters.

You will cover the following topics in this Module:

9.0 Deploying Big Data Clusters and Getting Started
9.1 Data Virtualization and Big Data Clusters
9.2 Spark and Machine Learning
9.3 Advanced: Exploring and Monitoring Big Data Clusters

SQL Server provides simple methods to deploy an entire Big Data Cluster on the Kubernetes deployment of your choice.

Deploying a set of software components on Kubernetes that includes SQL Server, HDFS, Spark, and a suite of services for control, management, and monitoring can be a complex task.

SQL Server 2019 Big Data Clusters come with tools such as the azdata command line interface (CLI) to help simplify the deployment of a Big Data Cluster on Kubernetes.

Watch this video as Mihaela Blendea, Senior Program Manager at Microsoft, talks more about Big Data Cluster deployment

Introducing SQL Server 2019

Azure Kubernetes Service (AKS) provides a managed platform to deploy a Kubernetes cluster. Kubernetes can also be deployed on the platform of your choice using tools like kubeadm.

SQL Server 2019 Big Data Clusters provide guidance for deployment on AKS or your Kubernetes cluster at https://docs.microsoft.com/en-us/sql/big-data-cluster/deployment-guidance

STEP 1: Deploy a Big Data Cluster

Follow the instructions at https://docs.microsoft.com/en-us/sql/big-data-cluster/deploy-on-aks to deploy SQL Server 2019 Big Data Clusters on AKS.

NOTE: If you would like to deploy a Big Data Cluster that includes built-in HA for the SQL Server Master Instance with Always-On Availability Groups, consult the documentation at https://docs.microsoft.com/en-us/sql/big-data-cluster/deployment-high-availability.

When using azdata for deployment, your results should look something like this from the command line (you will have responded to prompts for passwords)

The privacy statement can be viewed at:
https://go.microsoft.com/fwlink/?LinkId=853010

The license terms for SQL Server Big Data Cluster can be viewed at:
Enterprise: https://go.microsoft.com/fwlink/?linkid=2104292
Standard: https://go.microsoft.com/fwlink/?linkid=2104294
Developer: https://go.microsoft.com/fwlink/?linkid=2104079


Cluster deployment documentation can be viewed at:
https://aka.ms/bdc-deploy

Please provide a value for AZDATA_USERNAME:thewandog
Please provide a value for AZDATA_PASSWORD:

NOTE: Cluster creation can take a significant amount of time depending on
configuration, network speed, and the number of nodes in the cluster.

Starting cluster deployment.
Waiting for cluster controller to start.
Waiting for cluster controller to start.
Waiting for cluster controller to start.
Waiting for cluster controller to start.
Waiting for cluster controller to start.
Waiting for cluster controller to start.
Cluster controller endpoint is available at 13.65.88.162:30080.
Cluster control plane is ready.
Data pool is ready.
Storage pool is ready.
Compute pool is ready.
Master pool is ready.
Cluster deployed successfully.

The statement "Cluster deployed successfully" show mean the BDC cluster is ready to use. An additional step to verify cluster health can be done with azdata.

STEP 2: Verify cluster deployment

Login to the the cluster using the following command:

azdata login

You will be prompted for the controller login and password (which you supplied when creating the cluster) and the name of the cluster (which the default is mssql-cluster). If the login succeeds, you will be returned the value of the controller endpoint (which you can retrieve later in other ways)

Namespace: mssql-cluster
Username: thewandog
Password:
Logged in successfully to `https://[ip address]:30080` in namespace `mssql-cluster`. Setting active context to `mssql-cluster`.

You can now do a quick check of BDC health using the following command:

azdata bdc status show

The results should look like the following showing a State of Healthy on all Services (Services is a term for BDC components not a Kubernetes Service even though BDC does deploy several Kubernetes Services such as Load Balancers):

 Mssql-cluster: ready                                                                    Health Status:  healthy
 ===============================================================================================================
 Services: ready                                                                         Health Status:  healthy
 ---------------------------------------------------------------------------------------------------------------
 Servicename    State    Healthstatus    Details

 sql            ready    healthy         -
 hdfs           ready    healthy         -
 spark          ready    healthy         -
 control        ready    healthy         -
 gateway        ready    healthy         -
 app            ready    healthy         -


 Sql Services: ready                                                                     Health Status:  healthy
 ---------------------------------------------------------------------------------------------------------------
 Resourcename    State    Healthstatus    Details

 master          ready    healthy         StatefulSet master is healthy
 compute-0       ready    healthy         StatefulSet compute-0 is healthy
 data-0          ready    healthy         StatefulSet data-0 is healthy
 storage-0       ready    healthy         StatefulSet storage-0 is healthy

  Hdfs Services: ready                                                                    Health Status:  healthy
 ---------------------------------------------------------------------------------------------------------------
 Resourcename    State    Healthstatus    Details

 nmnode-0        ready    healthy         StatefulSet nmnode-0 is healthy
 storage-0       ready    healthy         StatefulSet storage-0 is healthy
 sparkhead       ready    healthy         StatefulSet sparkhead is healthy

 Spark Services: ready                                                                   Health Status:  healthy
 ---------------------------------------------------------------------------------------------------------------
 Resourcename    State    Healthstatus    Details

 sparkhead       ready    healthy         StatefulSet sparkhead is healthy
 storage-0       ready    healthy         StatefulSet storage-0 is healthy

 Control Services: ready                                                                 Health Status:  healthy
 ---------------------------------------------------------------------------------------------------------------
 Resourcename    State    Healthstatus    Details

 controldb       ready    healthy         -
 control         ready    healthy         -
 metricsdc       ready    healthy         DaemonSet metricsdc is healthy
 metricsui       ready    healthy         ReplicaSet metricsui is healthy
 metricsdb       ready    healthy         StatefulSet metricsdb is healthy
 logsui          ready    healthy         ReplicaSet logsui is healthy
 logsdb          ready    healthy         StatefulSet logsdb is healthy
 mgmtproxy       ready    healthy         ReplicaSet mgmtproxy is healthy


 Gateway Services: ready                                                                 Health Status:  healthy
 ---------------------------------------------------------------------------------------------------------------
 Resourcename    State    Healthstatus    Details

 gateway         ready    healthy         StatefulSet gateway is healthy


 App Services: ready                                                                     Health Status:  healthy
 ---------------------------------------------------------------------------------------------------------------
 Resourcename    State    Healthstatus    Details

 appproxy        ready    healthy         ReplicaSet appproxy is healthy

STEP 3: Find the endpoints to use the cluster

Once you have deployed a Big Data Cluster, you will want to start using it. A Big Data cluster comes with several endpoints to connect, run T-SQL queries, submit Spark jobs, and interface with various solutions with in the cluster:

Run the following command to get a list of defined endpoints to connect with the cluster:

azdata bdc endpoint list -o table

Your results should look like the following:

Description                                             Endpoint                                                  Name                        Protocol
------------------------------------------------------  --------------------------------------------------------  --------------------------  ----------
Gateway to access HDFS files, Spark                     https://[ip address]:30443                               gateway                     https
Spark Jobs Management and Monitoring Dashboard          https://[ip address]:30443/gateway/default/sparkhistory  spark-history               https
Spark Diagnostics and Monitoring Dashboard              https://[ip address]:30443/gateway/default/yarn          yarn-ui                     https
Application Proxy                                       https://[ip address]:30778                               app-proxy                   https
Management Proxy                                        https://[ip address]:30777                                mgmtproxy                   https
Log Search Dashboard                                    https://[ip address]:30777/kibana                         logsui                      https
Metrics Dashboard                                       https://[ip address]:30777/grafana                        metricsui                   https
Cluster Management Service                              https://[ip address]:30080                                controller                  https
SQL Server Master Instance Front-End                    [ip address],31433                                        sql-server-master           tds
SQL Server Master Readable Secondary Replicas           [ip address],31436                                        sql-server-master-readonly  tds
HDFS File System Proxy                                  https://[ip address]:30443/gateway/default/webhdfs/v1    webhdfs                     https
Proxy for running Spark statements, jobs, applications  https://[ip address]:30443/gateway/default/livy/v1       livy                        https

NOTE: This list includes a readable secondary replica for SQL Server and will only be viewable in your list if you have deployed a Big Data Cluster with High Availability.

The controller provides the key interface to expose all the endpoints in a Big Data Cluster. You may not use all of these endpoints and some of the names may give you a clue on who and when to use them. Here is a quick guide for the basics of when you would use some of these endpoints to use a Big Data Cluster. Some of these endpoints are related to managing and monitoring the Big Data Cluster which you can learn more about in Module 9.3 Advanced: Exploring and Monitoring Big Data Clusters:

  • SQL Server Master Instance Front-End (sql-server-master)

Use this IP address and port to connect to the SQL Server Master Instance, which is a TDS interface, with common SQL tools like Azure Data Studio or SQL Server Management Studio (SSMS). The SQL Server Master Instance can use a well-known endpoint for the controller in the cluster to access other resources in the cluster. This means you can connect to SQL Server with a TDS connection and access cluster resources with redirection from the controller.

  • Cluster Management Service (controller)

This is the connection to the controller which is a REST interface. In most cases you don't need to directly connect to the controller. For example the azdata tool can directly connect to the controller using the azdata login command (azdata can use the same well-known endpoint as the SQL Server Master Instance). Tools like Azure Data Studio may prompt you for this information to show a dashboard for cluster health. Note that even though this endpoint is an https address it accepts RESTful API requests so is not appropriate to connect with a browser. You will use the CONTROLLER_USERNAME and CONTROLLER_PASSWORD you provided when you deployed a Big Data cluster to access this endpoint.

  • Gateway to access HDFS files, Spark (gateway)

This endpoint is also known as a Knox gateway, using a REST interface, and is used to access the HDFS cluster deployed in a Big Data Cluster. It can also be used to directly execute Spark jobs.

Typically you will use proxy connections to use the Knox gateway which are also listed as endpoints in the list.

HDFS File System Proxy (webhdfs)

This proxy endpoint can be used to access the HDFS file system in the cluster directly through WebHDFS. For examples no how to ingest data into HDFS using this proxy see the documentation at https://docs.microsoft.com/en-us/sql/big-data-cluster/data-ingestion-curl?view=sql-server-ver15. Azure Data Studio has a method to display the HDFS file system in an Explorer view.

Proxy for running Spark statements, jobs, applications (livy)

This proxy is also known as a Livy endpoint. Although Spark jobs can be directly run through the Livy endpoint, the SQL Server Master Instance has the intelligence to allow a connection and redirect Spark Jobs within the cluster. The documentation includes an example of how to connect to the SQL Server Master Instance with Azure Data Studio and submit a Spark Job. Read more at https://docs.microsoft.com/en-us/sql/big-data-cluster/tutorial-data-pool-ingest-spark?view=sql-server-ver15.

  • Application Proxy (app-prox)

This endpoint, using a REST interface, is used to access applications deployed in the Application Pool. You can read more about using this endpoint at https://docs.microsoft.com/en-us/sql/big-data-cluster/big-data-cluster-consume-apps?view=sql-server-ver15.

You will learn in the next Module how to connect to the SQL Server Master Instance and submit queries for data virtualization.

TIP:The azdata tool allows you to execute T-SQL queries against the SQL Server Master instance through a SQL shell (using the mssqlcli tool) or direct queries. Read more at https://docs.microsoft.com/en-us/sql/big-data-cluster/reference-azdata-sql?view=sql-server-ver15.

When you are done proceed to the Activity Summary section for the Activity below.

SQL Server 2019 Big Data Clusters can be deployed on managed Kubernetes platforms like Azure Kubernetes Service with a single Command Line Interface (CLI) like azdata.

Big Data Clusters provides a series of endpoints to connect and run queries and interface with various services in the cluster.

Once you have deployed a SQL Server 2019 Big Data Cluster, one of the first usage scenarios is to access data stored within the cluster both in the Storage Pool with HDFS and the Data Pool through a cached or offline result set.

Some data is naturally stored as unstructured or semi-structured in the form of files. HDFS provides a standard mechanism to stored a distributed set of large files with this type of data. Deploying and managing a Hadoop cluster with HDFS can be an expensive and complex problem.

Accessing data of all types through ad-hoc queries or applications to relational, noSQL, or HDFS stores can provide near real-time results but may not yield maximum performance. Some users and applications only need data refreshed at fixed time intervals.

SQL Server 2019 Big Data Clusters solve challenges of HDFS deployment and maximum performance data access through a Storage and Data Pool.

A Storage Pool is a pre-deployed HDFS cluster using Kubernetes pods that can be accessed through standard HDFS interfaces (WebHDFS) or through the SQL Server Master Instance with Polybase using a special built-in connector. A Storage Pool uses the SQL Server engine for optimized access to HDFS files. You can read more about storage pools at https://docs.microsoft.com/en-us/sql/big-data-cluster/concept-storage-pool.

To learn more about querying data from the Storage Pool, watch this video by Microsoft Principal Program Manager Umachandar Jayachandran:

Introducing SQL Server 2019

A Data Pool is a pre-deployed set of pods using SQL Server instances to store shards of data optimized with columnstore indexes. Data Pools are accessed with Polybase from the SQL Server Master Instance through a special built-in connector. You can use T-SQL statements like INSERT, SELECT, TRUNCATE, and EXECUTE AS with data pools. You can read more about data pools at https://docs.microsoft.com/en-us/sql/big-data-cluster/concept-data-pool.

To learn more about querying data from the Data Pool watch this video by Microsoft Principal Program Manager Umachandar Jayachandran:

Introducing SQL Server 2019

In this activity, ingest data into the Storage Pool in HDFS and access this data through the SQL Server Master Instance through Polybase.

Then, ingest query results from SQL Server tables joined with HDFS into the Data Pool.

All scripts for this activity can be found in the sql2019workshop\09_BigDataClusters\storage_and_data_pool folder.

NOTE: Other external data sources such as Oracle, MongoDB, SQL Server (including Azure), and Teradata can be used in a big data cluster using the same techniques you learned in Module 08 Data Virtualization

STEP 1: Ingest data into HDFS in the Storage Pool

Follow the instructions to load sample data into HDFS in a Big Data cluster at https://docs.microsoft.com/en-us/sql/big-data-cluster/tutorial-load-sample-data.

STEP 2: Query data in HDFS through Polybase in a Big Data Cluster

Use the T-SQL notebook datavirtualization_storagepool.ipynb to query HDFS data in the storage pool using the sqlhdfs connector based on files loaded in STEP 1.

STEP 3: Ingest and access data in a Data Pool in a Big Data Cluster

Use the T-SQL notebook datavirtualization_datapool.ipynb to ingest data based on queries from STEP 2 and query the cached results using the sqldatapool connector.

When you are done proceed to the Activity Summary section for the Activity below.

In this activity, you learned how to ingest data into HDFS in the Storage Pool of a Big Data Cluster. You also learned how to query HDFS data through Polybase deployed and built-in to Big Data Clusters. You then ingested data and queried cached results in the data pool using Polybase.

Spark is a common distributed computing framework for processing large set of data and is often used witH HDFS.

Developers, data professionals, and data scientists need more than just T-SQL when working with Big Data. They need other interfaces they are familiar with especially to prepare, train, and deploy machine learning models.

Spark is a common, well-known, and proven framework for distributed computing and machine learning. SQL Server Big Data Clusters deploys Spark and provides interfaces to allow Spark jobs to be executed for data within and outside of the Big Data Cluster. Spark is deployed as part of the Storage Pool in Big Data Clusters which you can read about at https://docs.microsoft.com/en-us/sql/big-data-cluster/concept-storage-pool. You can also configure a Big Data Cluster to deploy Spark in its own pool called a Spark Pool which you can read more about at https://docs.microsoft.com/en-us/sql/big-data-cluster/deployment-custom-configuration?view=sql-server-ver15#sparkstorage.

Spark can be used for data ingestion and you can read about how to do this with Big Data Clusters at https://docs.microsoft.com/en-us/sql/big-data-cluster/tutorial-data-pool-ingest-spark.

A Big Data cluster deployment includes SparkML for machine learning and you can learn more about how to use SparkML at https://docs.microsoft.com/en-us/sql/big-data-cluster/spark-create-machine-learning-model.

Here are other examples of how to use Spark with Big Data Clusters:

In this activity you will use a notebook in Azure Data Studio to run Spark jobs to prepare, train, and persist a machine learning model.

The business scenario is a company delivers good that are temperature sensitive in refrigerated trucks. This company has had problems with the cooling systems they believe are caused by battery failures in the trucks.

Today the company has decided to replace these batteries at fixed time frames but wants a more cost-effective way to replace the batteries before they fail but only when needed.

You will use SQL Server Big Data Clusters, Spark,IoT data, and Machine Learning to help build a prediction model for battery lifetime.

NOTE: This activity assumes you have deployed a SQL Server 2019 Big Data Cluster per instructions in Activity 9.1.

All scripts for this activity can be found in the sql2019workshop\09_BigDataClusters\spark_and_ml folder.

Use Azure Data Studio connected to a SQL Server Big Data Cluster you have deployed to run through the steps in a PySpark notebook called truckrefrigpredict.ipynb.

When you are done proceed to the Activity Summary section for the Activity below.

You have learned how to submit a Spark job with Big Data Clusters to prepare, train, and persist a machine learning model for a real-world application problem.

Administrators and data professionals need methods and tools to manage a Big Data Cluster.

Big Data Clusters are built on the foundation of Kubernetes using nodes, pods, services, and other Kubernetes concepts. A Kubernetes cluster on its own can be a complex system to manage. Therefore, managing and monitoring Big Data Cluster components is important and requires built-in software and tools.

For information about how to manage a Kubernetes cluster consider using the book Managing Kubernetes which you can find at https://www.oreilly.com/library/view/managing-kubernetes/9781492033905/. In addition, a good source to learn more about Kubernetes can be found at https://azure.microsoft.com/mediahandler/files/resourcefiles/kubernetes-learning-path/Kubernetes%20Learning%20Path%20version%201.0.pdf. To learn more about using and managing an Azure Kubernetes Service (AKS) cluster look at these well-defined training resources.

Big Data Clusters comes deployed with several services and tools to help you monitor and manage the solution including:

  • A deployed set of containers in the cluster to collect metrics and logs from all the pools and services in the cluster.
  • A built-in controller which is used for deployment and redirecting key requests within the cluster.
  • The azdata command line interface (CLI) to interact, manage, and monitor aspects of the cluster
  • Dashboards to examine cluster health using Azure Data Studio.
  • Troubleshooting Guides implemented through notebooks built by the engineering team accessed through Azure Data Studio
  • Use the kubectl tool to copy data, manage, diagnose, and monitor Kubernetes.

To learn more about Big Data Cluster Administration watch this video from Senior Program Manager Mihaela Blendea:

Introducing SQL Server 2019

In this activity you will learn how to tools to explore various aspects of management and monitoring with SQL Server Big Data Clusters.

NOTE: This activity assumes you have deployed a SQL Server 2019 Big Data Cluster per instructions in Activity 9.1.

STEP 1: Find BDC management endpoints

One of the first actions you need to do in order to use all the tools to manage and monitor a SQL Server Big Data Cluster is to find the various endpoints to connect for specific management and monitoring activities to manage and monitor the cluster.

Similar to the first Activity in this module, use the following command to get a complete list of endpoints:

azdata bdc endpoint list -o table

Your results should look like the following:

Description                                             Endpoint                                                  Name                        Protocol
------------------------------------------------------  --------------------------------------------------------  --------------------------  ----------
Gateway to access HDFS files, Spark                     https://[ip address]:30443                               gateway                     https
Spark Jobs Management and Monitoring Dashboard          https://[ip address]:30443/gateway/default/sparkhistory  spark-history               https
Spark Diagnostics and Monitoring Dashboard              https://[ip address]:30443/gateway/default/yarn          yarn-ui                     https
Application Proxy                                       https://[ip address]:30778                               app-proxy                   https
Management Proxy                                        https://[ip address]:30777                                mgmtproxy                   https
Log Search Dashboard                                    https://[ip address]:30777/kibana                         logsui                      https
Metrics Dashboard                                       https://[ip address]:30777/grafana                        metricsui                   https
Cluster Management Service                              https://[ip address]:30080                                controller                  https
SQL Server Master Instance Front-End                    [ip address],31433                                        sql-server-master           tds
SQL Server Master Readable Secondary Replicas           [ip address],31436                                        sql-server-master-readonly  tds
HDFS File System Proxy                                  https://[ip address]:30443/gateway/default/webhdfs/v1    webhdfs                     https
Proxy for running Spark statements, jobs, applications  https://[ip address]:30443/gateway/default/livy/v1       livy                        https

NOTE: This list includes a readable secondary replica for SQL Server and will only be viewable in your list if you have deployed a Big Data Cluster with High Availability.

In this list of endpoints are key ones used for management and monitoring:

  • Cluster Management Service (controller)

This is the connection to the controller which is REST interface. In most cases you don't need to directly connect to the controller. For example the azdata tool can directly connect to the controller using the azdata login command. Tools like Azure Data Studio may prompt you for this information to show a dashboard for cluster health. Note that even though this endpoint is an https address it accepts RESTful API requests so is not appropriate to connect with a browser. You will use the CONTROLLER_USERNAME and CONTROLLER_PASSWORD you provided when you deployed a Big Data cluster to access this endpoint.

  • Log Search Dashboard (logsui)

This HTTP interface is used to access log files collected in the cluster and displayed using Kibana and searchable powered by Elasticsearch. You will use the CONTROLLER_USERNAME and CONTROLLER_PASSWORD you provided when you deployed a Big Data cluster to access this endpoint.

  • Metrics Dashboard (metricsui)

This HTTP interface is used to show metrics for resource usage for pods, nodes, and SQL Server instances across the cluster using an interface called Grafana. You will use the CONTROLLER_USERNAME and CONTROLLER_PASSWORD you provided when you deployed a Big Data cluster to access this endpoint.

  • Spark Jobs Management and Monitoring Dashboard (spark-history)

This HTTP interface is used to view the history of Spark Jobs. You can access this endpoint directly as it is proxied through the gateway endpoint. To access this endpoint, you will need to use the user root and the KNOX_PASSWORD you provided when you deployed a Big Data Cluster.

  • Spark Diagnostics and Monitoring Dashboard (yarn-ui)

This HTTP interface is used to monitor applications managed by YARN in the Big Data Cluster which will be Spark jobs. You can access this endpoint directly as it is proxied through the gateway endpoint. To access this endpoint, you will need to use the user root and the KNOX_PASSWORD you provided when you deployed a Big Data Cluster.

You can also retrieve a list of endpoints using the SQL Server Master Instance (sql-server-master) endpoint. The SQL Server Master Instance knows a in the cluster to contract the controller endpoint. Using this well-known endpoint SQL Server can use a REST API call to ask the controller for all endpoints in the cluster.

Connect to the SQL Server master instance with a tool like Azure Data Studio or SQL Server Management Studio (SSMS) and run the following T-SQL query:

SELECT * FROM sys.dm_cluster_endpoints

Your results should look the same as when you used the azdata command to list endpoints.

STEP 2: Use azdata for monitoring and managing

azdata is the "kubectl" for SQL Server Big Data Clusters. azdata knows how to connect to the controller endpoint in the cluster and can be used to perform a variety of tasks.

In the first activity you ran the following command to get the status of the cluster:

azdata bdc status show

The bdc subcommand has other interesting option including the abilty to get the status of individual services, create or delete a cluster, configure the cluster, retrieve endpoints, and submit spark jobs.

One interesting aspect of az data bdc is to interact with the HDFS file systems in the cluster

Run the following command to a deployed BDC to get a shell to interact with the HDFS file ssytem

azdata bdc hdfs shell

After supplying the KNOX_PASSWORD or CONTROLLER_PASSWORD you will get a prompt like the following:

HDFS Interactive Shell.  Type help or ? to list commands.

[hdfs]

You can now direclty interact wtih HDFS to perform file and diretory commands. Try out various commands wiht your HDFS file system. Type quit to exit this shell.

Review the azdata reference at Read the entire reference for azdata at https://docs.microsoft.com/en-us/sql/big-data-cluster/reference-azdata and try out other various azdta commands with your cluster

TIP: For SQL Server users take a look at the azdata sql commands.

STEP 3: Use dashboards to examine health

Azure Data Studio comes built-in with a dashboard to examine the health of a cluster. There are two ways to ring up the dashboard:

  • Azure Data Studio can connect directory to the controller
  • You can connect to the SQL Server Master Instance.

Follow the instructions in the documentation at https://docs.microsoft.com/en-us/sql/big-data-cluster/manage-with-controller-dashboard and view the dashboard for your cluster.

You will use this dashboard in the next activities to look at metrics and logs.

The following is an example dashboard for a Big Data Cluster

BDC Dashboard

STEP 4: Look at metrics using Grafana

SQL Server Big Data Clusters deploys containers throughout the cluster to collect metrics about components of the cluster include node, pod, and SQL Server metrics.

Using the dashboard you displayed in the previous step, click on the SQL Server service under Cluster Overview

SQL Server Service

This will bring up a new display of health and links for metrics and logs.

NOTE: This display is for a cluster where HA has been enabled which is why there are three master instances

Click on the link to View SQL Metrics for master-0

master_0_metrics

Your default browser will be activated.

NOTE: At the time of the creation of this workshop there could be problems with the Microsoft Edge browser. It is recommended you use another browser like Chrome or the Microsoft Edge Beta.

You will be prompted for the CONTROLLER_USERNAME and CONTROLLER_PASSWORD. Once this complete your webpage should look like this

grafana_big_data_cluster

As pointed by the arrows at this point you can change context to see other types of metrics such as Node or Pod metrics. Or you can see SQL metrics from other SQL Server instances deployed in the cluster.

You may close or leave open this browser for further exploration.

STEP 5: Explore logs using Kibana

Similar to metrics, containers are deployed in the SQL Server Big Data Cluster to collect logs for various components in the cluster including SQL Server ERRORLOG entries.

Using the same dashboard as you did in the previous step, click on View for master-0 logs

master_0_logs

Another browser window or tab will be dislplayed and you will be prompted for the CONTROLLER_USERNAME and CONTROLLER_PASSWORD.

NOTE: At the time of the creation of this workshop there could be problems with the Microsoft Edge browser. It is recommended you use another browser like Chrome or the Microsoft Edge Beta.

Your browser window should look similar to the following:

kibana_big_data_cluster

In order to see SQL ERRORLOG files, you will need to add a filter.

By default the last 15 minutes of all logs files are displayed. Choose the date picker to pick a different time frame like "This week".

Now add a filter to only get the entries from ERRORLOG files

kibana_filter_for_errorlogs

Now to make the output more readable add the kubernetes_pod_name and message fields to the output

kibana_add_fields

The result should look like SQL ERRORLOG entries. You could remove the filter for the master-0 pod to look at ERRORLOG entries across the cluster.

kibana_sql_errorlog_entries

STEP 6: Troubleshooting Notebooks

The best way to learn to troubleshoot is by learning from others. Explore the troubleshooting notebooks created by the Enginering team at https://docs.microsoft.com/en-us/sql/big-data-cluster/manage-notebooks on your deployed SQL Server Big Data Cluster

STEP 7: Exploring Kubernetes on Big Data Cluster

Since Big Data Clusters is deployed on Kubernetes you can use familar tools to interact with the k8s cluster including the kubectl tool and a Kubernetes dashboard.

Run the following command to see a list of the number of pods and containers deployed in the cluster:

kubectl get pods -o wide

Your results should look something like this:

NOTE: The following results include a HA enabled deployment on a 3 node AKS cluster. Notice how pods are distributed across the AKS cluster naturally

NAME              READY   STATUS    RESTARTS   AGE    IP            NODE                       NOMINATED NODE   READINESS GATES
appproxy-sqcpg    2/2     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
compute-0-0       3/3     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
control-8wvjl     3/3     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
controldb-0       2/2     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
controlwd-z67t6   1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-2              
data-0-0          3/3     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
data-0-1          3/3     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
gateway-0         2/2     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
logsdb-0          1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-2              
logsui-lfdvw      1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
master-0          4/4     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
master-1          4/4     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
master-2          4/4     Running   0          4h1m   [ip address]  aks-nodepool1-29363419-2              
metricsdb-0       1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
metricsdc-755bd   1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-2              
metricsdc-xjdnj   1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
metricsdc-xr8wr   1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
metricsui-gc925   1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
mgmtproxy-7lhlr   2/2     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
nmnode-0-0        2/2     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              
operator-grdlh    1/1     Running   0          6d     [ip address]  aks-nodepool1-29363419-2              
sparkhead-0       4/4     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
storage-0-0       4/4     Running   0          6d     [ip address]  aks-nodepool1-29363419-0              
storage-0-1       4/4     Running   0          6d     [ip address]  aks-nodepool1-29363419-1              

The values under the READY column indicate how many containers are deployed and are runnig. If you sum up these numbers you will see that Big Data Clusters deploys at minimum (again with HA enabled) some 53 containers!.

Explore the other aspects of using kubectl with Big Data Clusters using examples in the documentation at https://docs.microsoft.com/en-us/sql/big-data-cluster/cluster-troubleshooting-commands. See how to display a Kubernetes dashboard by following the steps in the documentation at https://docs.microsoft.com/en-us/sql/big-data-cluster/cluster-troubleshooting-commands?view=sql-server-ver15#kubernetes-dashboard.

kubernetes_dashboard_big_data_cluster

When you are done proceed to the Activity Summary section for the Activity below.

In this activity you learned how to use tools like azdata, Azure Data Studio, Kibana, Grafana, and kubectl to manage and monitor a SQL Server Big Data Cluster.

For Further Study

Next Steps

Next, Continue to Additional Capabilities, Migration, and Next Steps.