Skip to content
CMS

How to Install Ghost on Ubuntu Linux

Richard
Written by
Richard
Sep 28, 2021 Updated Jun 20, 2026 8 min read
nginx default page

You install Ghost on Ubuntu Linux by manually configuring the blogging platform with Nginx, MariaDB, and an SSL certificate.

Ghost is a powerful, open-source publishing platform built on Node.js, specifically designed for modern content creators who want speed and focus.

This guide shows you how to install the latest stable version of Ghost, set up MariaDB for your database, and configure Nginx as a reverse proxy. You will also learn how to secure your Ghost installation with a free Let’s Encrypt SSL certificate.

⚡ Quick Answer

Install Ghost by first updating your package list and installing Nginx and MariaDB. Then, create a dedicated database user and grant it privileges. Finally, run the Ghost installer command to set up the blogging platform.

How to install Nginx on Ubuntu Linux

Nginx is a popular web server that will help your Ghost blog run smoothly. Installing Nginx on Ubuntu is straightforward and involves a few simple commands to get it set up as a proxy for your Ghost installation.

To install Nginx, run the commands below:

🐧Bash / Shell
sudo apt update
sudo apt install nginx

After installing Nginx, the commands below can be used to stop, start, and enable the Nginx service to always start up with the server boots.

🐧Bash / Shell
sudo systemctl stop nginx.service
sudo systemctl start nginx.service
sudo systemctl enable nginx.service

Once Nginx is installed, open a web browser and browse to the server hostname or IP address. If you see a Nginx welcome page, it has been successfully installed and is running on Ubuntu.

💻Code
http://localhost
nginx default page

How to install MariaDB on Ubuntu Linux

MariaDB is a reliable, open-source database that Ghost needs to store its content. You can install MariaDB on Ubuntu easily by running a couple of commands in your terminal to get the database server up and running.

To install MariaDB, run the commands below:

🐧Bash / Shell
sudo apt install mariadb-server

After installing MariaDB, the commands below can stop, start, and enable the service to start when the server boots.

🐧Bash / Shell
sudo systemctl stop mariadb.service
sudo systemctl start mariadb.service
sudo systemctl enable mariadb.service

After that, run the commands below to secure the MariaDB server by creating a root password, disallowing remote root access, removing anonymity, and more.

🐧Bash / Shell
sudo mysql_secure_installation

When prompted, answer the questions below by following the guide.

💻Code
If you've just installed MariaDB, and haven't set the root password yet, you should just press enter here.

Enter current password for root (enter for none): PRESS ENTER

Switch to unix_socket authentication [Y/n] n

Change the root password? [Y/n] n

Remove anonymous users? [Y/n] y

Disallow root login remotely? [Y/n] y

Remove test database and access to it? [Y/n] y

Reload privilege tables now? [Y/n] y

All done!

The latest MariaDB servers have a root user set to use the auth_socket authentication method by default.

The auth_socket plugin authenticates users that connect from the local host through the Unix socket file. You can’t authenticate as a root by providing a password.

This can cause issues with some apps that need to connect to the database via root. To fix that, you’ll need to change the default authentication mechanism from auth_socket to mysql_native_password.

However, doing so might introduce security risks since root users shouldn’t be used to connect remotely to the database. A recommended method is to create a dedicated user to connect remotely to your database servers.

Since you don’t want to connect to the MariaDB database server from phpMyAdmin as the root user, you should probably create a separate account instead of connecting with the root.

Run the commands below to log on to the MariaDB server.

🐧Bash / Shell
sudo mysql -u root -p

Then, run the SQL commands below to create a new user for Ghost to connect to the database.

💻Code
CREATE USER 'ghostadmin'@'localhost' IDENTIFIED BY 'very_strong_password_here';

Then, grant the user full access to manage the database server.

💻Code
GRANT ALL PRIVILEGES ON *.* TO 'ghostadmin'@'localhost' WITH GRANT OPTION;

The server was successfully installed if you see a similar screen.

Create Ghost Database on Ubuntu Linux

With MariaDB installed, you’ll need to create a specific database for your Ghost blog to use. Creating a Ghost database on Ubuntu involves logging into MariaDB and running a simple command to set up the new database.

To log on to MariaDB, run the commands below.

🐧Bash / Shell
sudo mysql -u root -p

Then, create a database called Ghost.

💻Code
CREATE DATABASE ghost;

Next, use the Ghost account created above and give it access to the Ghost database.

💻Code
GRANT ALL ON ghost.* TO 'ghostadmin'@'localhost' WITH GRANT OPTION;

Finally, save your changes and exit.

💻Code
FLUSH PRIVILEGES;
EXIT;

How to install Node.js on Ubuntu Linux

Ghost runs on Node.js, so you’ll need to install it on your Ubuntu system. Installing Node.js on Ubuntu is done using package management commands, ensuring you have the correct version needed for Ghost to function properly.

🐧Bash / Shell
sudo apt install curl
curl -sL https://deb.nodesource.com/setup_14.x | sudo bash -

Next, run the commands below to install Node.js and the required packages for Ghost to function. An Nginx webserver will be needed for this. s

🐧Bash / Shell
sudo apt install nodejs

Next, run the commands below to include and enable the Yarn repository.

Command Prompt
curl -sS https://dl.yarnpkg.com/debian/pubkey.gpg | sudo apt-key add -
echo "deb https://dl.yarnpkg.com/debian/ stable main" | sudo tee /etc/apt/sources.list.d/yarn.list

Once the repository is enabled, install yarn with the following:

🐧Bash / Shell
sudo apt update
sudo apt-get -o Dpkg::Options::="--force-overwrite" install yarn

How to download and install Ghost

The Ghost CLI is a command-line tool that makes installing and managing Ghost simple. To get started, you’ll first install the Ghost CLI on your Ubuntu system using Yarn, which is a package manager for Node.js.

Run the commands below to install the Ghost install tool.

🐧Bash / Shell
sudo yarn global add ghost-cli

We will create a folder for Ghost content in the /var/www/ghost directory. To create the folder, run the commands below.

🐧Bash / Shell
sudo mkdir -p /var/www/ghost

Next, change the folder ownership to your account so you can run the Ghost tool to download Ghost packages.

🐧Bash / Shell
sudo chown $USER:$USER /var/www/ghost
sudo chmod 775 /var/www/ghost

Next, change into the directory and install Ghost.

Command Prompt
cd /var/www/ghost

To start the installation, run the command below. The command will install and configure Ghost, Nginx as a reverse proxy, and secure the site with a free let’s encrypt SSL certificate.

💻Code
ghost install

You should begin to see Ghost changing for packages that are required. Once all is validated, Ghost should begin downloading its package dependencies to install.

💻Code
 Checking system Node.js version - found v14.18.0
✔ Checking logged in user
✔ Checking current folder permissions
✔ Checking system compatibility
✔ Checking for a MySQL installation
✔ Checking memory availability
✔ Checking free space
✔ Checking for latest Ghost version
✔ Setting up install directory
Downloading and installing Ghost v4.16.0 > Installing dependencies >

Next, set up the database connection with the info created above.

💻Code
? Enter your blog URL: http://example.com
? Enter your MySQL hostname: localhost
? Enter your MySQL username: ghostadmin
? Enter your MySQL password: [hidden]
? Enter your Ghost database name: ghost
✔ Configuring Ghost
✔ Setting up instance

When asked if you want to set up Nginx, type yes.

💻Code
 Setting up "ghost" system user
ℹ Setting up "ghost" mysql user [skipped]
? Do you wish to set up Nginx? Yes
+ sudo nginx -s reload
✔ Setting up Nginx
? Do you wish to set up SSL? Yes
? Enter your email (For SSL Certificate) admin@example.com
Running sudo command: mkdir -p /etc/letsencrypt
Running sudo command: ./acme.sh --install --home /etc/letsencrypt
Running sudo command: /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt --domain example.com --webroot /var/www/ghost/system/nginx-root --reloadcmd "nginx -s reload" --accountemail admin@example.com
Running sudo command: openssl dhparam -out /etc/nginx/snippets/dhparam.pem 2048
Running sudo command: mv /tmp/ssl-params.conf /etc/nginx/snippets/ssl-params.conf
✔ Creating ssl config file at /var/www/ghost/system/files/example.com-ssl.conf
Running sudo command: ln -sf /var/www/ghost/system/files/example.com-ssl.conf /etc/nginx/sites-available/example.com-ssl.conf
Running sudo command: ln -sf /etc/nginx/sites-available/example.com-ssl.conf /etc/nginx/sites-enabled/example.com-ssl.conf
Running sudo command: nginx -s reload
✔ Setting up SSL

When prompted with questions below, choose yes.

💻Code
 Do you wish to set up Systemd? Yes
✔ Setting up Systemd
? Do you want to start Ghost? Yes
✔ Starting Ghost

If all goes well, you should see a complete setup message similar to the one below.

💻Code
Running sudo command: /var/www/ghost/current/node_modules/.bin/knex-migrator-migrate --init --mgpath /var/www/ghost/current
✔ Running database migrations
? Do you want to start Ghost? Yes
Running sudo command: systemctl is-active ghost_example-com
✔ Ensuring user is not logged in as ghost user
✔ Checking if logged in user is directory owner
✔ Checking current folder permissions
Running sudo command: systemctl is-active ghost_example-com
✔ Validating config
✔ Checking folder permissions
✔ Checking file permissions
✔ Checking content folder ownership
✔ Checking memory availability
Running sudo command: systemctl start ghost_example-com
✔ Starting Ghost
Running sudo command: systemctl is-enabled ghost_example-com
Running sudo command: systemctl enable ghost_example-com --quiet
✔ Starting Ghost
You can access your publication at https://example.com
Next, go to your admin interface at https://example.com/ghost/ to complete the setup of your publication

Ghost uses direct mail by default
To set up an alternative email method read our docs at https://docs.ghost.org/docs/mail-config

After that, open your browser and browse to the Ghost admin interface using the server hostname or IP address followed by /ghost/

💻Code
https://example.com/ghost/
Ghost setup Ubuntu
ghost setup ubuntu

To get started, click on the Create your account button to create your account and start configuring Ghost.

That should do it!

Conclusion:

This post showed you how to install Ghost CMS on Ubuntu with Nginx. Please use the comment form below if you find any errors above or have something to add.

Was this guide helpful?

Was this helpful?
Richard

About the Author

Richard

Tech Writer, IT Professional

Richard, a writer for Geek Rewind, is a tech enthusiast who loves breaking down complex IT topics into simple, easy-to-understand ideas. With years of hands-on experience in system administration and enterprise IT operations, he’s developed a knack for offering practical tips and solutions. Richard aims to make technology more accessible and actionable. He's deeply committed to the Geek Rewind community, always ready to answer questions and engage in discussions.

No comments yet — be the first to share your thoughts!

Leave a Comment

Your email address will not be published. Required fields are marked *

Exit mobile version