DEV Community

Cover image for Solana's Account Model Explained for Web2 Developers
Erick Carvajal
Erick Carvajal

Posted on

Solana's Account Model Explained for Web2 Developers

When I first started learning Solana, the account model was probably the most confusing concept.

Coming from Web2 development, I was used to thinking in terms of applications, databases, users, and servers. Then I opened Solana Explorer and suddenly everything seemed to be an account.

  • Wallets are accounts.
  • Programs are accounts.
  • Token balances are accounts.

Even data storage is handled through accounts.

At first, it felt strange. After spending time building on Solana, I realized the account model is actually one of the network's most elegant design choices.

Think of Solana Like a Filesystem

The easiest way to understand Solana is to imagine an operating system filesystem.

Solana and Filesystem

Every file has:

  • An address or location
  • Metadata
  • Content
  • Permissions

Solana accounts work in a very similar way.

Every account lives in a giant key-value store.

The key is a 32-byte public address.

The value is the account itself.

Instead of thinking about wallets and smart contracts as separate objects, think of everything as files stored in the same global filesystem.

The Five Fields Every Account Has

Every account on Solana contains the same structure:

Solana Account

Lamports

Lamports are the smallest unit of SOL.

Just like 1 dollar contains 100 cents:

1 SOL = 1,000,000,000 lamports.

This field stores the account's SOL balance.

Data

This is where an account stores information.

A wallet account might store little or no data.

A token account stores token balances.

A DeFi protocol might store liquidity pool information, positions, or user state.

The data field is simply a byte array that programs can interpret however they want.

Owner

This is one of the most important fields.

The owner is the program that has permission to modify the account's data.

Think of it like file ownership in Linux.

If a program doesn't own an account, it cannot arbitrarily change its contents.

Executable

This field indicates whether the account contains executable code.

If executable is true, the account is a program.

If executable is false, the account is simply storing data.

Rent Epoch

Historically this field was used for rent collection.

Today it is deprecated and typically set to a maximum value.

You will still see it when inspecting account data, but modern applications rarely need to interact with it directly.

Ownership Is Solana's Security Model

One rule explains most of Solana's security model:

Ownership Is Solana's

Only the owner program can modify an account's data or remove lamports from it.

Interestingly, anyone can send lamports to a writable account.

This means ownership is not about who can deposit funds.

Ownership determines who can modify state.

For Web2 developers, this feels similar to database permissions.

You may have read access to a table, but only specific services can modify certain records.

The Concept That Surprised Me Most

The biggest surprise for me was learning that programs do not store their own state.

In many systems we think of an application and its data as being tightly connected.

On Solana they are separated.

Solana State

A program account contains executable code.

Data accounts contain state.

The program reads and writes data from those accounts when processing instructions.

A useful analogy is a web application.

Imagine:

  • The program is your backend server.
  • Data accounts are your database tables.
  • Transactions are API requests.

The backend doesn't keep all data inside its source code.

It reads and writes information to a database.

Solana works in a very similar way.

Why Rent Exemption Exists

Since storing data on-chain consumes network resources, accounts must maintain a minimum balance.

This is known as rent exemption.

Solana Rent

The larger the account's data size, the more lamports it must hold.

For a basic account, the amount is relatively small, but larger accounts require more SOL.

This mechanism prevents the blockchain from being flooded with free, permanent storage.

A Real Example

Wallet Swap Result

When I explored my own DeFi swap transaction in Solana Explorer, I expected to see a simple token exchange.

Instead, I found dozens of accounts interacting together.

Swap in Explorer

Transaction: https://explorer.solana.com/tx/3DW1LgsjDg2cbgZnsPE4UkR4WqnZoZpwn5tufuRgKaAtV3FuujkCoHxQ4Lx3PfN6zRjL9tDoShJR8HsBR6DQ42rV

Some accounts held token balances.

Some belonged to liquidity pools.

Some were temporary accounts created during execution.

Others belonged to programs like Jupiter and the Token Program.

Understanding the account model suddenly made the transaction much easier to follow.

Everything was just accounts interacting under a set of ownership rules.

Final Thoughts

If you're coming from Web2, the Solana account model can initially feel unfamiliar.

But once you stop thinking in terms of wallets versus smart contracts and start thinking in terms of accounts, programs, and ownership, many parts of Solana begin to make sense.

Accounts are the foundation of everything on the network.

Tokens, NFTs, DeFi protocols, governance systems, and wallets all build on the same simple idea:

Everything is an account.

Top comments (0)