=============== Update the system:
sudo apt update && sudo apt upgrade -y
=============== Install required packages:
sudo apt install -y apt-transport-https ca-certificates curl gnupg lsb-release
=============== Add Docker’s GPG key:
curl -fsSL https://download.docker.com/linux/debian/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
=============== Add the Docker repository:
echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/debian $DEBIAN_CODENAME stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
=============== Update package index:
sudo apt update
=============== Install logrotate (for log management):
sudo apt install -y logrotate
=============== Configure logrotate:
cat > /etc/logrotate.d/secure2fa << 'EOF'
/root/docker/secure2fa/logs/*.log {
weekly
rotate 7
missingok
notifempty
compress
delaycompress
copytruncate
dateext
dateformat -%Y%m%d-%H%M%S
su root root
postrotate
docker restart secure2fa 2>/dev/null || true
endscript
}
EOF
=============== Install Docker Engine:
sudo apt install -y docker-ce docker-ce-cli containerd.io
=============== Add your user to the docker group:
sudo usermod -aG docker $USER
=============== Install Docker Compose (v2 is a plugin; recommended method):
sudo mkdir -p /usr/local/lib/docker/cli-plugins
sudo curl -SL "https://github.com/docker/compose/releases/download/v2.24.7/docker-compose-linux-$(uname -m)" -o /usr/local/lib/docker/cli-plugins/docker-compose
sudo chmod +x /usr/local/lib/docker/cli-plugins/docker-compose
=============== Verify Docker Compose:
docker compose version
=============== Enable Docker to start on boot:
sudo systemctl enable docker
=============== Create Secure2FA project folder:
mkdir -p /root/docker/secure2fa && cd /root/docker/secure2fa
=============== Download install script:
sudo wget https://secure2fa.top/downloads/install.sh -O install.sh && sudo chmod +x install.sh
=============== Run installation:
sudo ./install.sh
===============Configure project settings:
=============== Run container:
docker compose up -d
=============== Check container status:
docker ps -a | grep secure2fa
The output should be similar to:
89c064b80a8d registry.secure2fa.top/2fa-rdg-prod_2fa-rdg:latest "/entrypoint.sh" 21 minutes ago Up About a minute (healthy) 0.0.0.0:80->80/tcp, [::]:80->80/tcp, 0.0.0.0:443->443/tcp, [::]:443->443/tcp, 0.0.0.0:1812-1813->1812-1813/udp, [::]:1812-1813->1812-1813/udp, 8443/tcp secure2fa