Server Guides: Difference between revisions

From Irregularpedia
Jump to navigation Jump to search
Line 4: Line 4:


* [[matrix-server-guide|Matrix Server Guide]]
* [[matrix-server-guide|Matrix Server Guide]]
* [[ssh-keys|Create SSH Keys]]
** Maubot Chatbot Guides
* SimpleX Server
* [[Service%20-%20storage%20-%20Nextcloud|Service - Storage - Nextcloud]]
* [[Service%20-%20storage%20-%20Nextcloud|Service - Storage - Nextcloud]]
* [[Authentik%20Installation|Authentik Installation]]
* [[Authentik%20Installation|Authentik Installation]]
* [[setting%20up%20cryptpad%20server|Setting Up Cryptpad Server]]
* [[setting%20up%20cryptpad%20server|Setting Up Cryptpad Server]]
* Proxmox
* Proxmox
* Clapper


== Best Practices to Secure Servers in 2024 ==
== Best Practices to Secure Servers in 2024 ==
Line 20: Line 22:


* '''No Root Login''': Disable root login to enhance security.
* '''No Root Login''': Disable root login to enhance security.
* '''SSH Keys with Password''': Use SSH keys with a passphrase and disable password login.
* '''[[SSH Keys]] with Password''': Use SSH keys with a passphrase and disable password login.
* '''VPN Access''': VPN access is required to reach the SSH server.
* '''VPN Access''': VPN access is required to reach the SSH server.
* '''Firmware and Auto Updates''': Enable automatic updates for both firmware and software.
* '''Firmware and Auto Updates''': Enable automatic updates for both firmware and software.
Line 34: Line 36:


* '''Data Encryption''': Encrypt all data communication.
* '''Data Encryption''': Encrypt all data communication.
** Use ''scp'', ''ssh'', ''rsync'', or ''sftp'' for file transfer.
** Use ''scp'', ''ssh'', ''rsync'', rclone or ''sftp'' for file transfer.
** Consider reverse proxy (tail scale, Cloudflare) or wireguard.
** Consider reverse proxy (tail scale, Cloudflare) or wireguard.
* '''Service Management''':
* '''Service Management''':

Revision as of 03:43, 21 November 2024

Server Guides

Community Server Guides

Best Practices to Secure Servers in 2024

Source:

General Security Practices

  • No Root Login: Disable root login to enhance security.
  • SSH Keys with Password: Use SSH keys with a passphrase and disable password login.
  • VPN Access: VPN access is required to reach the SSH server.
  • Firmware and Auto Updates: Enable automatic updates for both firmware and software.
  • Firewall: Configure a firewall to control incoming and outgoing traffic.
  • Regular Updates: Ensure the server and all software are regularly updated.
  • Split Disks: Separate /tmp and /var partitions with noexec flag.
  • Log Monitoring: Regularly monitor server logs for suspicious activities.
  • Privilege Escalation Mitigation: Use sysctl variables and kernel parameters to mitigate privilege escalation.
  • Audit: Regularly audit the server using tools like rkhunter and debsecan.
  • Open Ports: Only open necessary ports (e.g., 80, 443, 22).

Detailed Security Measures

  • Data Encryption: Encrypt all data communication.
    • Use scp, ssh, rsync, rclone or sftp for file transfer.
    • Consider reverse proxy (tail scale, Cloudflare) or wireguard.
  • Service Management:
    • Avoid using insecure services like FTP, Telnet, and Rsh.
    • Minimize installed software to reduce vulnerability.
  • Kernel and Software Updates:
    • Apply all security patches promptly.
      • Use an Ansible Script to patch multiple servers periodically including OS, docker, git, etc
  • Linux Security Extensions:
    • Enable SELinux or other security extensions to enforce limitations on applications.
  • User Accounts and Password Policies:
    • Enforce strong password policies.
    • Use tools like pam_cracklib to enforce password strength.
    • Set up password aging policies using chage.
  • Fail2ban:
    • Install and configure Fail2ban to block IP addresses after failed login attempts.
  • Disable Unwanted Services:
    • Disable unnecessary services and daemons.
    • Use systemctl to manage services on modern Linux distributions.
  • Network Security:
    • Use iptables or firewalld to manage firewall rules.
    • Use tools like nmap to scan open ports.
  • File System Security:
    • Separate critical file systems into different partitions with appropriate mount options (noexec, nodev, nosuid).
  • Regular Backups:
    • Implement regular, encrypted backups to an offsite location.
  • Intrusion Detection Systems (IDS):
    • Use tools like AIDE and RKHunter for host-based intrusion detection.
  • Secure SSH Configuration:
    • Configure SSH for maximum security (e.g., disabling root login, using SSH keys, configuring Fail2ban).