Files
Colinx-Blog/content/posts/个人向Linux新服务器初始化清单.md
2025-06-15 18:49:28 +08:00

447 lines
15 KiB
Markdown
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

---
title: 个人向 Linux 新服务器初始化清单
date: 2023-03-14
description: 一份 Linux 初始化清单,避免每次拿到新的服务器都要一个个去各种地方搜集指令,以做备忘 & 供有需要的朋友参考。以目前最新的 Debian 11 Bullseye 为例
categories:
- 技术
tags:
- 技术
- Linux
- Debian
---
一份 Linux 初始化清单,避免每次拿到新的服务器都要一个个去各种地方搜集指令,以做备忘 & 供有需要的朋友参考。
服务器发行版我个人推荐 Debian 系列CentOS 系现在已经开始分裂而且说实话对新手其实并不友好。Debian 是在兼容性,易用性和稳定性之间都取得不错平衡的发行版。新手推荐 Ubuntu, 不过最近商业化有点过度,夹带了越来越多的私活,我个人所有新安装的 Linux 已经全线转向 Debian. 下文以目前最新的 Debian 11 Bullseye 为例。Debian 12 bookworm 也测试通过。
> azure 干净的 debian 11 镜像,资源使用情况供参考:
>
> ~1G Disk, ~100M RAM, ~300 packages
本文仅列举主要事项和操作,新手可先行阅读这篇文章熟悉概念。[云服务器入门指南](https://blog.colinx.one/posts/%E4%BA%91%E6%9C%8D%E5%8A%A1%E5%99%A8%E5%85%A5%E9%97%A8%E6%8C%87%E5%8D%97/)
正文开始
## 1 - 基础环境搭建
### 1.1 防火墙
检查服务商防火墙和系统自带防火墙 (debian 系一般为 `ufw`, cent os 系一般为 `firewall-cmd`).放行 SSH(22), 新的 SSH(自定义), HTTP, HTTPS, 以及其他常用开发端口
### 1.2 新建用户与检查 sudoer
登录到 root 用户,创建个人账户并设定密码
```shell
// -m 创建对应home文件夹
// 添加到 sudo 用户组自动获得sudo权限, 部分发行版为wheel组
useradd -m --groups sudo colin
// 设定密码
passwd colin
```
也可直接编辑`/etc/sudoers` 文件为新用户添加 sudo 权限,使用 `visudo` 指令可以自动帮你校验,避免配置写错把系统搞崩
### 1.3 镜像源与基础软件
如为境内服务器需要更换镜像源
#### 更换国内镜像源
一般情况下,将  `/etc/apt/sources.list`  文件中 Debian 默认的源地址  `http://deb.debian.org/`  替换为  `http://mirrors.ustc.edu.cn`  即可。
```shell
//for debian
sudo sed -i 's/deb.debian.org/mirrors.ustc.edu.cn/g' /etc/apt/sources.list
//for ubuntu
sudo sed -i 's@//.*archive.ubuntu.com@//mirrors.ustc.edu.cn@g' /etc/apt/sources.list
```
CentOS 系建议启用 EPEL, PowerTools 等 repo 以更方便地安装常用软件和工具。此处不再赘述
推荐的几个国内镜像站:[清华大学 TUNA 镜像站](https://mirrors.tuna.tsinghua.edu.cn/), [中科大 USTC LUG 镜像站](https://mirrors.ustc.edu.cn/), [腾讯镜像站](https://mirrors.cloud.tencent.com/)
#### 基础软件
```shell
sudo apt update
sudo apt install wget curl git nano
sudo apt install zsh tmux htop duf htop tldr screenfetch tree
```
### 1.4 SSH 安全
修改端口,配置文件`/etc/ssh/sshd_config`. 重启机器或 sshd 服务后生效。
此外最好将`PermitRootLogin`修改为`no`, 可以禁用 root 登录。
在本机检查`~/.ssh/`有无 id_rsa 等已生成的 key. 如没有再使用 `ssh-keygen` 生成私钥
将本机的公钥上传到远端,再写入远端的 `authorized_keys`
`cat ~/id_rsa.pub >> ~/.ssh/authorized_keys`
注意修改权限,`~/.ssh/authorized_keys` 权限为 600. `~/.ssh/`为 700
可以参考以下设置
> .ssh/ 0700/rwx------
> .ssh/*.pub 644/rw-r--r--
> .ssh/* 0600/rw-------
如失败可参考这篇文章 debug. [https://superuser.com/questions/1137438/ssh-key-authentication-fails](https://superuser.com/questions/1137438/ssh-key-authentication-fails)
### 1.5 设置 hostname
可选,为了便于识别和后续配置 oh-my-zsh 更美观。这里修改完后还需要更新 hosts 设置,把刚才设置的新的主机名指向 localhost
```shell
sudo hostnamectl set-hostname my-new-server
sudo hostnamectl status
```
此外`/etc/hosts` 中默认会有个本机 hostname 映射到`127.0.0.1` 的配置,修改 host 之后这里别名的映射也要修改下,不然终端执行命令会一直弹 `sudo: unable to resolve host xxx: Name or service not known`
修改后需重启
---
### 1.6 SWAP
可选,建议内存<2G 配置 swap, 大小至少为 2 倍物理内存
推荐用 `fallocate` , 因为这个是最简单最快速的创建交换空间的方法 `fallocate`  命令用于为文件预分配块 / 大小
以下内容参考 linux.cn
使用  `fallocate`  创建交换空间首先在  `/`  目录下创建一个名为  `swap_space`  的文件然后分配 2GB  `swap_space`  文件
```shell
sudo fallocate -l 2G /swap_space
ls -lh /swap_space
// 然后更改文件权限,让 `/swap_space` 更安全:
sudo chmod 600 /swap_space
// 创建交换空间
sudo mkswap /swap_space
// 启用
sudo swapon /swap_space
// 使用 s 参数查看列表
sudo swapon -s
```
每次重启后都要重新挂载磁盘分区因此为了使之持久化就像上面一样我们编辑  `/etc/fstab`  并输入下面行
```
/swap_space swap  swap  sw  0  0
```
保存并退出文件现在我们的交换分区会一直被挂载了我们重启后可以在终端运行  `free -m`  来检查交换分区是否生效
还可以按需选择使用 zram提升内存可用量不过会略微增加 cpu 使用和内存延时可以搜索 zramctl, zramswap 等关键字
---
### 1.7 绑定域名  
可选绑定一个域名或者改下本地 host 便于后续访问
### 1.8 添加本地 SSH 别名
配置文件为本机的 `~/.ssh/config`
格式如下
```config
Host serverA
HostName myserver.domain.xyz
User colinx
Port 2333
```
## 2 - 常用工具与配置
### 2.1 Docker 环境
#### Docker 安装
可参考官网文档注意是 docker engine 的安装[Docker 官方安装文档](https://docs.docker.com/engine/install/debian/)
或者我之前写的 RSS MAN 部署文档中 docker 安装的部分
[RSS MAN X 安装部署指南/#1-docker 环境准备](https://blog.colinx.one/posts/rssmanx%E5%AE%89%E8%A3%85%E9%83%A8%E7%BD%B2%E6%8C%87%E5%8D%97/#1-docker%E7%8E%AF%E5%A2%83%E5%87%86%E5%A4%87)
#### Docker 镜像源配置及日志配置
docker mirror 配置可以加速 image pull, 国内公开可用的加速站点可以参考这里 [docker 加速站点](https://gist.github.com/y0ngb1n/7e8f16af3242c7815e7ca2f0833d3ea6)
此外服务器上的 docker 都是长时间持续运行的不少容器日志打的很随意log 文件容易占据过多空间也最好限制一下
文件位置`/etc/docker/daemon.json`, 下面的配置供参考
```json
{
"registry-mirrors": [
"https://docker.nastool.de",
"https://docker.actima.top",
"https://docker.unsee.tech",
"https://docker.gh-proxy.com",
"https://docker.zhai.cm",
"https://docker.1panel.live",
"https://docker.1ms.run",
"https://docker.imgdb.de",
"https://dockerproxy.net"
],
"log-opts": {
"max-file": "5",
"max-size": "1m"
}
}
```
修改完保存重启 docker 服务即可生效可使用 `docker info` 命令检查是否生效
### 2.2 OH-MY-ZSH
安装 OH-MY-ZSH, 在此之前确保已安装 `git` `zsh`
```shell
sh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
# 如果在墙内 github 速度不加可以考虑使用清华的镜像
# https://mirrors.tuna.tsinghua.edu.cn/help/ohmyzsh.git/
# 先下载到任意位置然后指定REMOTE 参数执行安装程序
git clone https://mirrors.tuna.tsinghua.edu.cn/git/ohmyzsh.git --depth=1
cd ohmyzsh/tools
REMOTE=https://mirrors.tuna.tsinghua.edu.cn/git/ohmyzsh.git sh install.sh
```
安装插件
```shell
git clone https://github.com/zsh-users/zsh-autosuggestions $ZSH_CUSTOM/plugins/zsh-autosuggestions --depth=1
git clone https://github.com/zsh-users/zsh-syntax-highlighting.git ${ZSH_CUSTOM:-~/.oh-my-zsh/custom}/plugins/zsh-syntax-highlighting --depth=1
```
git clone 速度不佳可以考虑一些开放的加速服务比如
- https://ghproxy.org/
- https://mirror.ghproxy.com/
按需修改配置文件位置`~/.zshrc`, 下面为个人常用配置供参考注意去源文件修改对应项没有再到末尾加
```shell
# custom conf override
ZSH_THEME="af-magic"
CASE_SENSITIVE="false"
HYPHEN_INSENSITIVE="false"
plugins=(git z zsh-autosuggestions zsh-syntax-highlighting sudo)
```
自定义配置添加到末尾
```shell
export ZSH_AUTOSUGGEST_BUFFER_MAX_SIZE=20
```
保存并应用
```shell
source ~/.zshrc
```
### 2.3 nano 代码文件规则
日常常用文本编辑器为 nano, 轻量级编辑需求完全满足
```shell
curl https://cdn.jsdelivr.net/gh/scopatz/nanorc/install.sh | sh
```
### 2.4 时区调整
一般安装完都是 UTC+0, 看日志什么的不方便服务器初始化的时候配置好后面可以免去很多麻烦
debian 系可用过 `timedatectl` 命令调整时区东八区可以用这个命令
```shell
sudo timedatectl set-timezone Asia/Shanghai
```
### 2.5 厂商监控/SDK 卸载
懂得都懂自己搜
### 2.6 fail2ban 配置
使用 fail2ban 可以很好地保护你的服务器避免被人恶意爆破 SSH 等服务
```bash
// 安装 fail2ban
sudo apt update && sudo apt install fail2ban
sudo systemctl enable fail2ban
```
之后需要按照实际情况修改一下配置文件这里记录一下最小配置注意默认的配置 `/etc/fail2ban/jail.conf`不要改不然每次软件更新会被覆盖 jaid.d 这个目录下面新建一个文件`/etc/fail2ban/jail.d/local.conf`
```conf
[sshd]
enabled = true
# 这里修改为实际的 sshd 端口
port = 20000
filter = sshd
banaction = iptables-allports
[DEFAULT]
# 1h 时间窗口
findtime = 3600
maxretry = 3
bantime = 6h
```
之后重启`sudo systemctl restart fail2ban`然后可以看下服务状态是否正常 `sudo systemctl status fail2ban`如果配置文件有问题会报错如果是显示` active (running)` 就说明没有问题了
fail2ban 的测试及关闭服务方法
查看当前封禁 IP`sudo fail2ban-client status sshd`
解禁某一 IP: `sudo fail2ban-client set sshd unbanip IP_ADDRESS`
停止 fail2ban 服务`sudo systemctl stop fail2ban`
关闭 fail2ban 服务`sudo systemctl disable fail2ban`
刚配置没一会就有 IP 被封禁了可以看到效果还是很给力也安心了不少
```
➜ sudo fail2ban-client status sshd
Status for the jail: sshd
|- Filter
| |- Currently failed: 1
| |- Total failed: 6
| `- File list: /var/log/auth.log
`- Actions
|- Currently banned: 1
|- Total banned: 1
`- Banned IP list: 154.216.19.42
```
## 3 - 进阶内容
### 3.1 内核参数调优
一些内核参数调整交换内存阈值和 bbr, tcp fast open 按需启用启用前务必确认自己了解对应字段的含义否则不如保留系统初始值
配置文件位置 `/etc/sysctl.conf`
```conf
# mem
vm.swappiness = 10
# bbr and network tune 
net.core.default_qdisc=fq
net.ipv4.tcp_congestion_control=bbr
net.ipv4.tcp_fastopen=3
net.ipv4.tcp_slow_start_after_idle=0
```
配置完之后保存并应用
```shell
sudo sysctl -p
```
### 3.2 更多内存空间 - ZRAM
ZRAM 内存压缩对于个人服务器来说始终活跃的程序占用的内存只有比较小一部分启用 zram 可以将这部分内存压缩从而可以部署更多的服务
建议使用`zramtool`, 简单方便
```shell
sudo apt install zram-tools
```
修改`/etc/default/zramswap`, 末尾添加
```ini
ALGO=zstd
PERCENT=60
```
之后执行`sudo service zramswap reload`重载生效
可以使用 swapon 命令查看生效情况
```
~ » sudo swapon -show
NAME TYPE SIZE USED PRIO
/swap_space file 2G 32.1M -2
/dev/zram0 partition 489.9M 0B 100
```
这样依赖会将机器物理内存的 50% 配置 zram, 使用 zstd 压缩算法一般压缩比能达到 3:1, 也就是说1G 的机器可以相当于有`0.5G+3*0.5G=2G`的内存
注意 Debian 新版本 swapon 等工具所在的目录 /usr/sbin 不在普通用户的 PATH 可能需要手动执行前缀使用 /usr/sbin/swapon
### 3.3 更多内存空间 - 关闭 kdump释放预留的内存空间
新服务器开起来之后你会发现无论是 htop 还是 free 等命令看到的总内存就是比你买服务器时页面上写的要小比如我开的两核 1G 的机器实际机器上看到的总内存只有 816M. 这是因为 linux 系统会默认开启 kdump预留了一部分内存不让我们使用
Kdump Linux 系统的一种内核崩溃转储机制它允许在系统发生内核崩溃例如内核 panic捕获内存的转储信息从而帮助事后分析故障原因默认的配置`2G-8G:256M,8G-16G:512M,16G-:768M`, 如果你买的是 2G 的机器上来就有 1/8 的空间用不了
但是我们个人日常使用的 linux 机器基本用不到这个功能不用预留这部分空间
操作方法有两种将预留内存改为 0 or 直接关闭 kdump 服务对于个人玩家小内存机器我建议直接关闭操作如下
```bash
# 备份grub配置文件
sudo cp /etc/default/grub /etc/default/grub.bak
# 编辑grub配置,删除 crashkernel=0M-2G:0M,2G-8G:192M 这样的部分
sudo nano /etc/default/grub
# 部分发行版镜像可能还有单独的kdump配置文件,直接删除
sudo rm /etc/default/grub.d/kdump-tools.cfg
# 更新grub配置
sudo update-grub
# 关闭并禁用Kdump服务
sudo systemctl disable kdump-tools
sudo systemctl stop kdump-tools
# 重启系统
sudo reboot
# 检查是否生效, 状态为 inactive(dead),即 kdump 服务已停止运行
sudo systemctl status kdump
# 检查 crash size 是否为0
cat /sys/kernel/kexec_crash_size
```
更多内容可以参见这篇文档[预留内存相关文档 - 阿里云](https://help.aliyun.com/zh/ecs/use-cases/view-and-change-the-size-of-reserved-memory-on-a-linux-instance#7d5ae6803amdp) 或者 [预留内存相关文档 - 腾讯云](https://cloud.tencent.com/document/product/213/115734)
### 3.3 其他进阶配置
一些其他的系统维护技巧与策略
**配置文件管理**
所有应用 docker 通过 `docker compose` 文件管理
配置共享存储`rclone` 挂载 webdav, 同步 docker compose 等配置文件;
traefik 网关作为统一出口负责服务发现和自动维护 HTTPS 证书自定义配置通过 headless CMS directus 管理traefik 设定为通过 http 方式获取远端配置即可
**数据库备份**
所有数据相关的统一挂载到`/data/database/xxx`, 配置定时任务进行备份
以及配置 s3 上传到其他存储介质和其他地域
这些内容此处不再赘述有机会再单独写篇文章分享吧
END
---
## 附录
- Install Docker Engine [https://docs.docker.com/engine/install/](https://docs.docker.com/engine/install/)
- RSSManX 安装部署指南 [https://blog.colinx.one/posts/rssmanx%E5%AE%89%E8%A3%85%E9%83%A8%E7%BD%B2%E6%8C%87%E5%8D%97/](https://blog.colinx.one/posts/rssmanx%E5%AE%89%E8%A3%85%E9%83%A8%E7%BD%B2%E6%8C%87%E5%8D%97/)
- 云服务器入门指南 [https://blog.colinx.one/posts/%E4%BA%91%E6%9C%8D%E5%8A%A1%E5%99%A8%E5%85%A5%E9%97%A8%E6%8C%87%E5%8D%97/](https://blog.colinx.one/posts/%E4%BA%91%E6%9C%8D%E5%8A%A1%E5%99%A8%E5%85%A5%E9%97%A8%E6%8C%87%E5%8D%97/)
- Portainer Install Doc [https://docs.portainer.io/start/install-ce/server/docker/linux](https://docs.portainer.io/start/install-ce/server/docker/linux)