Client Interfaces
Multi-Protocol Support
Ozone is a multi-protocol file system. There are different protocols by which users can access data on Ozone.
Ofs (Hadoop compatible)
Hadoop Compatible file system allows any application that expects an HDFS like interface to work against Ozone with zero changes. Frameworks like Apache Spark, YARN and Hive work against Ozone without needing any change. Global level view.
Ofs (Hadoop compatible)O3fs (Hadoop compatible)
Hadoop Compatible file system allows any application that expects an HDFS like interface to work against Ozone with zero changes. Frameworks like Apache Spark, YARN and Hive work against Ozone without needing any change. Bucket level view.
O3fs (Hadoop compatible)S3 Protocol
Ozone supports Amazon’s Simple Storage Service (S3) protocol. In fact, You can use S3 clients and S3 SDK based applications without any modifications with Ozone.
S3 ProtocolCommand Line Interface
Ozone shell is the primary interface to interact with Ozone from the command line. Behind the scenes it uses the Java API. There are some functionality which couldn’t be accessed without using ozone sh commands. For example: Creating volumes with quota Managing internal ACLs Creating buckets with encryption key All of these are one-time, administration tasks. Applications can use Ozone without this CLI using other interface like Hadoop Compatible File System (o3fs or ofs) or S3 interface.
Command Line InterfaceRecon API
Recon server supports HTTP endpoints to help troubleshoot and monitor Ozone cluster.
Recon APIJava API
Ozone has a set of Native RPC based APIs. This is the lowest level API’s on which all other protocols are built. This is the most performant and feature-full of all Ozone protocols.
Java APICSI Protocol
Ozone supports Container Storage Interface(CSI) protocol. You can use Ozone by mounting an Ozone volume by Ozone CSI.
CSI ProtocolHttpFS Gateway
Ozone HttpFS is a WebHDFS compatible interface implementation, as a separate role it provides an easy integration with Ozone.
HttpFS GatewayInteractive Recon API Specification
window.onload = function () { const ui = SwaggerUIBundle({ url: "..\/swagger-resources\/recon-api.yaml", dom_id: '#api-container', deepLinking: true, presets: [ SwaggerUIBundle.presets.apis, SwaggerUIStandalonePreset ], plugins: [ SwaggerUIBundle.plugins.DownloadUrl ], layout: "StandaloneLayout", docExpansion: 'none' }) window.ui = ui; }
Interactive Recon API Specification