1
0
wiki/FormalSciences/ComputerScience/OperatingSystem/Linux/4.系统管理/Linux 基本配置.md
2024-10-12 17:50:12 +08:00

12 KiB
Raw Blame History

title description keywords tags author date
Linux 基本配置 执行基本的系统管理任务、配置环境设置、以及配置网络访问和系统安全。管理用户、组和文件权限。
系统配置
用户管理
Linux/系统管理
技术/操作系统
仲平 2024-03-26

1. 网络配置

网络配置是 Linux 系统管理中的一个基础且关键的环节,它确保系统能够正确地连接到网络并进行通信。以下是网络配置的一些基本步骤和建议实践:

1.1 配置网络接口

确保正确配置网络接口,以便系统能够连接到互联网或内部网络。这通常涉及到设置静态 IP 地址或配置 DHCP 客户端。

  • 静态 IP 地址配置:编辑网络配置文件,如 /etc/network/interfaces(对于基于 Debian 的系统)或 /etc/sysconfig/network-scripts/ifcfg-<interface>(对于基于 RedHat 的系统),来设置静态 IP 地址、子网掩码、默认网关和 DNS 服务器。
  • DHCP 客户端设置:大多数现代 Linux 发行版使用 NetworkManager 或 NetworkConfig 工具来管理 DHCP。可以通过图形界面或相应的命令行工具来启用 DHCP 并配置网络接口。

1.2 配置 DNS

DNS 配置对于确保域名能够正确解析至关重要。以下是配置 DNS 的一些建议实践:

  • 使用 NetworkManager 管理 DNSNetworkManager 可以自动配置 DNS 设置,包括使用网络接口的 DHCP 配置或手动设置 DNS 服务器。
  • 手动配置 DNS:如果需要手动配置 DNS可以编辑 /etc/resolv.conf 文件来添加 DNS 服务器。此外,/etc/hosts 文件也可以用来添加静态主机名到 IP 地址的映射,这对于本地网络中的名称解析非常有用。

2. 主机配置

主机配置涉及到设置系统的基本信息,如主机名、语言和键盘布局、时区等。以下是主机配置的一些基本步骤和建议实践:

2.1 配置主机名称

主机名称是系统在网络上的身份标识,正确配置主机名称对于网络管理和故障排查非常重要。

  • 使用 hostnamectl 配置主机名hostnamectl 是一个强大的工具,可以用来查看和修改系统的主机名。使用 sudo hostnamectl set-hostname <新主机名> 命令可以直接设置新的主机名。
  • 手动编辑配置文件:也可以直接编辑 /etc/hostname 文件来更改主机名,并更新 /etc/hosts 文件以确保内部名称解析的一致性。

2.2 配置语言和键盘布局

正确的语言和键盘布局设置可以提高用户工作效率,并确保系统输出的一致性。

  • 使用 localectl 配置语言和键盘布局localectl 命令可以用来设置系统语言和键盘布局。例如,使用 sudo localectl set-locale LANG=en_US.UTF-8 设置系统语言为英语(美国),使用 sudo localectl set-keymap us 设置键盘布局为美国标准布局。
  • 手动编辑配置文件:语言和键盘布局的配置通常存储在 /etc/locale.conf/etc/vconsole.conf 文件中。可以直接编辑这些文件来设置系统语言和键盘布局。

2.3 配置时区

正确的时区设置对于系统日志、定时任务和用户活动的记录非常重要。

  • 使用 timedatectl 配置时区timedatectl 是一个用于管理日期和时间设置的工具。使用 sudo timedatectl set-timezone <时区> 命令可以设置系统时区,例如 sudo timedatectl set-timezone Asia/Shanghai 将时区设置为上海。
  • 手动链接时区文件:时区信息可以通过链接 /etc/localtime 文件到 /usr/share/zoneinfo/ 目录下的相应时区文件来设置。timedatectl 命令会自动处理这个链接的更新。

2.4 配置 NTP

网络时间协议NTP用于同步系统时钟与互联网时间服务器确保系统时间的准确性。

  • 安装并启动 NTP 服务:安装 chronydntpd 服务,并启动它们。对于 chronyd,使用 sudo systemctl start chronydsudo systemctl enable chronyd 命令;对于 ntpd,使用 sudo systemctl start ntpdsudo systemctl enable ntpd 命令。
  • 配置 NTP 服务器:在 NTP 配置文件中指定要使用的 NTP 服务器。对于 chronyd,编辑 /etc/chrony.conf 文件;对于 ntpd,编辑 /etc/ntp.conf 文件。添加 server 指令来指定 NTP 服务器地址。

2.5 配置时间同步

确保系统时间自动与选定的 NTP 服务器保持同步,这通常通过 NTP 服务的配置来自动完成。

  • 检查和手动触发同步:对于 chronyd,使用 chronyc sources 命令查看时间源状态,使用 chronyc makestep 命令手动触发立即同步。对于 ntpd,使用 ntpq -p 命令查看时间源状态。

3. 更新系统

为了确保系统的安全性和稳定性,定期更新操作系统和应用程序是非常重要的。这不仅可以修复已知的安全漏洞,还可以带来新功能和性能改进。

  • 软件源管理首先需要确保软件源repositories是最新和最可靠的
    • 对于基于 Debian 的系统,编辑 /etc/apt/sources.list 文件。
    • 对于基于 RedHat 的系统,编辑 /etc/yum.repos.d/ 目录下的文件。
  • 更新软件包列表:使用包管理器更新本地软件包数据库。
    • 对于 APT可以使用 sudo apt-get update 命令;
    • 对于 YUM可以使用 sudo yum makecache 或者 sudo dnf makecache(如果你的系统使用 DNF 作为包管理器)。
  • 更新升级系统:在更新了软件包列表之后,可以进行系统更新。
    • 对于 APT使用 sudo apt-get upgrade 命令;
    • 对于 YUM 或 DNF使用 sudo yum updatesudo dnf upgrade。这些命令会下载并安装所有可用的更新。

4. 安装基本软件和工具

  • 安装文本编辑器:选择适合的文本编辑器(如 vim、nano以便于配置文件编辑。
  • 安装网络工具:安装基础网络诊断工具(如 curl、wget、net-tools、traceroute

5. 安全设置

安全性是系统管理中的一个关键方面。以下是一些基本的安全设置步骤。

  • 设置防火墙ufwfirewalld 是两个流行的防火墙管理工具。它们可以轻松配置入站和出站规则,限制未授权访问。例如,使用 sudo ufw allow 22 来允许 SSH 连接。
  • 安装和配置安全增强工具SELinux 和 AppArmor 提供了强制访问控制,可以增强系统安全。安装后,需要根据需要配置相应的策略。
  • 定期扫描漏洞使用安全扫描工具定期检查系统漏洞。ClamAV 是一个开源的杀毒工具可以扫描恶意软件。Lynis 是一个安全审计工具,可以帮助检查系统配置和潜在的安全风险。

6. OpenSSH 通讯

OpenSSH 是 Linux 系统中用于远程管理的标准工具。以下是一些重要的 SSH 配置和安全措施。

  • 配置 SSH:安装 OpenSSH 服务后,编辑 /etc/ssh/sshd_config 文件进行配置。可以更改默认端口,配置密钥认证,禁用 root 登录等。
  • 定期更新密码:定期更新用户和 root 账户的密码,遵循强密码策略,以增加账户安全性。
  • 配置 SSH 密钥认证:密钥认证比密码认证更安全。生成密钥对,并将其添加到服务器的 ~/.ssh/authorized_keys 文件中。
  • 禁用 SSH 空密码登录:确保 SSH 配置文件中的 PermitEmptyPasswords 选项设置为 no,以防止空密码账户通过 SSH 登录。

7. 用户账户角色管理

用户账户管理是系统安全的关键部分。合理的用户和权限管理可以防止未授权的访问和潜在的安全风险。

  • 添加用户:使用 sudo addusersudo useradd 命令创建新用户。为每个任务创建专用的用户账户,避免使用 root 账户进行日常工作。
  • 用户组管理:合理地使用用户组来分配权限和管理用户权限。使用 sudo groupadd 创建新组,使用 sudo usermod -aG 将用户添加到组中。
  • root 用户管理:限制 root 账户的远程访问,只通过 sudo 提升权限。确保 root 账户有一个强密码,并定期更新。
  • 用户权限管理:通过配置 /etc/sudoers 文件或使用 visudo 命令,为特定用户分配 sudo 权限。确保遵循最小权限原则,只授予必要的权限。
  • 重置 root 密码:如果忘记 root 密码,可以使用系统救援模式或 Live CD/USB 来重置密码。这通常涉及到挂载系统分区并修改 /etc/shadow 文件。

8. 配置服务和程序

服务和程序的配置对于系统的稳定运行和性能至关重要。

  • 管理 systemd 系统服务:使用 systemctl 命令管理服务。了解不同 systemd 单元文件的存放位置和优先级,以便正确管理服务。
  • 服务自启动管理:使用 systemctl enabledisable 命令来管理服务是否在系统启动时自动运行。这有助于控制系统启动时的资源消耗。
  • 不必要服务的移除:定期审查系统服务,卸载或禁用不必要的服务和程序,以减少系统的潜在攻击面和提高系统性能。
  • 引导至救援模式:了解如何使用系统引导菜单或添加启动参数进入救援模式。这对于系统修复和故障排除非常有用。

9. 日志管理和监控

日志管理和监控对于维护系统安全和稳定运行至关重要。

  • 配置系统日志:使用 rsyslogsyslog-ng 配置日志记录规则。确保重要信息,如安全警告和系统错误,被妥善记录。
  • 安装监控工具:安装 htopiftop 等工具来监控系统资源使用情况。还可以考虑安装 nmonglances 等综合系统监控工具,以获得更全面的系统状态视图。
  • 日志分析工具:安装日志分析工具如 Logwatch 或 GoAccess这些工具可以帮助更容易地分析和理解日志文件及时发现潜在的安全威胁或系统问题。

10. 备份和恢复计划

备份和恢复计划是防止数据丢失和系统故障的关键。

  • 配置定期备份:使用 rsynctar 或定制脚本实现重要数据和配置的定期备份。考虑使用定时任务cron jobs来自动执行备份。
  • 远程备份:使用远程备份解决方案,如 rsync 配合 SSH 将备份数据同步到远程服务器,提高数据安全性。
  • 灾难恢复计划:制定并测试灾难恢复计划,确保在数据丢失或系统崩溃时能够迅速恢复。这可能包括系统镜像备份、关键数据的恢复流程等。

11. 自定义用户环境

为了提高用户的工作效率和满意度,可以对用户环境进行一些自定义设置。

  • 磁盘配额:使用 quota 工具为用户和用户组设置磁盘配额,防止单个用户占用过多磁盘空间。
  • 使用 ulimit 设置资源限制:使用 ulimit 命令为用户和进程设置资源使用限制,如打开文件的数量,以避免单个进程耗尽系统资源。
  • Shell 环境定制:根据个人偏好定制 Shell 环境,配置别名、环境变量和命令提示符。这可以通过编辑用户的 .bashrc.bash_profile.zshrc 文件来实现。
  • 安装和配置图形界面(可选):如果系统需要图形界面,安装桌面环境(如 GNOME、KDE并进行相应配置。确保图形界面的安全性例如通过配置 .xinitrc 文件来启动图形会话。

12. 系统性能优化

系统性能优化可以提高系统响应速度和处理能力,特别是在资源受限的环境中。

  • 内核参数调整:根据系统用途调整 /etc/sysctl.conf 中的内核参数。例如,可以增加 net.core.somaxconn 来提高网络性能,或者调整 fs.file-max 来增加文件系统的最大句柄数。

13. 故障转移

故障转移和灾难恢复策略对于确保业务连续性至关重要。

  • 故障转移和灾难恢复策略:制定并实施故障转移和灾难恢复策略。这可能包括设置冗余服务器、配置数据同步、以及制定在发生故障时切换到备份系统的流程。

14. 文档和记录

良好的文档和记录习惯对于系统管理和故障排除非常重要。

  • 系统配置文档化:详细记录系统配置和定制过程。这包括网络配置、安全设置、服务管理等,以便于故障排除和系统迁移。
  • 变更管理:记录所有系统变更,包括软件安装、配置修改等。这有助于追踪可能的问题来源,并在必要时回滚更改。