|
|
|
---
|
|
|
|
layout: core
|
|
|
|
description: "Blockstack naming service (BNS)"
|
|
|
|
permalink: /:collection/:path.html
|
|
|
|
---
|
|
|
|
# Blockstack Naming Service (BNS)
|
|
|
|
{:.no_toc}
|
|
|
|
|
|
|
|
This document gives an overview of how the Blockstack Naming Service work. This
|
|
|
|
section introduces you to BNS and explains the following concepts:
|
|
|
|
|
|
|
|
* TOC
|
|
|
|
{:toc}
|
|
|
|
|
|
|
|
The ([Stacks Node](https://github.com/blockstack/blockstack-core))
|
|
|
|
repository is the reference implementation of the Blockstack Naming Service.
|
|
|
|
|
|
|
|
|
|
|
|
## What is BNS
|
|
|
|
|
|
|
|
The Blockstack Naming Service (BNS) is a network system that binds names
|
|
|
|
to off-chain state without relying on any central points of control.
|
|
|
|
It does so by embedding a log of its control-plane messages within a public blockchain, like Bitcoin.
|
|
|
|
|
|
|
|
Each BNS peer determines the state of each name by indexing these specially-crafted
|
|
|
|
transactions. In doing so, each peer independently calculates the same global
|
|
|
|
name state.
|
|
|
|
|
|
|
|
Names in BNS have three properties:
|
|
|
|
|
|
|
|
* **Names are globally unique.** The protocol does not allow name collisions, and all
|
|
|
|
well-behaved nodes resolve a given name to the same state.
|
|
|
|
* **Names are human-meaningful.** Each name is chosen by its creator.
|
|
|
|
* **Names are strongly-owned.** Only the name's owner can change the state it
|
|
|
|
resolves to. Specifically, a name is owned by one or more ECDSA private keys.
|
|
|
|
|
|
|
|
Internally, a BNS node implements a replicated name database. Each BNS node keeps itself
|
|
|
|
synchronized to all of the other ones in the world, so queries on one BNS node
|
|
|
|
will be the same on other nodes. BNS nodes allow a name's owner to bind
|
|
|
|
up to 40Kb of off-chain state to their name, which will be replicated to all
|
|
|
|
BNS nodes via the [Atlas network]({{ site.baseurl }}/core/atlas/overview.html).
|
|
|
|
|
|
|
|
BNS nodes extract the name database log from an underlying blockchain (Blockstack
|
|
|
|
Core currently uses Bitcoin, and had used Namecoin in the past).
|
|
|
|
BNS uses the blockchain to establish a shared "ground truth" for the system: as long as
|
|
|
|
two nodes have the same view of the blockchain, then they will build up the same
|
|
|
|
database.
|
|
|
|
|
|
|
|
The biggest consequence for developers is that in BNS, reading name state is
|
|
|
|
fast and cheap but writing name state is slow and expensive. This is because
|
|
|
|
registering and modifying names requires one or more transactions to be sent to
|
|
|
|
the underlying blockchain, and BNS nodes will not process them until they are
|
|
|
|
sufficiently confirmed. Users and developers need to acquire and spend
|
|
|
|
the requisite cryptocurrency (i.e. Bitcoin) to send BNS transactions.
|
|
|
|
|
|
|
|
## Motivation behind naming services
|
|
|
|
|
|
|
|
We rely on naming systems in everyday life, and they play a critical
|
|
|
|
role in many different applications. For example, when you look up a
|
|
|
|
friend on social media, you are using the platform's naming service to resolve
|
|
|
|
their name to their profile. When you look up a website, you are using the
|
|
|
|
Domain Name Service to
|
|
|
|
resolve the hostname to its host's IP address. When you check out a Git branch, you
|
|
|
|
are using your Git client to resolve the branch name to a commit hash.
|
|
|
|
When you look up someone's PGP key on a keyserver, you are resolving
|
|
|
|
their key ID to their public key.
|
|
|
|
|
|
|
|
What kinds of things do we want to be true about names? In BNS, names are
|
|
|
|
globally unique, names are human-meaningful, and names are strongly-owned.
|
|
|
|
However, if you look at these examples, you'll see that each of them only
|
|
|
|
guarantees *two* of these properties. This limits how useful they can be.
|
|
|
|
|
|
|
|
* In DNS and social media, names are globally unique and human-readable, but not
|
|
|
|
strongly-owned. The system operator has the
|
|
|
|
final say as to what each names resolves to.
|
|
|
|
* **Problem**: Clients must trust the system to make the right
|
|
|
|
choice in what a given name resolves to. This includes trusting that
|
|
|
|
no one but the system administrators can make these changes.
|
|
|
|
|
|
|
|
* In Git, branch names are human-meaningful
|
|
|
|
and strongly-owned, but not globally unique. Two different Git nodes may resolve the same
|
|
|
|
branch name to different unrelated repository states.
|
|
|
|
* **Problem**: Since names can refer to conflicting state, developers
|
|
|
|
have to figure out some other mechanism to resolve ambiguities. In Git's
|
|
|
|
case, the user has to manually intervene.
|
|
|
|
|
|
|
|
* In PGP, names are key IDs. They are
|
|
|
|
are globally unique and cryptographically owned, but not human-readable. PGP
|
|
|
|
key IDs are derived from the keys they reference.
|
|
|
|
* **Problem**: These names are difficult for most users to
|
|
|
|
remember since they do not carry semantic information relating to their use in the system.
|
|
|
|
|
|
|
|
BNS names have all three properties, and none of these problems. This makes it a
|
|
|
|
powerful tool for building all kinds of network applications. With BNS, we
|
|
|
|
can do the following and more:
|
|
|
|
|
|
|
|
* Build domain name services where hostnames can't be hijacked.
|
|
|
|
* Build social media platforms where user names can't be stolen by phishers.
|
|
|
|
* Build version control systems where repository branches do not conflict.
|
|
|
|
* Build public-key infrastructure where it's easy for users to discover and
|
|
|
|
remember each other's keys.
|
|
|
|
|
|
|
|
|
|
|
|
# Organization of BNS
|
|
|
|
|
|
|
|
BNS names are organized into a global name hierarchy. There are three different
|
|
|
|
layers in this hierarchy related to naming:
|
|
|
|
|
|
|
|
* **Namespaces**. These are the top-level names in the hierarchy. An analogy
|
|
|
|
to BNS namespaces are DNS top-level domains. Existing BNS namespaces include
|
|
|
|
`.id`, `.podcast`, and `.helloworld`. All other names belong to exactly one
|
|
|
|
namespace. Anyone can create a namespace, but in order for the namespace
|
|
|
|
to be persisted, it must be *launched* so that anyone can register names in it.
|
|
|
|
Namespaces are not owned by their creators.
|
|
|
|
|
|
|
|
* **BNS names**. These are names whose records are stored directly on the
|
|
|
|
blockchain. The ownership and state of these names are controlled by sending
|
|
|
|
blockchain transactions. Example names include `verified.podcast` and
|
|
|
|
`muneeb.id`. Anyone can create a BNS name, as long as the namespace that
|
|
|
|
contains it exists already. The state for BNS names is usually stored in the [Atlas
|
|
|
|
network]({{ site.baseurl }}/core/atlas/overview.html).
|
|
|
|
|
|
|
|
* **BNS subdomains**. These are names whose records are stored off-chain,
|
|
|
|
but are collectively anchored to the blockchain. The ownership and state for
|
|
|
|
these names lives within the [Atlas network]({{ site.baseurl }}/core/atlas/overview.html). While BNS
|
|
|
|
subdomains are owned by separate private keys, a BNS name owner must
|
|
|
|
broadcast their subdomain state. Example subdomains include `jude.personal.id`
|
|
|
|
and `podsaveamerica.verified.podcast`. Unlike BNS namespaces and names, the
|
|
|
|
state of BNS subdomains is *not* part of the blockchain consensus rules.
|
|
|
|
|
|
|
|
A feature comparison matrix summarizing the similarities and differences
|
|
|
|
between these name objects is presented below:
|
|
|
|
|
|
|
|
| Feature | **Namespaces** | **BNS names** | **BNS Subdomains** |
|
|
|
|
|---------|----------------|---------------|--------------------|
|
|
|
|
| Globally unique | X | X | X |
|
|
|
|
| Human-meaningful | X | X | X |
|
|
|
|
| Owned by a private key | | X | X |
|
|
|
|
| Anyone can create | X | X | [1] |
|
|
|
|
| Owner can update | | X | [1] |
|
|
|
|
| State hosted on-chain | X | X | |
|
|
|
|
| State hosted off-chain | | X | X |
|
|
|
|
| Behavior controlled by consensus rules | X | X | |
|
|
|
|
| May have an expiration date | | X | |
|
|
|
|
|
|
|
|
[1] Requires the cooperation of a BNS name owner to broadcast its transactions
|