Size: 288
Comment:
|
Size: 5352
Comment:
|
Deletions are marked like this. | Additions are marked like this. |
Line 1: | Line 1: |
Describe DebianChecklist here. | Chris Lamb has a good [[http://www.chris-lamb.co.uk/2009/06/03/checklist-configuring-debian-system/|Debian installation checklist]], from which I stole most of this list. |
Line 5: | Line 5: |
# Enable log compression with date postfix'd extension cat /etc/logrotate.conf | sed "s/#compress/compress/" > /etc/logrotate.conf.tmp echo "dateext" >> /etc/logrotate.conf.tmp |
# Configure sudo, adding my user to the sudo group so I don't get password prompts apt install sudo adduser xjjk sudo echo '%sudo ALL=(ALL) NOPASSWD: ALL' > /etc/sudoers.d/No-Passwords-for-sudo-Group chmod 0440 /etc/sudoers.d/No-Passwords-for-sudo-Group # Disable installation of recommended packages echo 'APT::Install-Recommends "false";' > /etc/apt/apt.conf.d/90recommends # Configure locales to prevent harassment about it later apt install locales export LANGUAGE=en_US.UTF-8 export LANG=en_US.UTF-8 export LC_ALL=en_US.UTF-8 locale-gen en_US.UTF-8 dpkg-reconfigure -plow locales # …or install all locales so they don't need to be configured/reinstalled apt install locales-all # Enable log compression with date suffixed extension cat /etc/logrotate.conf | sed "s/#compress/compress\ndateext/" > /etc/logrotate.conf.tmp |
Line 9: | Line 27: |
# Disable root login—public key access only! sed -i \ -e "s/[#]*PermitRootLogin yes/PermitRootLogin without-password/g" \ -e "s/AcceptEnv LANG LC_\*$/AcceptEnv LANG LC_\* TZ/" \ /etc/ssh/sshd_config service ssh restart # Prevent PAM from allowing easily-crackable passwords apt install libpam-cracklib # Install essential utilities sudo apt install \ openssh-server screen \ rsync \ atool lzma rzip xz-utils \ htop dstat iotop \ manpages manpages-dev \ strace tcpdump lsof \ less moreutils \ mosh \ dnsutils \ vim vim-pathogen vim-addon-manager vim-scripts \ bash-completion \ sysfsutils procps \ vnstat \ unattended-upgrades \ ncurses-term \ molly-guard # Optional stuff… sudo apt install \ chrony \ cpufrequtils powertop # Ensure enough entropy is always available sudo apt install \ haveged rng-tools # I hate rm sudo apt install \ trash-cli # Reduce bufferbloat echo 'net.core.default_qdisc=fq_codel' > /etc/sysctl.d/reduce-bufferbloat.conf # Enable automatic security updates (careful!) sudo DEBIAN_FRONTEND=noninteractive dpkg-reconfigure -plow unattended-upgrades # HDD Temperature/SMART monitoring utilities apt install hddtemp smartmontools sed -i 's/^#start_smartd=yes/start_smartd=yes/' /etc/default/smartmontools /etc/init.d/smartmontools start # Configure rsyslog for daily archival logging cat << EOF > /etc/rsyslog.d/51-cron.conf # Enable cron logging cron.* /var/log/cron.log EOF cat << EOF > /etc/rsyslog.d/99-archive.conf \$template DailyLogs,"/var/log/archive/%\$YEAR%%\$MONTH%/%\$YEAR%%\$MONTH%%\$DAY%.log" # Archive logging *.* -?DailyLogs EOF cat << EOF > /etc/cron.daily/rsyslog-archive #!/bin/sh # Compress *.log-files not changed in more than 24 hours find /var/log/archive -type f -mtime +1 -name "*.log" -exec xz '{}' \; EOF chmod +x /etc/cron.daily/rsyslog-archive # Async logging for rsync (commit every 30m) cat << EOF > /etc/rsyslog.d/98-async.conf \$OMFileFlushInterval 1800 \$OMFileASyncWriting on EOF # Use tmpfs for /var/run and /var/lock (may break some buggy packages), like Ubuntu cat << EOF >> /etc/default/rcS RAMRUN=yes RAMLOCK=yes EOF # Allow running X11 apps remotely sudo apt install xbase-clients # Add noatime,commit=900 to entries in /etc/fstab # Enable SATA ALPM echo SATA_ALPM_ENABLE=true | sudo tee /etc/pm/config.d/sata_alpm # Switch to systemd sudo apt install systemd-sysv libpam-systemd |
|
Line 10: | Line 121: |
Other sources: https://feeding.cloud.geek.nz/posts/usual-server-setup/ == New account setup == === Remote === {{{#!highlight sh # Quiet login touch .hushlogin cd ~ mkdir -p .ssh/controls mkdir -p .vim/tmp chmod -R 755 .ssh chmod 644 .ssh/authorized_keys }}} === Locally === {{{#!highlight sh # Setup dot files mkdir -p ~/src/git.other/ cd ~/src/git.other/ git clone https://github.com/samatjain/dotfiles.git cd dotfiles source init-dots dots groups set base # Set addtl groups as necessary dots install }}} === Raspberry Pi stuff === {{{#!highlight sh # Switch from wheezy to testing cd /etc/apt/ sed -i 's/wheezy/testing/g' /etc/apt/sources.list #sudo find . -type f -exec sed -i 's/wheezy/testing/g' {} \; # Disable tty2–tty6 sed -i '/[2-6]:23:respawn:\/sbin\/getty 38400 tty[2-6]/s%^%#%g' /etc/inittab # Disable tty on serial line sed -i '/T0:23:respawn:\/sbin\/getty -L ttyAMA0 115200 vt100/s%^%#%g' /etc/inittab # Optimize mounts sed -i 's/defaults,noatime/defaults,noatime,nodiratime/g' /etc/fstab # Overclock to 800 Mhz (no overvolting required). Overclocking not forced, but keep it on for the first 2 min during boot echo -e "arm_freq=800\nsdram_freq=400\ncore_freq=300\nforce_turbo=0\ninitial_turbo=120" >> /boot/config.txt # Use only 16 MiB for GPU (only run after updating firmware!) echo -e "gpu_mem=16" >> /boot/config.txt # Enable IPv6 for Avahi sudo sed -i 's/mdns4_minimal/mdns_minimal/g' /etc/nsswitch.conf # Delete default 'pi' user sudo deluser --remove-all-files pi }}} Some of these are from [[https://extremeshok.com/1081/raspberry-pi-raspbian-tuning-optimising-optimizing-for-reduced-memory-usage/|Raspberry Pi Raspbian tuning / optimising / optimizing for reduced memory usage]] |
Chris Lamb has a good Debian installation checklist, from which I stole most of this list.
1 # Configure sudo, adding my user to the sudo group so I don't get password prompts
2 apt install sudo
3 adduser xjjk sudo
4 echo '%sudo ALL=(ALL) NOPASSWD: ALL' > /etc/sudoers.d/No-Passwords-for-sudo-Group
5 chmod 0440 /etc/sudoers.d/No-Passwords-for-sudo-Group
6
7 # Disable installation of recommended packages
8 echo 'APT::Install-Recommends "false";' > /etc/apt/apt.conf.d/90recommends
9
10 # Configure locales to prevent harassment about it later
11 apt install locales
12 export LANGUAGE=en_US.UTF-8
13 export LANG=en_US.UTF-8
14 export LC_ALL=en_US.UTF-8
15 locale-gen en_US.UTF-8
16 dpkg-reconfigure -plow locales
17 # …or install all locales so they don't need to be configured/reinstalled
18 apt install locales-all
19
20 # Enable log compression with date suffixed extension
21 cat /etc/logrotate.conf | sed "s/#compress/compress\ndateext/" > /etc/logrotate.conf.tmp
22 mv /etc/logrotate.conf.tmp /etc/logrotate.conf
23
24 # Disable root login—public key access only!
25 sed -i \
26 -e "s/[#]*PermitRootLogin yes/PermitRootLogin without-password/g" \
27 -e "s/AcceptEnv LANG LC_\*$/AcceptEnv LANG LC_\* TZ/" \
28 /etc/ssh/sshd_config
29 service ssh restart
30
31 # Prevent PAM from allowing easily-crackable passwords
32 apt install libpam-cracklib
33
34 # Install essential utilities
35 sudo apt install \
36 openssh-server screen \
37 rsync \
38 atool lzma rzip xz-utils \
39 htop dstat iotop \
40 manpages manpages-dev \
41 strace tcpdump lsof \
42 less moreutils \
43 mosh \
44 dnsutils \
45 vim vim-pathogen vim-addon-manager vim-scripts \
46 bash-completion \
47 sysfsutils procps \
48 vnstat \
49 unattended-upgrades \
50 ncurses-term \
51 molly-guard
52
53 # Optional stuff…
54 sudo apt install \
55 chrony \
56 cpufrequtils powertop
57
58 # Ensure enough entropy is always available
59 sudo apt install \
60 haveged rng-tools
61
62 # I hate rm
63 sudo apt install \
64 trash-cli
65
66 # Reduce bufferbloat
67 echo 'net.core.default_qdisc=fq_codel' > /etc/sysctl.d/reduce-bufferbloat.conf
68
69 # Enable automatic security updates (careful!)
70 sudo DEBIAN_FRONTEND=noninteractive dpkg-reconfigure -plow unattended-upgrades
71
72 # HDD Temperature/SMART monitoring utilities
73 apt install hddtemp smartmontools
74 sed -i 's/^#start_smartd=yes/start_smartd=yes/' /etc/default/smartmontools
75 /etc/init.d/smartmontools start
76
77 # Configure rsyslog for daily archival logging
78 cat << EOF > /etc/rsyslog.d/51-cron.conf
79 # Enable cron logging
80 cron.* /var/log/cron.log
81 EOF
82 cat << EOF > /etc/rsyslog.d/99-archive.conf
83 \$template DailyLogs,"/var/log/archive/%\$YEAR%%\$MONTH%/%\$YEAR%%\$MONTH%%\$DAY%.log"
84 # Archive logging
85 *.* -?DailyLogs
86 EOF
87 cat << EOF > /etc/cron.daily/rsyslog-archive
88 #!/bin/sh
89 # Compress *.log-files not changed in more than 24 hours
90 find /var/log/archive -type f -mtime +1 -name "*.log" -exec xz '{}' \;
91 EOF
92 chmod +x /etc/cron.daily/rsyslog-archive
93
94 # Async logging for rsync (commit every 30m)
95 cat << EOF > /etc/rsyslog.d/98-async.conf
96 \$OMFileFlushInterval 1800
97 \$OMFileASyncWriting on
98 EOF
99
100 # Use tmpfs for /var/run and /var/lock (may break some buggy packages), like Ubuntu
101 cat << EOF >> /etc/default/rcS
102 RAMRUN=yes
103 RAMLOCK=yes
104 EOF
105
106 # Allow running X11 apps remotely
107 sudo apt install xbase-clients
108
109 # Add noatime,commit=900 to entries in /etc/fstab
110
111 # Enable SATA ALPM
112 echo SATA_ALPM_ENABLE=true | sudo tee /etc/pm/config.d/sata_alpm
113
114 # Switch to systemd
115 sudo apt install systemd-sysv libpam-systemd
Other sources:
https://feeding.cloud.geek.nz/posts/usual-server-setup/
New account setup
Remote
Locally
Raspberry Pi stuff
1 # Switch from wheezy to testing
2 cd /etc/apt/
3 sed -i 's/wheezy/testing/g' /etc/apt/sources.list
4 #sudo find . -type f -exec sed -i 's/wheezy/testing/g' {} \;
5
6 # Disable tty2–tty6
7 sed -i '/[2-6]:23:respawn:\/sbin\/getty 38400 tty[2-6]/s%^%#%g' /etc/inittab
8 # Disable tty on serial line
9 sed -i '/T0:23:respawn:\/sbin\/getty -L ttyAMA0 115200 vt100/s%^%#%g' /etc/inittab
10
11 # Optimize mounts
12 sed -i 's/defaults,noatime/defaults,noatime,nodiratime/g' /etc/fstab
13
14 # Overclock to 800 Mhz (no overvolting required). Overclocking not forced, but keep it on for the first 2 min during boot
15 echo -e "arm_freq=800\nsdram_freq=400\ncore_freq=300\nforce_turbo=0\ninitial_turbo=120" >> /boot/config.txt
16
17 # Use only 16 MiB for GPU (only run after updating firmware!)
18 echo -e "gpu_mem=16" >> /boot/config.txt
19
20 # Enable IPv6 for Avahi
21 sudo sed -i 's/mdns4_minimal/mdns_minimal/g' /etc/nsswitch.conf
22
23 # Delete default 'pi' user
24 sudo deluser --remove-all-files pi
Some of these are from Raspberry Pi Raspbian tuning / optimising / optimizing for reduced memory usage