Filter interviews by
Be the first one to contribute and help others!
I applied via Company Website and was interviewed in Apr 2024. There were 4 interview rounds.
Sql, pyhton, azure databricks, azure data factory
I applied via Referral and was interviewed in Aug 2023. There were 2 interview rounds.
Airflow is a platform to programmatically author, schedule, and monitor workflows.
Airflow is written in Python and uses Directed Acyclic Graphs (DAGs) to define workflows.
It has a web-based UI for visualization and monitoring of workflows.
Airflow consists of a scheduler, a metadata database, a web server, and an executor.
Tasks in Airflow are defined as operators, which determine what actually gets executed.
Example: A D...
RDD stands for Resilient Distributed Dataset in Spark, which is an immutable distributed collection of objects.
RDD is the fundamental data structure in Spark, representing a collection of elements that can be operated on in parallel.
RDDs are fault-tolerant, meaning they can automatically recover from failures.
RDDs support two types of operations: transformations (creating a new RDD from an existing one) and actions (tr
RDD Lineage is the record of transformations applied to an RDD and the dependencies between RDDs.
RDD Lineage tracks the sequence of transformations applied to an RDD from its source data.
It helps in fault tolerance by allowing RDDs to be reconstructed in case of data loss.
RDD Lineage is used in Spark to optimize the execution plan by eliminating unnecessary computations.
Example: If an RDD is created from a text file an...
Broadcast Variables are read-only shared variables that are cached on each machine in a Spark cluster rather than being sent with tasks.
Broadcast Variables are used to efficiently distribute large read-only datasets to all worker nodes in a Spark cluster.
They are useful for tasks that require the same data to be shared across multiple stages of a job.
Broadcast Variables are created using the broadcast() method in Spark...
Broadcasting is a technique used in Apache Spark to optimize data transfer by sending smaller data to all nodes in a cluster.
Broadcasting is used to efficiently distribute read-only data to all nodes in a cluster to avoid unnecessary data shuffling.
It is commonly used when joining large datasets with smaller lookup tables.
Broadcast variables are cached in memory and reused across multiple stages of a Spark job.
The limi...
Accumulators are used for aggregating values across tasks, while Catalyst optimizer is a query optimizer for Apache Spark.
Accumulators are variables that are only added to through an associative and commutative operation and can be used to implement counters or sums.
Catalyst optimizer is a rule-based query optimizer that leverages advanced programming language features to build an extensible query optimizer.
Catalyst op...
To debug a slow block, start by identifying potential bottlenecks, analyzing logs, checking for errors, and profiling the code.
Identify potential bottlenecks in the code or system that could be causing the slow performance.
Analyze logs and error messages to pinpoint any issues or exceptions that may be occurring.
Use profiling tools to analyze the performance of the code and identify areas that need optimization.
Check f...
The number of executors required to load 200 Petabytes of data depends on the size of each executor and the available cache.
Calculate the size of each executor based on available resources and data size
Consider the amount of cache available for data processing
Determine the optimal number of executors based on the above factors
Prepartition is the process of dividing data into smaller partitions before performing any operations on it.
Prepartitioning helps in improving query performance by reducing the amount of data that needs to be processed.
It can also help in distributing data evenly across multiple nodes in a distributed system.
Examples include partitioning a large dataset based on a specific column like date or region before running anal
Case classes in Python are classes that are used to create immutable objects for pattern matching and data modeling.
Case classes are typically used in functional programming to represent data structures.
They are immutable, meaning their values cannot be changed once they are created.
Case classes automatically define equality, hash code, and toString methods based on the class constructor arguments.
They are commonly use...
Lambda Architecture is a data processing architecture designed to handle massive quantities of data by taking advantage of both batch and stream processing methods. Lambda function is a small anonymous function that can take any number of arguments, but can only have one expression.
Lambda Architecture combines batch processing and stream processing to handle large amounts of data efficiently.
Batch layer stores and proc...
I applied via Naukri.com and was interviewed before Feb 2023. There were 2 interview rounds.
I applied via Company Website and was interviewed before Sep 2023. There were 2 interview rounds.
Reasoning,logical, grammatical
Developed a data analysis tool to predict customer churn using machine learning algorithms.
Used Python for data preprocessing and model building
Implemented logistic regression and random forest algorithms
Evaluated model performance using metrics like accuracy, precision, and recall
2 questions on basics of DS and algo. easy and medium level included.
I applied via campus placement at Karunya Institute of Technology, Coimbatore and was interviewed before Apr 2023. There were 2 interview rounds.
Aptitude questions, verbal test and pseudocode.
I was interviewed before May 2023.
Basic aptitude questions and a couple of codes
posted on 28 Mar 2024
I applied via LinkedIn and was interviewed before Mar 2023. There were 3 interview rounds.
That was great and easy
Gave 2 codes
Difficult level is medium
TCS
Accenture
Wipro
Cognizant