Install Discourse on Ubuntu for Development

:warning: This guide covers installation instructions in development environment, for a production guide see: Install Discourse in production with the official, supported instructions


So you want to set up Discourse on Ubuntu to hack on and develop with?

We’ll assume that you don’t have Ruby/Rails/Postgres/Redis installed on your Ubuntu system. Let’s begin!

Although this guide assumes that you are using Ubuntu, but the set-up instructions will work fine for any Debian based distribution.

This guide has been confirmed to be working without the use of any additional steps on Ubuntu 18.

:exclamation: Depending on what version of Ubuntu/Debian you’re using to install Discourse, you may want to review the following:

Notes about Installing Discourse on Ubuntu 20.04 or later

By default, Ubuntu version 20.04 comes preinstalled with OpenSSL 3.0.2. You’ll likely want to compile an earlier version of OpenSSL from source (we recommend OpenSSL-1.1.1n). You’ll also want to check what version of Ruby you’re using with ruby --version Discourse still uses Ruby 2, so if you’re using Ruby 3.x or later you’ll need to use an earlier version. We recommend using a version manager for Ruby here, and we’ve found that Ruby 2.7.6 is currently the best version to use with Discourse. See Notes about Installing Discourse on Ubuntu 20.04 for more details about this.

Ubuntu 22.04 Warning for Early Adopters

This section added by @pfaffman 22.05.16 and should one day be wrong and the suggestion unnecessary.

NOTE: This won’t work for Ubuntu 22.04 just yet. If you are forced to use 22.04 (I was using Pop! OS), see Failed to build ruby 2.7.5 on ubuntu 22.04 · Discussion #1940 · rbenv/ruby-build · GitHub for how to compile a compatible version of openssl.

End of @pfaffman additions.

Install Discourse Dependencies

As regular user run this script in terminal, to setup Rails development environment:-

bash <(wget -qO- https://raw.githubusercontent.com/discourse/install-rails/master/linux)

This will install following new packages on your system:

In case you have any of this package pre-installed and don’t want to run entire script, see the script and pick the packages you don’t have currently installed. The script is fine-tuned for Discourse, and includes all the packages required for Discourse installation.

Now that we have installed Discourse dependencies, let’s move on to install Discourse itself.

Clone Discourse

Clone the Discourse repository in ~/discourse folder:

git clone https://github.com/discourse/discourse.git ~/discourse

~ indicates home folder, so Discourse source code will be available in your home folder.

Setup Database

Create role with the same name as your ubuntu system username:

sudo -u postgres createuser -s "$USER"

Bootstrap Discourse

Switch to your Discourse folder:

cd ~/discourse

Install the needed gems

source ~/.bashrc
bundle install

Install the JS dependencies

yarn install

Now that you have successfully installed gems, run these commands:

bundle exec rake db:create 
bundle exec rake db:migrate
RAILS_ENV=test bundle exec rake db:create db:migrate

Try running the specs:

bundle exec rake autospec

All the tests should pass.

Start rails server:

bundle exec rails server

You should now be able to connect with your Discourse app on http://localhost:3000 - try it out!

Starting with Discourse 2.5+ EmberCLI is required in development and these additional steps will be required:

In a separate terminal instance, navigate to your discourse folder (cd ~/discourse) and run:

bin/ember-cli

You should now be able to navigate to http://localhost:4200 to see your local Discourse installation.

Create New Admin

To create a new admin, run the following command:

RAILS_ENV=development bundle exec rake admin:create

Follow the prompts, and a new admin account will be created.

Configure Mail

Run MailHog:

mailhog

Congratulations! You are now the admin of your own Discourse installation!

Happy hacking! And to get started with that, see Beginner’s Guide to Creating Discourse Plugins.


Last Reviewed by @AlexDev on 2022-05-26T19:00:00Z

50 Likes
Docker setup for development
Share your Discourse dev setup
Discourse as Your First Rails App
Why is my dev server not showing me uploaded images in Topics?
Not receiving Activation Email
Moderation Tools
Jhead and svgo errors while running specs
Override profile background via SSO
Rspec failing to load when using the official beginners guide
How to add a new language
Can I install discourse on my local machine
How to open via internal IP?
Can't set up dev environment due to cppjieba_rb failing to install
Export only database data Postgres (for users, posts and topics)
How to create new user with verified email in development mode?
Issue in setup discourse on ubuntu server
Unable to create Vagrant local installation
Installing problem - bundle install
How to get a docker image of discourse using bash on windows 10?
Attachment filename not set on download
[PAID] Import from Legacy Postgres DB
Dev Category sidebar
Discourse Server logs show DB queries when I run the server
Does Gemfile need to include svg?
Does Gemfile need to include svg?
Database wont migrate Discourse
I want to build a debug version of discourse
How to reset discourse on dev mode? (w/o docker)
Install Discourse on Windows 10 for development
Nodebb to Discourse
Install Discourse on Windows 10 for development
Install Discourse on Windows 10 for development
RSpec search_spec.rb RateLimiter LimitExceeded problems
Discourse as Your First Rails App
Issue with vagrant version following the dev guide
NULL first_visited_at dates in the topic_users table
Multiple instances. Visiting the second instance signs out the logged in account on the running instance
Can't run my Discourse locally
I want to install a plugin for development, what should I do?
Mini_racer installation issues on ubuntu vagrant (OSX)
Bundle exec rake fails
Vbulletin 4 import -
Hello from Gitpod! (installing on google cloud + automated dev setup)
How to Install Discourse on LocalHost in Windows?
Migration from Yahoo! Groups
Does the forum for development start up 24 hours*?
Two issues: Are they related to sidekiq? uninitialized constant Jobs::Jobs ::Scheduled (Discourse Newbie)
Bitnami Discourse VM on Virtualbox + SMTP mail-server for testing
How to allow customs hosts in development mode
Help with setting up discourse An error occurred while installing xorcist (1.1.2), and Bundler cannot continue
Any interest in Podman?
Install Discourse for development using Docker
Bundler cannot continue due installation error of mini_racer 0.4.0
How to setup discourse in my local for development?
How might we better structure #howto?
Please help, how do I install Discourse on macOS?
How might we better structure #howto?
Can't reach Discourse server in VM from Host
Migrate a MyBB forum to Discourse
Developing Discourse Plugins - Part 6 - Add acceptance tests
Images are not being populated in discourse
How to install Discourse locally?
Developing Discourse Plugins - Part 1 - Create a basic plugin
Discourse Local setup
Is this correct? How long to install dev Version?
Overriding user_guardian.rb in a plugin (no fork necessary!)
Installing Plugins in Discourse Development Install
How Sam's Windows development environment is configured
Site setting is different Every time on Ubuntu development installation
Problems with understanding the development of Discourse
How do I change the address in the database?
Discourse on local pc
Error while importing topics from Flarum (users, groups import OK)
Unable to Install Discourse for development
Flarum To Discourse Migration
Problem in development Installation
Install Discourse on macOS for development
Calling out for Testers
Problem in development Installation
Developing on the mobile version of Discourse
Can't build Discourse on Ubuntu 20.10
Errno::EACCES: Permission denied on new Ubuntu development setup
Discourse standalone
Set up a local Discourse Development Environment?
(Superseded) Set up a development environment using Vagrant on Ubuntu
Unable to setup discourse
Migrate a phpBB3 forum to Discourse
Migrate a vBulletin 4 forum to Discourse
Migrate from GetSatisfaction to Discourse
Migrate a FluxBB forum to Discourse
Migrate a NodeBB forum with Redis to Discourse
Migrate a MyBB forum to Discourse
Migrate a NodeBB forum with MongoDB to Discourse
Migrate a Ning forum to Discourse
Migrate a Phorum forum to Discourse
Migrate a PunBB forum to Discourse
Migrate from another forum to Discourse
Migrate a Kunena 3 forum to Discourse
Migrate a bbPress WordPress plugin forum to Discourse
Unable to setup discourse
Discourse Development Contributor Guidelines
Install Discourse on Windows 10 for development
Use the Discourse API ruby gem
Use Screen To Bootstrap A Development Install (Ubuntu)
Set up Discourse for development on Fedora Linux
Need to restart Ember in order to test front-end changes
Setup DiscourseConnect - Official Single-Sign-On for Discourse (sso)
Overriding user_guardian.rb in a plugin (no fork necessary!)
Migrate a MyBB forum to Discourse
Docker in VMWare - How to access to Discourse
How can I make my own Discourse plugins?
Install Discourse on Windows 10 for development
What is the latest recommended workflow for local development? (Ubuntu 16.04)
What is the latest recommended workflow for local development? (Ubuntu 16.04)
How to customize the Discourse app using docker container?
Update PhantomJS to latest for Ubuntu dev guide?
A check for updates has not been performed lately. Ensure sidekiq is running
How to fix bundler executable conflicts in the `techAPJ/install-rails` script?
Ubuntu development install: Permission denied @ apply2files
Install discourse on localhost
Trouble getting a top level page to Ember
Formal german available?
Any interest in Podman?
Rake aborted message is showing when installing vagrant development
Where is the db connection information discourse?
How to install the bootsnap gem?
Google Groups Import Script Fails (Due to Invalid Browser)
State of disqus to discourse importer
Connecting to Droplet
Connecting to Droplet
Install Discourse on Windows 10 for development
Install and import Mysql on the development environment
Can't uninstall on Ubuntu 18.04
How to install Discourse on windows
Share your Discourse dev setup
Discourse running very slow on local machine
Can't find the Discourse folder inside virtual box via ssh
Importing MyBB database to Discourse
How to install Discourse on windows

Which steps exactly did you not need to do?

Here’re the steps I’m talking about:

1 Like

I set up a dev environment on 22.04 like a week or so ago and had the issues described. Actually opted to just downgrade to 18.whatever because it was easier.

Not sure what the difference is.

1 Like

Discourse <2.5 was a long time ago. Maybe it’s time to remove this part? I won’t do it myself since it’s I’m not competent in this subject. :slight_smile: