Rust The Future Proof Systems Language
rei.r.joshua • March 3, 2024
Rust The Future Proof Systems Language

Industry Embrace of Rust

Rust has gained credibility across the tech industry thanks to its performance, safety and scaleability:


Cloud Giants like AWS, Azure, Cloudflare and Fastly use Rust for cloud services and edge computing.

Tools & Databases like npm, MongoDB, Vector and Databend leverage Rust’s speed and memory safety.

Operating Systems from Linux to Windows to Fuchsia incorporate Rust for reliability.

Web Tech sees Rust drive Firefox, Deno, CDNs, APIs and more.

Blockchains like Solana, Polkadot and Ethereum rely on Rust for their core infrastructure.


With Rust being battle-tested across domains from tiny devices to massive cloud platforms, it seems primed for long-term industry adoption driven by its unique capabilities.

Zero Bugs and Zero Cost How is This Possible?

Lifetimes represent the scope for which references in Rust are valid. Each reference has an associated lifetime that ensures it always points to valid, allocated data.


For example, consider a function that returns a reference to data created inside the function:

This code does not compile in Rust because the String s is deallocated once the function exits. So the returned reference would be invalid.


To fix this, we need to associate the lifetime of the reference with the lifetime of s. Rust allows specifying lifetime parameters to represent these scopes:

Now the returned reference is only valid for the lifetime 'a, which matches the scope of s. This makes the code safe.

Lifetime analysis is performed at compile time by Rust to catch any invalid references before they cause issues at runtime. They help guarantee memory safety without any runtime cost.


Lifetimes are usually implicit and inferred automatically in Rust. But understanding how explicit lifetimes work unlocks the full power and flexibility of Rust’s borrow checker for advanced scenarios.

Rust is a Breath of Fresh Air

So by now you see why Rust is such a big deal. It gives you both safety and speed — without the usual tradeoffs. Rust sidesteps entire classes of major headaches that have plagued programmers for ages.


Now it won’t click overnight. That borrow checker enforces unique rules; expect a learning curve as you adapt. But developers who embrace Rust tend to become hooked. The superpowers are just too good. Leaders like Microsoft, Google and AWS are betting big on Rust too. They want what it brings — secure, high-performance code. And Rust’s ecosystem expands daily. Rust may never become as popular as Java. But not every tool needs to do everything. Rust solves nasty problems in computing at the lowest level. It makes programmers happy along the way. So while it may never be used everywhere, Rust punches way above its weight class. And working with it just might rekindle that coding joy and thrill that drew you to programming originally. That alone makes Rust worth mastering.

Over the past decade, an exciting systems programming language called Rust has rapidly gained adoption across the industry. Originally created by Mozilla and now stewarded by the Rust Foundation, it has quickly become one of the fastest growing and most beloved languages after finally breaking through to the mainstream in recent years.


Despite being over 10 years old, Rust was mostly an academic curiosity and niche language for its first decade. But it now appears to be hitting an inflection point and coming into its own. Surveys show it topping charts as the “most loved language” among developers for years running.


Leading technology companies have started leveraging Rust for key infrastructure, products, and services. But what explains this once niche language’s newfound mass adoption and meteoric rise to prominence? Much of Rust’s success stems from how it creatively tackles long-standing pain points in systems programming.


Specifically, Rust guarantees memory safety without requiring a garbage collector for memory management. It does this via new concepts like ownership and borrowing that statically enforce validity of memory references at compile time. This eliminates entire categories of crashes, vulnerabilities, and bugs that have plagued systems programmers for decades — all without runtime overhead.


In this article, we will explore Rust’s unique approach to memory safety and other key features that make it well suited for performance-critical systems software like operating system components, embedded devices, browsers, and more. We’ll cover concepts of ownership, borrowing, and lifetimes that come together to enable Rust’s guarantees.

Memory Safety Without the Garbage Truck

Rust’s novel concept of ownership establishes clear resource management rules that the compiler rigorously enforces. Each value in Rust has a variable that serves as its unique owner. Ownership confers both responsibilities and privileges:


  • There can only be one owner at a time
  • The owner has exclusive access to modify or move the resource
  • When the owner goes out of scope, the resource is automatically cleaned up

By statically tracking resource ownership as variables enter and exit scope, Rust ensures resources are managed safely and efficiently without requiring manual allocation/freeing or garbage collection.

The owner of a resource is responsible for both its usage while in scope as well as clean up when no longer needed. This simple but strict rule eliminates entire classes of bugs.

We’ll build on ownership through language mechanisms like borrowing and lifetimes that enable sharing references to resources in well-defined ways. But ownership establishes the foundation.

  • Code Examples

    A code editor depicting lines of formatted rust code.

  • Code Examples

    A code editor depicting lines of formatted rust code.

  • Code Examples

    A code editor depicting lines of formatted rust code.

  • Code Examples

    A code editor depicting lines of formatted rust code.

  • Code Examples

    A code editor depicting lines of formatted rust code.

Concurrency Fearless by Default

A key innovation in Rust is the concept of borrowing. Borrowing allows access to data that is owned by someone else in a controlled manner. When a variable is borrowed, it creates a temporary reference to the resource that enforces rules about valid access at compile time.


Borrowing in Rust comes in two flavors immutable and mutable borrows. Immutable borrows use the & operator. These allow read access to the data, but prevent modifying it as long as the borrow exists:

Mutable borrows use the &mut operator. These allow both reading and modifying the data, but can only have one active mutable borrow at a time:

The Rust compiler (known affectionately as “the borrow checker”) ensures these borrowing rules are satisfied. This prevents invalid references and ensures memory safety without any runtime costs.

Next we’ll explore Rust’s concept of lifetimes, which represent the scope for which borrows are valid…

Abstract digital connected cloud.
By rei.r.joshua October 5, 2024
When you hear Salesforce, you probably think of a massive, all-encompassing SaaS provider tailored for enterprise clients. You envision dashboards, reports, accounts, and sales opportunities—all seamlessly connected within complex business processes. Teams of professionals interact with the system daily, weaving their tasks into Salesforce’s vast landscape. But beneath this complexity lies a simple, elegant structure that powers everything. In this article, we’ll strip away the layers to focus on Salesforce's fundamental building blocks—its DNA: objects, records, and relationships.
An abstract image of bright details cloud and commerce related elements.
By rei.r.joshua September 27, 2024
"What is the best option for current Salesforce Commerce Cloud engineers to future-proof their career?" This article aims to answer the question and introduce a more fundamental career philosophy that can enlighten and empower your decisions in the e-commerce sector.
By rei.r.joshua September 24, 2024
Salesforce Archive, unveiled at Dreamforce 2023, is the platform's latest offering designed to help organizations manage vast amounts of data. As the volume of business data grows, retaining and managing inactive or historical data becomes a challenge for many Salesforce users and a massive expense. Salesforce Archive offers a Salesforce native solution intended to help address these customer pain points by improving system performance, reducing storage costs, and ensuring compliance with data retention regulations. Whether you're a Salesforce architect, developer, or an e-commerce professional, understanding how Salesforce Archive works and what it offers is crucial when considering it as an addition to your Salesforce solution. The Launch of the Salesforce Archive The Unveiling During Dreamforce 2023, Salesforce introduced its native archiving solution. Among the many features showcased, Salesforce Archive immediately caught the attention of numerous current and potential Salesforce customers grappling with data overload. The product is currently in the pilot phase but is expected to become Generally Available (GA) shortly. This makes it a promising solution for businesses looking to alleviate the stress of managing their data and streamline their data management and retention infrastructure. Current Pilot Program and Availability Timeline The Salesforce Archive pilot program is ongoing and available to selected customers in several regions, including: United States Australia Germany India This new offering is projected to be available in November 2024, and Salesforce plans to roll it out globally in phases. This pilot allows early participants to shape the product's features based on real-world feedback. The Data Bloat Problem in Salesforce Impact on System Performance As organizations grow, their Salesforce environments become overwhelmed with inactive records, outdated files, and unnecessary attachments. This data bloat significantly impacts numerous system processes, such as slower queries, dashboards, and reports. These directly impact user productivity and, by extension, a client's ability to do business effectively. Increasing Storage Costs With Salesforce's on-platform tiered storage system, costs can quickly escalate, especially when you exceed your allocated limits. However, by leveraging Salesforce Archive, a native solution tailored for large-scale data storage, you can potentially reduce your on-platform storage footprint. This translates to significant cost savings, both in terms of required tiered storage and the additional costs associated with overages, providing a sense of financial security and confidence in your investment. Data Governance Challenges Many industries, such as healthcare and finance, face strict compliance and data governance rules. In these situations, hard Deletion is often not an option due to the need to retain data for regulatory reasons. Salesforce Archive offers a balanced approach, allowing customers to preserve data for future access without compromising the day-to-day performance of a production environment. This reassures users about the solution's effectiveness in managing data retention and system performance. What is Salesforce Archive? A Native Archiving Solution Salesforce Archive is Salesforce's first native archiving solution. It enables organizations to archive inactive or historical records that need to be retained but are irrelevant to day-to-day operations. Designed for Scalability and Efficiency Explicitly built to scale with a customer's data needs, Salesforce Archive empowers businesses to design and automate archiving processes, store vast amounts of historical data, and retrieve it on demand. It utilizes a highly efficient archiving engine, ensuring the Salesforce instance remains fast and responsive even as data grows. Key Features of Salesforce Archive Supports Both Standard and Custom Objects One of Salesforce Archive's standout features is its ability to handle standard and custom objects. This flexibility means the ability to design and implement archiving policies tailored to each customer's unique business needs. Whether you're managing customer records, transaction data, or custom objects explicitly built for your business, Salesforce Archive promises to be a valuable tool. Automated Archiving Policies Salesforce Archive allows users to automate their data archival processes. You can set policies that dictate how often archival jobs run, whether daily, weekly, or based on a custom schedule. Custom Scheduling of Archive Jobs You get to decide when and how often archive policies should run. You can configure the system to archive inactive data regularly without manual intervention, keeping your active Salesforce environment lean and fast. Archiving Inactive Records, Files, and Attachments From outdated records to large files, Salesforce Archive automates the removal of data you no longer actively use. However, it's not deleted—it's stored securely and remains accessible when needed. Seamless Access via Salesforce Connect Archived data is kept outside your primary Salesforce instance but can be viewed directly through Salesforce Connect. This means your archived data doesn't occupy storage space but is still accessible whenever needed. Built-In Compliance and Security All archived data remains within the Salesforce Trust Boundary, adhering to strict security standards. Making Salesforce Archive a highly secure option for industries dealing with sensitive data or strict regulatory compliance requirements. Understanding the Storage Architecture Separate Tech Stack for Performance Salesforce Archive operates on a separate technology stack within the Salesforce ecosystem. This separation ensures that archived data does not interfere with active system processes, improving query performance. Security and Compliance within the Salesforce Trust Boundary Salesforce has designed the archiving solution to meet its rigorous security protocols, ensuring that archived data remains secure and compliant with standards such as GDPR and CCPA. Automating Your Data Cleanup Building Custom Archiving Policies Salesforce Archive lets you define specific archiving policies for your business. Whether dealing with standard or custom objects, you can automate data cleanup based on the frequency and rules that make the most sense for your operations. Policy Creation for Standard and Custom Objects Whether working with standard Salesforce objects like Accounts and Contacts or custom objects, Salesforce Archive allows for tailored archiving policies that address your unique data requirements. Monitoring Archive Jobs and Sessions The Archive Management UI provides full transparency into archiving jobs, showing policy names, descriptions, job status, and frequency, so you always know what's happening with your data. Real-World Use Cases for Salesforce Archive Boosting Query Performance and User Productivity By offloading inactive data, Salesforce Archive significantly speeds up query response times and dashboard load speeds, helping users stay productive. Reducing Redundant Records and Data Footprint By automating the removal of inactive data, Salesforce Archive helps reduce redundancies and ensures a cleaner, more efficient Salesforce environment. Regulatory Compliance for Data Retention Whether it's healthcare records or financial transactions, archived data can be kept securely for compliance while remaining accessible when needed. How Salesforce Archive Improves Compliance GDPR, CCPA, and Industry-Specific Standards Salesforce Archive offers a secure and compliant way to retain historical data, helping organizations comply with global data regulations. Secure Archival of Historical Data Salesforce's security protocols protect all archived data, ensuring your business complies with privacy regulations while reducing storage costs. Integrating Salesforce Archive with Other Tools Salesforce Connect for Data Retrieval Using Salesforce Connect, you can seamlessly retrieve archived data, giving you full access to historical records without cluttering your active data store. Extending Archival Capabilities with Salesforce Shield, Backup, and Data Mask For even greater data control, Salesforce Archive can be integrated with tools like Salesforce Shield for auditing, Salesforce Backup for data recovery, and Data Mask.
Show More