====== Setup ====== ===== Server Setup ===== * Login to the server via SSH as root * Install sudo, create the main user, and add him to the sudoers group# apt install sudo # adduser # vi /etc/group (add to line "sudo:x:27:") * (VPS) change the machine name:sudo edit /etc/hostname sudo edit /etc/hosts * enable //force_color_prompt=yes// in file ''~/.bashrc'' * copy ''/home/user/.bashrc'' to ''/root'' and modify PS1 prompt color (//32m// --> //31m//) ===== Security ===== * Configure [[deb9:ssh|SSH Access]] * Install [[deb9:ufw|UFW Firewall]] * Disable root login by changing file ''/etc/passwd'' from line 1 to line 2root:x:0:0:root:/root:/bin/bash root:x:0:0:root:/root:/sbin/nologin ===== Install and configure packages ===== * Additional packages$ sudo apt update $ sudo apt install vim $ sudo apt install zip $ sudo apt install rename $ sudo apt install rsync $ sudo apt install openjdk-17-jre openjdk-17-jdk * Change visudo editor$ sudo update-alternatives --config editor ===== Upgrade linux headers ===== * Check remaining space on the boot partition with:df -h | grep "^/dev/" * Remove outdated kernel packages:sudo apt-get autoremove * First check your kernel version, so you won't delete the in-use kernel image, running:uname -r * Delete the kernels you don't want/need anymore by running this:sudo apt-get remove linux-image-VERSION * Update grub kernel list:sudo update-grub ===== System Startup ===== Debian 11 uses Systemd, not SysV, that's why your commands in ''/etc/rc.local'' file would not run at system boot time. This guide explains how to enable ''/etc/rc.local'' script to run on system startup. - Create a rc.local unit file, follow [[deb10:rclocal|Services - rc.local]] - Create file rc.local in /etc with the following content:vim /etc/rc.local #!/bin/sh -e # # rc.local # # This script is executed at the end of each multiuser runlevel. # Make sure that the script will "exit 0" on success or any other # value on error. # # In order to enable or disable this script just change the execution # bits. # # By default this script does nothing. exit 0 - Add execute permissions and start daemon:chmod +x /etc/rc.local systemctl daemon-reload systemctl start rc-local systemctl status rc-local ● rc-local.service - /etc/rc.local Compatibility Loaded: loaded (/lib/systemd/system/rc-local.service; static; vendor preset: Drop-In: /lib/systemd/system/rc-local.service.d └─debian.conf Active: active (exited) since Sun 2019-05-05 10:55:29 +07; 11min ago Process: 1443 ExecStart=/etc/rc.local start (code=exited, status=0/SUCCESS) Tasks: 0 (limit: 4915) CGroup: /system.slice/rc-local.service * [[https://www.linuxbabe.com/linux-server/how-to-enable-etcrc-local-with-systemd|How to Enable /etc/rc.local with Systemd]] * [[https://stackoverflow.com/questions/44797694/where-is-rc-local-in-debian-9-debian-stretch|Where is rc.local in Debian 9 (Debian Stretch)]] ===== System Shutdown ===== - Put a symbolic link to the script to be run at shutdown into /lib/systemd/system-shutdown * [[https://unix.stackexchange.com/questions/347306/how-to-execute-scripts-in-usr-lib-systemd-system-shutdown-at-reboot-or-shutdow|How to execute scripts in /usr/lib/systemd/system-shutdown/ at reboot or shutdown?]] * [[https://opensource.com/life/16/11/running-commands-shutdown-linux|How to run commands at shutdown on Linux]]