nitter twitter youtbe front end

Zed a77c0f6a84 Change jester branch 2 weeks ago
.github a8d99cc685 Add donation details 1 month ago
public 6b16ad2ce0 JS cleanup 1 month ago
src a89376008a Bypass A/B testing by restricting user agents 3 weeks ago
tests a39b891a3d Update tests, some tweets got removed 1 month ago
tools 795d9f4ec3 Add task to compile scss 5 months ago
.gitignore 96b7a6fa51 Fix .gitignore css typo 5 months ago
.travis.yml ba54182e0a Add PR support to travis config 3 months ago
Dockerfile 300d82a8ac Update Dockerfile and readme 4 months ago
LICENSE f031098f15 Add license file 8 months ago a8d99cc685 Add donation details 1 month ago
config.nims a77c0f6a84 Change jester branch 2 weeks ago
nitter.conf c9da638366 Rename themes 3 months ago
nitter.nimble a77c0f6a84 Change jester branch 2 weeks ago
screenshot.png bd4895f6fd Update readme 5 months ago

Nitter (WIP)

Build Status

A free and open source alternative Twitter front-end focused on privacy. \ Inspired by the project.

  • No JavaScript or ads
  • All requests go through the backend, client never talks to Twitter
  • Prevents Twitter from tracking your IP or JavaScript fingerprint
  • Unofficial API (no rate limits or developer account required)
  • Lightweight (for @nim_lang, 36KB vs 580KB from
  • RSS feeds
  • Themes
  • Mobile support (responsive design)
  • AGPLv3 licensed, no proprietary instances permitted

Todo (roughly in this order)

  • Embeds
  • Caching + archiving tweets/profiles
  • Simple account system with customizable feed
  • Json API endpoints
  • Emoji support (WIP, uses native font for now)


The wiki contains a list of Nitter instances and a list of browser extensions maintained by the community.


It's basically impossible to use Twitter without JavaScript enabled. If you try, you're redirected to the legacy mobile version which is awful both functionally and aesthetically. For privacy-minded folks, preventing JavaScript analytics and potential IP-based tracking is important, but apart from using the legacy mobile version and a VPN, it's impossible.

Using an instance of Nitter (hosted on a VPS for example), you can browse Twitter without JavaScript while retaining your privacy. In addition to respecting your privacy, Nitter is on average around 15 times lighter than Twitter, and in some cases serves pages faster.

In the future a simple account system will be added that lets you follow Twitter users, allowing you to have a clean chronological timeline without needing a Twitter account.




To compile Nitter you need a Nim installation, see for details. It is possible to install it system-wide or in the user directory you create below.

You also need to install libsass to compile the scss files. On Ubuntu and Debian, you can use libsass-dev.

# useradd -m nitter
# su nitter
$ git clone
$ cd nitter
$ nimble build -d:release
$ nimble scss
$ mkdir ./tmp

Set your hostname, port, page title and HMAC key in nitter.conf, then run Nitter by executing ./nitter. You should run Nitter behind a reverse proxy such as Nginx or Apache for better security.

To build and run Nitter in Docker:

docker build -t nitter:latest .
docker run -v $(pwd)/nitter.conf:/src/nitter.conf -d -p 8080:8080 nitter:latest

A prebuilt Docker image is provided as well:

docker run -v $(pwd)/nitter.conf:/src/nitter.conf -d -p 8080:8080 zedeus/nitter:latest

To run Nitter via systemd you can use this service file:

Description=Nitter (An alternative Twitter front-end)


# set user and group

# configure location



Then enable and run the service: systemctl enable --now nitter.service

Donating Donate using Liberapay

BTC: bc1qp7q4qz0fgfvftm5hwz3vy284nue6jedt44kxya \ ETH: 0x66d84bc3fd031b62857ad18c62f1ba072b011925 \ LTC: ltc1qhsz5nxw6jw9rdtw9qssjeq2h8hqk2f85rdgpkr \ XMR: 42hKayRoEAw4D6G6t8mQHPJHQcXqofjFuVfavqKeNMNUZfeJLJAcNU19i1bGdDvcdN6romiSscWGWJCczFLe9RFhM3d1zpL


Feel free to join our Freenode IRC channel at #nitter, or our Matrix server. You can email me at if you wish to contact me personally.