A realtime, decentralized, offline-first, mutable graph protocol to sync the web.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Mark Nadal cb3f8600d9
Merge pull request #1029 from jussiry/master
3 weeks ago
.github not sure how it happend - but fixed the tab mixup 2 months ago
examples Merge branch 'master' of github.com:amark/gun 2 months ago
hooks Made the Docker Hub Automated build hook usable offline via 'npm docker' 4 years ago
lib Merge branch 'master' of github.com:amark/gun 1 month ago
sea Merge remote-tracking branch 'origin/master' into pr/sirpy/12 8 months ago
src build/unbuild 8 months ago
test Merge pull request #1035 from mimiza/master 1 month ago
types remove ts-type import 9 months ago
.dockerignore * Sanitized /examples dependency management 4 years ago
.gitignore Merge branch 'master' into manhattan 10 months ago
.npmignore chore: .npmignore 11 months ago
.prettierignore WIP: use isomorphic-webcrypto for RN 1 year ago
.travis.yml DROPPING NODEJS 8 SUPPORT!!!! 1 year ago
CHANGELOG.md Update CHANGELOG.md 8 months ago
Dockerfile fix dockerfile 7 months ago
LICENSE.md chore(license): Adding triple license 5 years ago
Procfile puff it 10 months ago
README.md Update README.md 4 months ago
app.json visualize memory 1 year ago
as.js afore! test? 1 year ago
axe.js do not axe up peers on puts 7 months ago
bower.json fix path, map, set, load, load, ws & escape todo + bump 5 years ago
browser.js add: restore old browser export and add react-native friendly exports 1 year ago
global.d.ts refactor: update types for better extendable 11 months ago
gun.d.ts refactor: update types for better extendable 11 months ago
gun.js Fixed issue 935. Detects zero length key 3 months ago
gun.min.js build/unbuild 8 months ago
index.d.ts refactor: update types for better extendable 11 months ago
index.js Massive directory cleanup, more reliable transport 6 years ago
nts.js patch + update `.mesh` to _ 2 years ago
package-lock.json clean package 8 months ago
package.json remove react-native-webiew-crypto dependency which breaks the build 2 months ago
sea.js fix bug 1 month ago
tsconfig.json split @types/gun 11 months ago


Travis FOSSA Status Gitter

GUN is an ecosystem of tools that let you build community run and encrypted applications.

Currently, Internet Archive and HackerNoon run GUN in production.

Decentralized alternatives to Zoom, Reddit, Slack, YouTube, Wikipedia, etc. have already pushed terabytes of daily P2P traffic on GUN. We are a friendly community creating a free fun future for freedom:

The ecosystem is one nice stack of technologies that looks like this: (names -> use case)

For now, it is best to start with GUN and just use it to learn the basics, since it is so easy: (or want to read more? Skip ahead to the "What is GUN?" section.)


  • Try the interactive tutorial in the browser (5min ~ average developer).
  • Or npm install gun and run the examples with cd node_modules/gun && npm start (5min ~ average developer).

Note: If you don't have node or npm, read this first. If the npm command line didn't work, you may need to mkdir node_modules first or use sudo.

<script src="https://cdn.jsdelivr.net/npm/gun/gun.js"></script>
// var Gun = require('gun'); // in NodeJS
// var Gun = require('gun/gun'); // in React
var gun = Gun();

  name: "Mark",
  email: "mark@gunDB.io",

gun.get('mark').on(function(data, key){
  console.log("update:", data);
  • Or try something mind blowing, like saving circular references to a table of documents! (play)
var cat = {name: "Fluffy", species: "kitty"};
var mark = {boss: cat};
cat.slave = mark;

// partial updates merge with existing data!

// access the data as if it is a document.
gun.get('mark').get('boss').get('name').once(function(data, key){
  // `val` grabs the data once, no subscriptions.
  console.log("Mark's boss is", data);

// traverse a graph of circular references!
gun.get('mark').get('boss').get('slave').once(function(data, key){
  console.log("Mark is the slave!", data);

// add both of them to a table!

// grab each item once from the table, continuously:
gun.get('list').map().once(function(data, key){
  console.log("Item:", data);

// live update the table!
gun.get('list').set({type: "cucumber", goal: "scare cat"});

Want to keep building more? Jump to THE DOCUMENTATION!

What is GUN?

First & foremost, GUN is a community of the nicest and most helpful people out there. So I want to invite you to come tell us about what you are working on & wanting to build (new or old school alike! Just be nice as well.) and ask us your questions directly. :)

On that note, let's get some official shout outs covered first:


Thanks to:

Robert Heessels, Lorenzo Mangani, NLnet Foundation, Sam Liu, Daniel Dombrowsky, Vincent Woo, AJ ONeal, Bill Ottman, Mike Lange, Sean Matheson, Alan Mimms, Dário Freire, John Williamson, Robin Bron, Elie Makhoul, Mike Staub, Bradley Matusiak


GUN was created by Mark Nadal in 2014 after he had spent 4 years trying to get his collaborative web app to scale up with traditional databases.

After he realized Master-Slave database architecture causes one big bottleneck, he (as a complete newbie outsider) naively decided to question the status quo and shake things up with controversial, heretical, and contrarian experiments:

The NoDB - no master, no servers, no "single source of truth", not built with a real programming language or real hardware, no DevOps, no locking, not just SQL or NoSQL but both (all - graphs, documents, tables, key/value).

The goal was to build a P2P database that could survive living inside any browser, and could correctly sync data between any device after assuming any offline-first activity.

Technically, GUN is a graph synchronization protocol with a lightweight embedded engine, capable of doing 20M+ API ops/sec in just ~9KB gzipped size.


API reference





React & Native




CAP Theorem Tradeoffs

How Data Sync Works

How GUN is Built

Crypto Auth



This would not be possible without community contributors, big shout out to:

ajmeyghani (Learn GUN Basics with Diagrams); anywhichway (Block Storage); beebase (Quasar); BrockAtkinson (brunch config); Brysgo (GraphQL); d3x0r (SQLite); forrestjt (file.js); hillct (Docker); JosePedroDias (graph visualizer); JuniperChicago (cycle.js bindings); jveres (todoMVC); kristianmandrup (edge); Lightnet (Awesome Vue User Examples & User Kitchen Sink Playground); lmangani (Cytoscape Visualizer, Cassandra, Fastify, LetsEncrypt); mhelander (SEA); omarzion (Sticky Note App); PsychoLlama (LevelDB); RangerMauve (schema); robertheessels (gun-p2p-auth); rogowski (AXE); sbeleidy; sbiaudet (C# Port); Sean Matheson (Observable/RxJS/Most.js bindings); Shadyzpop (React Native example); sjones6 (Flint); Stefdv (Polymer/web components); zrrrzzt (JWT Auth); xmonader (Python Port);

I am missing many others, apologies, will be adding them soon! This list is infintiely old & way out of date, if you want to be listed in it please make a PR! :)


Tests may be run with npm test. Tests will trigger persistent writes to the DB, so subsequent runs of the test will fail. You must clear the DB before running the tests again. This can be done by running the following command in the project directory.

rm -rf *data*

Additional Cryptography Libraries

These are only needed for NodeJS & React Native, they shim the native Browser WebCrypto API.

If you want to use SEA for User auth and security, you will need to install:

npm install text-encoding @peculiar/webcrypto --save

Please see our React Native docs for installation instructions!

Then you can require SEA without an error:

var GUN = require('gun/gun');
var SEA = require('gun/sea');


Note: The default examples that get auto-deployed on npm start CDN-ify all GUN files, modules, & storage.

To quickly spin up a GUN relay peer for your development team, utilize either Heroku, Docker, any variant thereof Dokku, Flynn.io, now.sh, etc. ! Or use all of them so your relays are decentralized too!



Heroku deletes your data every 15 minutes, one way to fix this is by adding cheap storage.


git clone https://github.com/amark/gun.git
cd gun
heroku create
git push -f heroku HEAD:master

Then visit the URL in the output of the 'heroku create' step, in a browser.


npm install -g now
now --npm amark/gun

Then visit the URL in the output of the 'now --npm' step, in your browser.


Fork this GUN repo (Unubo only deploys from your own GitHub repo's).
Add a Node.js app, select your GUN fork, set npm start start as the command and deploy.

From the experience of genderev, this only works if you set your country to the United States.

Visit the deployed app by following the 'view app' button, in your browser.


Warning: Docker image is community contributed and may be old with missing security updates, please check version numbers to compare.

Docker Automated buil Docker Pulls Docker Stars

Pull from the Docker Hub . Or:

docker run -p 8765:8765 gundb/gun

Or build the Docker image locally:

git clone https://github.com/amark/gun.git
cd gun
docker build -t myrepo/gundb:v1 .
docker run -p 8765:8765 myrepo/gundb:v1

Or, if you prefer your Docker image with metadata labels (Linux/Mac only):

npm run docker
docker run -p 8765:8765 username/gun:git

Then visit http://localhost:8765 in your browser.


Designed with ♥ by Mark Nadal, the GUN team, and many amazing contributors.

Openly licensed under Zlib / MIT / Apache 2.0.

FOSSA Status

YouTube . Twitter