File Block Size
File Block Size
Core Definition
File Block Size (also referred to as row group size or split size) is a critical physical configuration parameter in big data storage systems. It dictates the maximum size of the logical chunks into which a massive dataset is divided before being written to disk or object storage.
In distributed computing frameworks like Apache Hadoop, Apache Spark, and open table formats like Apache Iceberg, data is not processed as one giant monolithic file. A 1 Terabyte table is broken down into hundreds or thousands of smaller “blocks” or “files” (e.g., 128 MB or 256 MB each). The size of these blocks fundamentally dictates how the cluster allocates worker nodes and reads data, making it one of the most important tuning levers for data engineers.
Diagram 1: Conceptual Architecture

Implementation and Operations
The concept originated with the Hadoop Distributed File System (HDFS), where the default block size was typically 64 MB or 128 MB. If you wrote a 1GB file to HDFS, it physically split it into eight 128 MB blocks distributed across eight different servers. When a query ran, the coordinator assigned eight separate CPU tasks to process those blocks in parallel.
In the modern open data lakehouse, the concept applies primarily to the internal structure of columnar files like Apache Parquet. A Parquet file is divided internally into “Row Groups”.
The Small File Problem: If the block size (or physical file size) is configured too small (e.g., 10 KB), a 10 GB table will consist of one million tiny files. When an engine like Trino tries to query this table, the network overhead of opening, reading metadata from, and closing one million separate HTTP connections to Amazon S3 completely overwhelms the system. The query will crawl to a halt.
The Giant File Problem: Conversely, if the block size is too large (e.g., 10 GB), a 10 GB table is just one massive file. Spark cannot easily split this file. Only a single worker node will be assigned to read it, while the other 99 nodes in the cluster sit completely idle. Furthermore, massive block sizes require massive amounts of RAM on the worker node to hold the uncompressed data in memory, frequently causing Out Of Memory (OOM) crashes.
Diagram 2: Operational Flow

Summary and Tradeoffs
Tuning the file block size is an exercise in finding the “Goldilocks zone.” For modern data lakehouses utilizing Parquet on cloud object storage (like S3 or GCS), the industry standard best practice is to aim for a file size/block size between 128 MB and 512 MB. This size is large enough to ensure excellent compression ratios and minimize S3 API call overhead, but small enough to ensure that massive distributed clusters can easily divide the workload among thousands of parallel CPU cores without blowing out the RAM of individual worker nodes. Open table formats like Apache Iceberg provide built-in maintenance procedures (like RewriteDataFiles) specifically to compact small files and enforce these optimal block sizes automatically.
Extended Deep Dive: The Data Engineering Ecosystem
To truly understand this concept, it must be placed within the broader context of the modern data engineering ecosystem. The evolution from traditional, monolithic on-premises data warehouses to decoupled, cloud-native open data lakehouses represents one of the most significant paradigm shifts in software architecture over the last two decades.
The Problem with Legacy Data Warehouses
Historically, organizations relied on proprietary appliances from vendors like Teradata, Oracle, or IBM. These systems were characterized by a tight coupling of compute and storage. The data physically resided on the hard drives of the specific servers that executed the SQL queries. While incredibly fast for structured, relational data, this architecture suffered from fatal scalability flaws. If an organization needed more storage for historical logs, they were forced to purchase expensive, proprietary servers that included compute power they did not actually need. Furthermore, these systems struggled to ingest unstructured data (like raw JSON, images, or massive IoT streams), creating impenetrable data silos.
The Rise and Fall of the Data Lake (Hadoop)
To solve the volume and variety problem, the industry pivoted to the Data Lake, pioneered by Apache Hadoop. Organizations began dumping all raw data—structured, semi-structured, and unstructured—into the Hadoop Distributed File System (HDFS). Because HDFS ran on cheap commodity hardware, storage became essentially free. However, the data lake lacked the basic governance, transactional guarantees, and performance optimization of the data warehouse. Without ACID (Atomicity, Consistency, Isolation, Durability) transactions, concurrent reads and writes frequently corrupted data. Without schema enforcement, the data lake quickly devolved into an unmanageable, unqueryable “data swamp.”
The Open Data Lakehouse Paradigm
The open data lakehouse merges the best of both worlds. It utilizes the infinitely scalable, low-cost storage of the cloud (like Amazon S3 or Google Cloud Storage) but overlays the management and performance features of a traditional data warehouse.
This is achieved through a multi-layered architecture:
- The Storage Layer: Cloud object storage provides the infinite hard drive.
- The File Format Layer: Open columnar formats like Apache Parquet and ORC provide extreme compression and analytical read efficiency.
- The Table Format Layer: Technologies like Apache Iceberg, Delta Lake, and Apache Hudi sit on top of the physical files. They provide the metadata layer that enables ACID transactions, schema evolution, and time travel, bringing warehouse-level reliability to the raw object storage.
- The Compute Layer: Decoupled, highly elastic engines like Trino, Dremio, Apache Spark, and Snowflake sit at the top. They can be scaled up or down independently of the storage, providing massive parallel processing power only when queries are actively running.
Performance Optimization Strategies
In this decoupled architecture, network bandwidth between the compute engine and the object storage is the primary bottleneck. Data engineers employ a variety of advanced strategies to minimize this I/O:
- Partitioning: Organizing data into distinct directories based on a frequently queried column (e.g., separating data by
year/month/day). When an analyst queries a specific date, the engine simply ignores all directories that do not match, massively reducing data reads. - Z-Ordering and Space-Filling Curves: Advanced sorting techniques that cluster multi-dimensional data physically close together on the disk. This dramatically improves the effectiveness of file-skipping statistics (Min/Max filtering) in formats like Iceberg, allowing engines to read highly targeted, microscopic subsets of massive tables.
- Compaction: Over time, streaming ingestions create millions of tiny, inefficient files. Data engineers run scheduled compaction jobs (often utilizing bin-packing algorithms) to merge these tiny files into optimally sized, large columnar blocks (typically 128MB to 512MB), restoring query performance and reducing S3 API overhead.
Security and Governance
As data is democratized across the enterprise, governance becomes paramount. The open lakehouse relies on centralized metadata catalogs (like AWS Glue, Apache Polaris, or Unity Catalog) to manage access. Fine-Grained Access Control (FGAC) allows administrators to mask specific columns (like Social Security Numbers) or restrict specific rows based on the user’s role, ensuring that a single, unified dataset can be securely queried by marketing, finance, and engineering teams simultaneously without violating compliance regulations like GDPR or CCPA.
Conclusion
The architecture described above is not static. The industry is rapidly moving toward real-time streaming ingestion, automated “agentic” data modeling, and universal cross-engine compatibility via projects like Apache XTable. Understanding the foundational layers—how data is serialized, compressed, stored, and transported—is the absolute prerequisite for architecting systems that can handle the exabyte-scale analytics demands of the future.
Extended Deep Dive: The Data Engineering Ecosystem
To truly understand this concept, it must be placed within the broader context of the modern data engineering ecosystem. The evolution from traditional, monolithic on-premises data warehouses to decoupled, cloud-native open data lakehouses represents one of the most significant paradigm shifts in software architecture over the last two decades.
The Problem with Legacy Data Warehouses
Historically, organizations relied on proprietary appliances from vendors like Teradata, Oracle, or IBM. These systems were characterized by a tight coupling of compute and storage. The data physically resided on the hard drives of the specific servers that executed the SQL queries. While incredibly fast for structured, relational data, this architecture suffered from fatal scalability flaws. If an organization needed more storage for historical logs, they were forced to purchase expensive, proprietary servers that included compute power they did not actually need. Furthermore, these systems struggled to ingest unstructured data (like raw JSON, images, or massive IoT streams), creating impenetrable data silos.
The Rise and Fall of the Data Lake (Hadoop)
To solve the volume and variety problem, the industry pivoted to the Data Lake, pioneered by Apache Hadoop. Organizations began dumping all raw data—structured, semi-structured, and unstructured—into the Hadoop Distributed File System (HDFS). Because HDFS ran on cheap commodity hardware, storage became essentially free. However, the data lake lacked the basic governance, transactional guarantees, and performance optimization of the data warehouse. Without ACID (Atomicity, Consistency, Isolation, Durability) transactions, concurrent reads and writes frequently corrupted data. Without schema enforcement, the data lake quickly devolved into an unmanageable, unqueryable “data swamp.”
The Open Data Lakehouse Paradigm
The open data lakehouse merges the best of both worlds. It utilizes the infinitely scalable, low-cost storage of the cloud (like Amazon S3 or Google Cloud Storage) but overlays the management and performance features of a traditional data warehouse.
This is achieved through a multi-layered architecture:
- The Storage Layer: Cloud object storage provides the infinite hard drive.
- The File Format Layer: Open columnar formats like Apache Parquet and ORC provide extreme compression and analytical read efficiency.
- The Table Format Layer: Technologies like Apache Iceberg, Delta Lake, and Apache Hudi sit on top of the physical files. They provide the metadata layer that enables ACID transactions, schema evolution, and time travel, bringing warehouse-level reliability to the raw object storage.
- The Compute Layer: Decoupled, highly elastic engines like Trino, Dremio, Apache Spark, and Snowflake sit at the top. They can be scaled up or down independently of the storage, providing massive parallel processing power only when queries are actively running.
Performance Optimization Strategies
In this decoupled architecture, network bandwidth between the compute engine and the object storage is the primary bottleneck. Data engineers employ a variety of advanced strategies to minimize this I/O:
- Partitioning: Organizing data into distinct directories based on a frequently queried column (e.g., separating data by
year/month/day). When an analyst queries a specific date, the engine simply ignores all directories that do not match, massively reducing data reads. - Z-Ordering and Space-Filling Curves: Advanced sorting techniques that cluster multi-dimensional data physically close together on the disk. This dramatically improves the effectiveness of file-skipping statistics (Min/Max filtering) in formats like Iceberg, allowing engines to read highly targeted, microscopic subsets of massive tables.
- Compaction: Over time, streaming ingestions create millions of tiny, inefficient files. Data engineers run scheduled compaction jobs (often utilizing bin-packing algorithms) to merge these tiny files into optimally sized, large columnar blocks (typically 128MB to 512MB), restoring query performance and reducing S3 API overhead.
Security and Governance
As data is democratized across the enterprise, governance becomes paramount. The open lakehouse relies on centralized metadata catalogs (like AWS Glue, Apache Polaris, or Unity Catalog) to manage access. Fine-Grained Access Control (FGAC) allows administrators to mask specific columns (like Social Security Numbers) or restrict specific rows based on the user’s role, ensuring that a single, unified dataset can be securely queried by marketing, finance, and engineering teams simultaneously without violating compliance regulations like GDPR or CCPA.
Conclusion
The architecture described above is not static. The industry is rapidly moving toward real-time streaming ingestion, automated “agentic” data modeling, and universal cross-engine compatibility via projects like Apache XTable. Understanding the foundational layers—how data is serialized, compressed, stored, and transported—is the absolute prerequisite for architecting systems that can handle the exabyte-scale analytics demands of the future.
Extended Deep Dive: The Data Engineering Ecosystem
To truly understand this concept, it must be placed within the broader context of the modern data engineering ecosystem. The evolution from traditional, monolithic on-premises data warehouses to decoupled, cloud-native open data lakehouses represents one of the most significant paradigm shifts in software architecture over the last two decades.
The Problem with Legacy Data Warehouses
Historically, organizations relied on proprietary appliances from vendors like Teradata, Oracle, or IBM. These systems were characterized by a tight coupling of compute and storage. The data physically resided on the hard drives of the specific servers that executed the SQL queries. While incredibly fast for structured, relational data, this architecture suffered from fatal scalability flaws. If an organization needed more storage for historical logs, they were forced to purchase expensive, proprietary servers that included compute power they did not actually need. Furthermore, these systems struggled to ingest unstructured data (like raw JSON, images, or massive IoT streams), creating impenetrable data silos.
The Rise and Fall of the Data Lake (Hadoop)
To solve the volume and variety problem, the industry pivoted to the Data Lake, pioneered by Apache Hadoop. Organizations began dumping all raw data—structured, semi-structured, and unstructured—into the Hadoop Distributed File System (HDFS). Because HDFS ran on cheap commodity hardware, storage became essentially free. However, the data lake lacked the basic governance, transactional guarantees, and performance optimization of the data warehouse. Without ACID (Atomicity, Consistency, Isolation, Durability) transactions, concurrent reads and writes frequently corrupted data. Without schema enforcement, the data lake quickly devolved into an unmanageable, unqueryable “data swamp.”
The Open Data Lakehouse Paradigm
The open data lakehouse merges the best of both worlds. It utilizes the infinitely scalable, low-cost storage of the cloud (like Amazon S3 or Google Cloud Storage) but overlays the management and performance features of a traditional data warehouse.
This is achieved through a multi-layered architecture:
- The Storage Layer: Cloud object storage provides the infinite hard drive.
- The File Format Layer: Open columnar formats like Apache Parquet and ORC provide extreme compression and analytical read efficiency.
- The Table Format Layer: Technologies like Apache Iceberg, Delta Lake, and Apache Hudi sit on top of the physical files. They provide the metadata layer that enables ACID transactions, schema evolution, and time travel, bringing warehouse-level reliability to the raw object storage.
- The Compute Layer: Decoupled, highly elastic engines like Trino, Dremio, Apache Spark, and Snowflake sit at the top. They can be scaled up or down independently of the storage, providing massive parallel processing power only when queries are actively running.
Performance Optimization Strategies
In this decoupled architecture, network bandwidth between the compute engine and the object storage is the primary bottleneck. Data engineers employ a variety of advanced strategies to minimize this I/O:
- Partitioning: Organizing data into distinct directories based on a frequently queried column (e.g., separating data by
year/month/day). When an analyst queries a specific date, the engine simply ignores all directories that do not match, massively reducing data reads. - Z-Ordering and Space-Filling Curves: Advanced sorting techniques that cluster multi-dimensional data physically close together on the disk. This dramatically improves the effectiveness of file-skipping statistics (Min/Max filtering) in formats like Iceberg, allowing engines to read highly targeted, microscopic subsets of massive tables.
- Compaction: Over time, streaming ingestions create millions of tiny, inefficient files. Data engineers run scheduled compaction jobs (often utilizing bin-packing algorithms) to merge these tiny files into optimally sized, large columnar blocks (typically 128MB to 512MB), restoring query performance and reducing S3 API overhead.
Security and Governance
As data is democratized across the enterprise, governance becomes paramount. The open lakehouse relies on centralized metadata catalogs (like AWS Glue, Apache Polaris, or Unity Catalog) to manage access. Fine-Grained Access Control (FGAC) allows administrators to mask specific columns (like Social Security Numbers) or restrict specific rows based on the user’s role, ensuring that a single, unified dataset can be securely queried by marketing, finance, and engineering teams simultaneously without violating compliance regulations like GDPR or CCPA.
Conclusion
The architecture described above is not static. The industry is rapidly moving toward real-time streaming ingestion, automated “agentic” data modeling, and universal cross-engine compatibility via projects like Apache XTable. Understanding the foundational layers—how data is serialized, compressed, stored, and transported—is the absolute prerequisite for architecting systems that can handle the exabyte-scale analytics demands of the future.
Extended Deep Dive: The Data Engineering Ecosystem
To truly understand this concept, it must be placed within the broader context of the modern data engineering ecosystem. The evolution from traditional, monolithic on-premises data warehouses to decoupled, cloud-native open data lakehouses represents one of the most significant paradigm shifts in software architecture over the last two decades.
The Problem with Legacy Data Warehouses
Historically, organizations relied on proprietary appliances from vendors like Teradata, Oracle, or IBM. These systems were characterized by a tight coupling of compute and storage. The data physically resided on the hard drives of the specific servers that executed the SQL queries. While incredibly fast for structured, relational data, this architecture suffered from fatal scalability flaws. If an organization needed more storage for historical logs, they were forced to purchase expensive, proprietary servers that included compute power they did not actually need. Furthermore, these systems struggled to ingest unstructured data (like raw JSON, images, or massive IoT streams), creating impenetrable data silos.
The Rise and Fall of the Data Lake (Hadoop)
To solve the volume and variety problem, the industry pivoted to the Data Lake, pioneered by Apache Hadoop. Organizations began dumping all raw data—structured, semi-structured, and unstructured—into the Hadoop Distributed File System (HDFS). Because HDFS ran on cheap commodity hardware, storage became essentially free. However, the data lake lacked the basic governance, transactional guarantees, and performance optimization of the data warehouse. Without ACID (Atomicity, Consistency, Isolation, Durability) transactions, concurrent reads and writes frequently corrupted data. Without schema enforcement, the data lake quickly devolved into an unmanageable, unqueryable “data swamp.”
The Open Data Lakehouse Paradigm
The open data lakehouse merges the best of both worlds. It utilizes the infinitely scalable, low-cost storage of the cloud (like Amazon S3 or Google Cloud Storage) but overlays the management and performance features of a traditional data warehouse.
This is achieved through a multi-layered architecture:
- The Storage Layer: Cloud object storage provides the infinite hard drive.
- The File Format Layer: Open columnar formats like Apache Parquet and ORC provide extreme compression and analytical read efficiency.
- The Table Format Layer: Technologies like Apache Iceberg, Delta Lake, and Apache Hudi sit on top of the physical files. They provide the metadata layer that enables ACID transactions, schema evolution, and time travel, bringing warehouse-level reliability to the raw object storage.
- The Compute Layer: Decoupled, highly elastic engines like Trino, Dremio, Apache Spark, and Snowflake sit at the top. They can be scaled up or down independently of the storage, providing massive parallel processing power only when queries are actively running.
Performance Optimization Strategies
In this decoupled architecture, network bandwidth between the compute engine and the object storage is the primary bottleneck. Data engineers employ a variety of advanced strategies to minimize this I/O:
- Partitioning: Organizing data into distinct directories based on a frequently queried column (e.g., separating data by
year/month/day). When an analyst queries a specific date, the engine simply ignores all directories that do not match, massively reducing data reads. - Z-Ordering and Space-Filling Curves: Advanced sorting techniques that cluster multi-dimensional data physically close together on the disk. This dramatically improves the effectiveness of file-skipping statistics (Min/Max filtering) in formats like Iceberg, allowing engines to read highly targeted, microscopic subsets of massive tables.
- Compaction: Over time, streaming ingestions create millions of tiny, inefficient files. Data engineers run scheduled compaction jobs (often utilizing bin-packing algorithms) to merge these tiny files into optimally sized, large columnar blocks (typically 128MB to 512MB), restoring query performance and reducing S3 API overhead.
Security and Governance
As data is democratized across the enterprise, governance becomes paramount. The open lakehouse relies on centralized metadata catalogs (like AWS Glue, Apache Polaris, or Unity Catalog) to manage access. Fine-Grained Access Control (FGAC) allows administrators to mask specific columns (like Social Security Numbers) or restrict specific rows based on the user’s role, ensuring that a single, unified dataset can be securely queried by marketing, finance, and engineering teams simultaneously without violating compliance regulations like GDPR or CCPA.
Conclusion
The architecture described above is not static. The industry is rapidly moving toward real-time streaming ingestion, automated “agentic” data modeling, and universal cross-engine compatibility via projects like Apache XTable. Understanding the foundational layers—how data is serialized, compressed, stored, and transported—is the absolute prerequisite for architecting systems that can handle the exabyte-scale analytics demands of the future.
Visual Architecture

