Tired of tedious post-installation checklists for your Debian or Ubuntu servers? This tutorial introduces DebPostInstall, a Bash script designed to automate essential post-installation tasks, saving you time and effort. Whether you're a Linux novice or a seasoned sysadmin, DebPostInstall simplifies server setup.
This guide will walk you through using DebPostInstall to quickly configure a secure and optimized Debian-based server. Let's begin!
Table of Contents
- Understanding the Script's Functionality
- Automating Crucial Post-Installation Steps with DebPostInstall
- Verifying Successful Post-Installation
- Conclusion
DebPostInstall: Your Automated Debian/Ubuntu Post-Installation Solution
DebPostInstall is a concise Bash script automating key post-installation procedures on minimal Debian or Ubuntu servers. These automated tasks include:
- Creating a new user with
sudo
privileges. - Adding a public SSH key for secure remote access.
- Disabling password authentication and root login for enhanced security.
- Configuring the Uncomplicated Firewall (UFW) for robust server protection.
- Creating a swap file to boost system performance.
- Setting the timezone and enabling time synchronization for accurate timekeeping.
While manual configuration is possible, DebPostInstall streamlines this process significantly.
Here's the script's code:
#!/usr/bin/env bash # ------------------------------------------------------------------# Script Name: DebPostInstall # Description: Automates essential post-installation tasks on Debian/Ubuntu # Website: [Link to GitHub Gist or similar] # Version: 1.0 # Usage: sudo ./debpostinstall.sh # ------------------------------------------------------------------# System Update echo "Updating the system..." apt-get update && apt-get full-upgrade -y apt-get autoremove -y && apt-get autoclean -y # Install Essential Packages echo "Installing necessary packages..." apt-get install -y sudo openssh-server ufw systemd-timesyncd vim htop net-tools curl wget git # New User Setup read -p "Enter the new user's username: " USERNAME # ... (rest of the script remains the same as in the original input) ...
This script is open-source and can be freely modified and distributed. Feel free to customize it to meet your specific requirements.
Understanding the Script's Functionality
The script's functionality is broken down into logical sections:
-
Shebang:
#!/usr/bin/env bash
specifies Bash as the interpreter. -
System Update: Updates and upgrades packages using
apt-get
. -
Package Installation: Installs essential packages like
openssh-server
,ufw
, and others. -
User Creation: Prompts for a username and password, creating a new user with
sudo
access. - SSH Key Addition: Prompts for a public SSH key and adds it to the authorized_keys file, ensuring secure access.
- Security Hardening: Disables password authentication and root login for enhanced security.
- Firewall Configuration: Configures UFW, allowing SSH access.
- Swap File Creation: Creates a swap file based on system memory.
- Timezone and Time Synchronization: Sets the timezone and enables time synchronization.
Each section performs a specific task, contributing to a secure and well-configured server.
Automating Crucial Post-Installation Steps with DebPostInstall
Before running the script:
- Generate an SSH key pair on your local machine using
ssh-keygen
. - Copy the public key (
id_ed25519.pub
).
Next, log into your server, save the DebPostInstall
script (e.g., as debpostinstall.sh
), and make it executable: chmod x debpostinstall.sh
.
Run the script using sudo ./debpostinstall.sh
. The script will guide you through the process, prompting for the username, public SSH key, and timezone. Remember to reboot your server after completion.
Verifying Successful Post-Installation
After running the script and rebooting, verify the changes:
-
User Verification:
getent passwd <username></username>
-
Sudo Access:
groups <username></username>
-
SSH Key:
ls -ld ~/.ssh/
,ls -l ~/.ssh/authorized_keys
-
Password Authentication:
grep "PasswordAuthentication no" /etc/ssh/sshd_config
-
Root Login:
grep "PermitRootLogin no" /etc/ssh/sshd_config
-
UFW Status:
sudo ufw status
-
Swap File:
sudo swapon --show
-
/etc/fstab
:grep "/swapfile" /etc/fstab
-
Timezone:
timedatectl | grep "Time zone"
-
Time Synchronization:
sudo systemctl status systemd-timesyncd
Conclusion
DebPostInstall simplifies Debian/Ubuntu server setup by automating crucial post-installation tasks. By using this script, you can significantly reduce the time and effort required to configure a secure and efficient server environment. Remember to customize the script to fit your specific needs and always verify the changes after running it.
The above is the detailed content of DebPostInstall: Debian And Ubuntu Server Post Install Script. For more information, please follow other related articles on the PHP Chinese website!

LinuxandWindowsmanagememorydifferentlyduetotheirdesignphilosophies.Linuxusesovercommittingforbetterperformancebutrisksout-of-memoryerrors,whileWindowsemploysdemand-pagingandmemorycompressionforstabilityandefficiency.Thesedifferencesimpactdevelopmenta

Linux systems rely on firewalls to safeguard against unauthorized network access. These software barriers control network traffic, permitting or blocking data packets based on predefined rules. Operating primarily at the network layer, they manage

Determining if your Linux system is a desktop or laptop is crucial for system optimization. This guide outlines simple commands to identify your system type. The hostnamectl Command: This command provides a concise way to check your system's chassis

Guide to adjust the number of TCP/IP connections for Linux servers Linux systems are often used in servers and network applications. Administrators often encounter the problem that the number of TCP/IP connections reaches the upper limit, resulting in user connection errors. This article will guide you how to improve the maximum number of TCP/IP connections in Linux systems. Understanding TCP/IP connection number TCP/IP (Transmission Control Protocol/Internet Protocol) is the basic communication protocol of the Internet. Each TCP connection requires system resources. When there are too many active connections, the system may reject new connections or slow down. By increasing the maximum number of connections allowed, server performance can be improved and more concurrent users can be handled. Check the current number of Linux connections limits Change settings

SVG (Scalable Vector Graphics) files are ideal for logos and illustrations due to their resizability without quality loss. However, PNG (Portable Network Graphics) format often offers better compatibility with websites and applications. This guide d

LiveCode: A Cross-Platform Development Revolution LiveCode, a programming language debuting in 1993, simplifies app development for everyone. Its high-level, English-like syntax and dynamic typing enable the creation of robust applications with ease

This guide provides a step-by-step process for resetting a malfunctioning USB device via the Linux command line. Troubleshooting unresponsive or disconnected USB drives is simplified using these commands. Step 1: Identifying Your USB Device First, i

Temporarily setting a static IP address on Linux is invaluable for network troubleshooting or specific session configurations. This guide details how to achieve this using command-line tools, noting that the changes are not persistent across reboots


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Dreamweaver CS6
Visual web development tools

WebStorm Mac version
Useful JavaScript development tools

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),
