
How to Install Directus on Ubuntu 24.04 • Linux & Open Source
A Headless CMS (Content Management System) is a content management system that separates the backend from the frontend. Unlike traditional CMS platforms (such as WordPress or Joomla), which combine content with the web display, a headless CMS provides only a backend for managing content and an API to access it. The frontend, or display, is entirely separate and can be developed using any technology, such as JavaScript, mobile applications, or even IoT platforms. Headless CMSs are popular among developers due to their flexibility and ability to integrate content across various platforms and devices.
Directus is an open-source headless CMS based on Node.js. Its main advantages are flexibility and ease of use for building modern content management systems. This platform not only provides a user-friendly admin interface but also supports GraphQL and REST APIs, making data access convenient for any frontend application.
With Directus, you can create various types of applications, including:
- Dynamic websites and blogs
- Content-based mobile applications
- Internal applications for company data management
- Community portals or simple CRM systems
Install Directus
Directus is installed on top of Docker containers. Install Docker and Docker Compose first if they are not yet available:
sudosh–c“curl -fsSL | sh” |
Create a directory to store the Directus project:
mkdirdirectus cddirectus |
Creating the required directory:
mkdirmariadb_datadatabase_datauploads_dataextensions_data |
Create a docker-compose.yml
file:
Enter the configuration:
directus:
image: directus/directus:11.1.1
container_name: directus
environment:
SECRET: “randomstringsecretkey”
ADMIN_EMAIL: “admin@example.com”
ADMIN_PASSWORD: “rahasia”
DB_CLIENT: “mysql”
DB_HOST: “mariadb”
DB_PORT: “3306”
DB_DATABASE: “directus”
DB_USER: “directus”
DB_PASSWORD: “rahasia”
WEBSOCKETS_ENABLED: “true”
PUBLIC_URL: ”
ports:
– 8055:8055
volumes:
– database_data:/directus/database
– uploads_data:/directus/uploads
– extensions_data:/directus/extensions
depends_on:
– mariadb
networks:
– directus
networks:
directus:
volumes:
mariadb_data:
database_data:
uploads_data:
extensions_data:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 |
services:  Âmariadb:    Âimage:mariadb:10.6    Âcontainer_name:mariadb    Âenvironment:      ÂMYSQL_ROOT_PASSWORD:rahasia      ÂMYSQL_DATABASE:directus      ÂMYSQL_USER:directus      ÂMYSQL_PASSWORD:rahasia    Âvolumes:      –mariadb_data:/var/lib/mysql    Ânetworks:      –directus   Âdirectus:    Âimage:directus/directus:11.1.1    Âcontainer_name:directus    Âenvironment:      ÂSECRET:“randomstringsecretkey”      ÂADMIN_PASSWORD:“rahasia”      ÂDB_CLIENT:“mysql”      ÂDB_HOST:“mariadb”      ÂDB_PORT:“3306”      ÂDB_DATABASE:“directus”      ÂDB_USER:“directus”      ÂDB_PASSWORD:“rahasia”      ÂWEBSOCKETS_ENABLED:“true”      ÂPUBLIC_URL:“    Âports:      –8055:8055    Âvolumes:      –database_data:/directus/database      –uploads_data:/directus/uploads      –extensions_data:/directus/extensions    Âdepends_on:      –mariadb    Ânetworks:      –directus  networks:  Âdirectus:  volumes:  Âmariadb_data:  Âdatabase_data:  Âuploads_data:  Âextensions_data: |
The docker-compose.yml configuration above will create MariaDB and Directus containers.
Run docker-compose to start building the container:
sudodocker–composeup–d |
After the process is complete, Directus can be accessed at http://localhost:8055. Log in using the email and password that you have set in the docker-compose.yml.
caleg24
Berita Olahraga
News
Berita Terkini
Berita Terbaru
Berita Teknologi
Seputar Teknologi
Drama Korea
Resep Masakan
Pendidikan
Berita Terbaru
Berita Terbaru
Berita Terbaru