Need advice about which tool to choose?Ask the StackShare community!
Azure Synapse vs Presto: What are the differences?
Introduction
Azure Synapse and Presto are both popular tools used in the field of big data analytics. Both tools provide powerful capabilities for processing and querying large datasets. However, there are several key differences between Azure Synapse and Presto that set them apart from each other. In this article, we will highlight the main differences between these two tools.
Integration with Azure Ecosystem: Azure Synapse is a fully managed analytics service provided by Microsoft Azure, which allows seamless integration with other Azure services such as Azure Data Lake Storage, Azure Blob Storage, and Azure SQL Data Warehouse. On the other hand, Presto is an open-source distributed SQL query engine that can be integrated with various data sources including Hadoop, Kafka, and Amazon S3.
Data Processing Architecture: Azure Synapse leverages the concept of a distributed processing engine known as Apache Spark, which allows it to perform distributed processing of large datasets. Presto, on the other hand, utilizes a distributed SQL query engine that is optimized for low latency interactive queries. This difference in architecture impacts the performance characteristics of each tool and the types of workloads they are best suited for.
Scalability and Performance: Azure Synapse provides automatic scaling capabilities that allow it to handle workloads of any size, making it highly scalable. It also provides built-in connectors that enable fast data ingestion and processing. Presto, on the other hand, is designed to scale horizontally by adding more compute nodes to the cluster. It provides high query performance for interactive queries but may require manual tuning for optimal performance.
Security and Governance: Azure Synapse provides robust security features such as encryption at rest and in transit, role-based access control, and transparent data encryption. It also integrates with Azure Active Directory for user authentication and authorization. Presto, while it does support authentication and authorization, may require additional setup and configuration for security features.
Cost: Azure Synapse follows a pay-as-you-go pricing model, where users only pay for the resources they use. It offers a range of pricing tiers to cater to different workload requirements. Presto, being an open-source tool, does not have any licensing costs. However, users need to manage the infrastructure and compute resources themselves, which may incur additional costs.
Supported SQL Dialect: Azure Synapse supports T-SQL (Transact-SQL), which is a dialect of SQL developed by Microsoft. This makes it easier for users already familiar with Microsoft SQL Server to transition to Azure Synapse. Presto, on the other hand, supports ANSI SQL, which is a standard SQL dialect widely used in the industry. This allows greater portability of queries across different systems.
In Summary, Azure Synapse and Presto differ in their integration with the Azure ecosystem, data processing architecture, scalability, performance, security, governance, cost, and supported SQL dialects. The choice between these two tools depends on specific requirements and the existing infrastructure and expertise of the organization.
To provide employees with the critical need of interactive querying, we’ve worked with Presto, an open-source distributed SQL query engine, over the years. Operating Presto at Pinterest’s scale has involved resolving quite a few challenges like, supporting deeply nested and huge thrift schemas, slow/ bad worker detection and remediation, auto-scaling cluster, graceful cluster shutdown and impersonation support for ldap authenticator.
Our infrastructure is built on top of Amazon EC2 and we leverage Amazon S3 for storing our data. This separates compute and storage layers, and allows multiple compute clusters to share the S3 data.
We have hundreds of petabytes of data and tens of thousands of Apache Hive tables. Our Presto clusters are comprised of a fleet of 450 r4.8xl EC2 instances. Presto clusters together have over 100 TBs of memory and 14K vcpu cores. Within Pinterest, we have close to more than 1,000 monthly active users (out of total 1,600+ Pinterest employees) using Presto, who run about 400K queries on these clusters per month.
Each query submitted to Presto cluster is logged to a Kafka topic via Singer. Singer is a logging agent built at Pinterest and we talked about it in a previous post. Each query is logged when it is submitted and when it finishes. When a Presto cluster crashes, we will have query submitted events without corresponding query finished events. These events enable us to capture the effect of cluster crashes over time.
Each Presto cluster at Pinterest has workers on a mix of dedicated AWS EC2 instances and Kubernetes pods. Kubernetes platform provides us with the capability to add and remove workers from a Presto cluster very quickly. The best-case latency on bringing up a new worker on Kubernetes is less than a minute. However, when the Kubernetes cluster itself is out of resources and needs to scale up, it can take up to ten minutes. Some other advantages of deploying on Kubernetes platform is that our Presto deployment becomes agnostic of cloud vendor, instance types, OS, etc.
#BigData #AWS #DataScience #DataEngineering
The platform deals with time series data from sensors aggregated against things( event data that originates at periodic intervals). We use Cassandra as our distributed database to store time series data. Aggregated data insights from Cassandra is delivered as web API for consumption from other applications. Presto as a distributed sql querying engine, can provide a faster execution time provided the queries are tuned for proper distribution across the cluster. Another objective that we had was to combine Cassandra table data with other business data from RDBMS or other big data systems where presto through its connector architecture would have opened up a whole lot of options for us.
Pros of Azure Synapse
- ETL4
- Security3
- Serverless2
- Doesn't support cross database query1
Pros of Presto
- Works directly on files in s3 (no ETL)18
- Open-source13
- Join multiple databases12
- Scalable10
- Gets ready in minutes7
- MPP6
Sign up to add or upvote prosMake informed product decisions
Cons of Azure Synapse
- Dictionary Size Limitation - CCI1
- Concurrency1