Software Alternatives, Accelerators & Startups

runc VS Apache Thrift

Compare runc VS Apache Thrift and see what are their differences

runc logo runc

CLI tool for spawning and running containers according to the OCI specification - opencontainers/runc

Apache Thrift logo Apache Thrift

An interface definition language and communication protocol for creating cross-language services.
  • runc Landing page
    Landing page //
    2023-08-21
  • Apache Thrift Landing page
    Landing page //
    2019-07-12

runc features and specs

  • Standardization
    runc is part of the Open Containers Initiative (OCI), promoting standardization across container runtimes. This ensures interoperability and broad community support.
  • Lightweight
    As a lightweight and fast CLI tool, runc provides a minimal runtime for environments where resource efficiency is critical.
  • Security
    runc adheres to principles of secure software development and incorporates Linux kernel features like namespaces and cgroups to enhance security.
  • Broad Adoption
    As the reference implementation for OCI, runc is widely adopted and tested in production environments, ensuring reliability.
  • Flexibility
    runc offers the flexibility to handle low-level container configurations, making it suitable for advanced users needing granular control.

Possible disadvantages of runc

  • Complexity for Beginners
    The low-level nature of runc can be daunting for beginners who might prefer higher-level tools like Docker that abstract away complexities.
  • Minimalist Design
    While its simplicity is an advantage, runc lacks some of the advanced features and orchestration capabilities found in other container platforms.
  • Manual Configurations
    Users need to manually handle configurations, which can be error-prone and time-consuming compared to automated solutions.
  • Ecosystem Integration
    runc does not provide direct integration with tools and platforms by default, requiring additional setup for comprehensive ecosystem support.
  • Limited Features
    Compared to complete container platforms, runc offers fewer built-in features, requiring supplementary tools to achieve similar functionalities.

Apache Thrift features and specs

  • Cross-Language Support
    Apache Thrift supports numerous programming languages including Java, Python, C++, Ruby, and more, enabling seamless communication between services written in different languages.
  • Efficient Serialization
    Thrift offers efficient binary serialization which helps in reducing the payload size and improves the communication speed between services.
  • Service Definition Flexibility
    Thrift provides a robust interface definition language (IDL) for defining and generating code for services with strict type checking, fostering strong contract interfaces.
  • Scalability
    Due to its lightweight and efficient serialization mechanisms, Apache Thrift can handle a large number of simultaneous client connections, making it suitable for scalable distributed systems.
  • Versioning Support
    Thrift supports service versioning which helps in evolving APIs without disrupting existing services or clients.

Possible disadvantages of Apache Thrift

  • Steep Learning Curve
    For new users, especially those not familiar with RPC frameworks, learning and understanding Thrift’s IDL and operations can be complex and time-consuming.
  • Documentation and Community Support
    Compared to some alternative technologies, Apache Thrift's documentation and community support can be less robust, which might pose challenges in troubleshooting or seeking guidance.
  • Lack of Advanced Features
    Thrift does not support some advanced features like streaming or multiplexing out of the box, which could limit its use in complex systems requiring these functionalities.
  • Infrastructure Overhead
    Integrating Thrift into an existing system might introduce infrastructure overhead both in initial setup and ongoing maintenance, especially when dealing with multiple languages.
  • Protocol Limitations
    While Thrift is highly efficient, its protocol limitations might require additional workarounds for certain data structures or transport mechanisms, complicating development.

runc videos

2/21/19 RunC Vulnerability Gives Root Access on Container Systems| AT&T ThreatTraq

More videos:

  • Review - Demo MONEY,TIME - RunC

Apache Thrift videos

Apache Thrift

Category Popularity

0-100% (relative to runc and Apache Thrift)
Web Servers
41 41%
59% 59
Web And Application Servers
Developer Tools
60 60%
40% 40
Load Balancer / Reverse Proxy

User comments

Share your experience with using runc and Apache Thrift. For example, how are they different and which one is better?
Log in or Post with

Social recommendations and mentions

Apache Thrift might be a bit more popular than runc. We know about 13 links to it since March 2021 and only 11 links to runc. We are tracking product recommendations and mentions on various public social media platforms and blogs. They can help you identify which product is more popular and what people think of it.

runc mentions (11)

  • Setup multi node kubernetes cluster using kubeadm
    For kubeadm , kubetlet , kubectl should same version package in this lab I used v1.31 to have 1.31.7 References: Https://kubernetes.io/docs/reference/networking/ports-and-protocols/ Https://kubernetes.io/docs/setup/production-environment/tools/kubeadm/install-kubeadm/ Https://github.com/opencontainers/runc/releases/... - Source: dev.to / about 2 months ago
  • Comparing 3 Docker container runtimes - Runc, gVisor and Kata Containers
    Previously I wrote about the multiple variants of Docker and also the dependencies behind the Docker daemon. One of the dependencies was the container runtime called runc. That is what creates the usual containers we are all familiar with. When you use Docker, this is the default runtime, which is understandable since it was started by Docker, Inc. - Source: dev.to / 6 months ago
  • You run containers, not dockers - Discussing Docker variants, components and versioning
    Now we have dockerd which uses containerd, but containerd will not create containers directly. It needs a runtime and the default runtime is runc, but that can be changed. Containerd actually doesn't have to know the parameters of the runtime. There is a shim process between containerd and runc, so containerd knows the parameters of the shim, and the shim knows the parameters of runc or other runtimes. - Source: dev.to / 6 months ago
  • US Cybersecurity: The Urgent Need for Memory Safety in Software Products
    It's interesting that, in light of things like this, you still see large software companies adding support for new components written in non-memory safe languages (e.g. C) As an example Red Hat OpenShift added support for crun(https://github.com/containers/crun), which is written in C as an alternative to runc, which is written in Go( - Source: Hacker News / over 1 year ago
  • Why did the Krustlet project die?
    Yeah, runtimeClass lets you specify which CRI plugin you want based on what you have available. Here's an example from the containerd documentation - you could have one node that can run containers under standard runc, gvisor, kata containers, or WASM. Without runtimeClass, you'd need either some form of custom solution or four differently configured nodes to run those different runtimes. That's how krustlet did... Source: over 2 years ago
View more

Apache Thrift mentions (13)

  • Show HN: TypeSchema – A JSON specification to describe data models
    I once read a paper about Apache/Meta Thrift [1,2]. It allows you to define data types/interfaces in a definition file and generate code for many programming languages. It was specifically designed for RPCs and microservices. [1]: https://thrift.apache.org/. - Source: Hacker News / 7 months ago
  • Delving Deeper: Enriching Microservices with Golang with CloudWeGo
    While gRPC and Apache Thrift have served the microservice architecture well, CloudWeGo's advanced features and performance metrics set it apart as a promising open source solution for the future. - Source: dev.to / about 1 year ago
  • Reddit System Design/Architecture
    Services in general communicate via Thrift (and in some cases HTTP). Source: about 2 years ago
  • Universal type language!
    Protocol Buffers is the most popular one, but there are many others such as Apache Thrift and my own Typical. Source: about 2 years ago
  • You worked on it? Why is it slow then?
    RPC is not strictly OO, but you can think of RPC calls like method calls. In general it will reflect your interface design and doesn't have to be top-down, although a good project usually will look that way. A good contrast to REST where you use POST/PUT/GET/DELETE pattern on resources where as a procedure call could be a lot more flexible and potentially lighter weight. Think of it like defining methods in code... Source: over 2 years ago
View more

What are some alternatives?

When comparing runc and Apache Thrift, you can also consider the following products

Docker Hub - Docker Hub is a cloud-based registry service

Eureka - Eureka is a contact center and enterprise performance through speech analytics that immediately reveals insights from automated analysis of communications including calls, chat, email, texts, social media, surveys and more.

SkyDNS - DNS service discovery for etcd. Contribute to skynetservices/skydns development by creating an account on GitHub.

Traefik - Load Balancer / Reverse Proxy

Apache ZooKeeper - Apache ZooKeeper is an effort to develop and maintain an open-source server which enables highly reliable distributed coordination.

Avro - Avro Keyboard is an Unicode and ANSI compliant Free Bangla Typing Software and Bangla Spell Checker for Windows.