成为系统管理员,你需要知道什么

通过掌握这些最低限度的能力来开启您的系统管理员职业生涯。
176 位读者喜欢这个。
Avoiding data disasters with Sanoid

Opensource.com

昨天的系统管理员整天周旋于用户和服务器之间,并在早晚之间花费数百米的时间铺设数百根电缆。今天仍然如此,但增加了云计算、容器和虚拟机的复杂性。

从外部来看,很难准确指出系统管理员到底是做什么的,因为他们在很多地方都扮演着至少很小的角色。没有人一开始就知道一份工作所需的一切,但每个人都需要一个坚实的基础。如果您想开始系统管理之路,以下是您应该在个人或正式培训中关注的内容。

Bash

当您学习 Bash shell 时,您不仅仅是在学习 Bash shell。您学习的是 Linux 系统、BSD、MacOS 甚至 Windows(在合适的条件下)的通用接口。您学习语法的重要性,以便您可以快速适应 Cisco 路由器的命令行或 Microsoft 的 PowerShell 等系统,最终,您甚至可以学习更强大的语言,如 Python 或 Go。并且您也开始以程序化的方式思考,以便您可以分析复杂的问题并将其分解为各个组件,这很关键,因为互联网、组织的内网、Web 服务器或备份解决方案等系统就是这样设计的。

但是等等。还有更多。

了解 Bash shell 变得尤为重要,因为最近 DevOps 和容器的趋势。您作为系统管理员的职业生涯可能会将您带入一个基础设施被视为代码的世界,这通常意味着您必须了解脚本编写的基础知识、基于 YAML 的配置结构,以及如何与交互容器(在沙箱文件中运行的微型 Linux 系统)。 了解 Bash 是高效管理最激动人心的开源技术的门户,所以去 Bourne Again 吧。

资源

有很多方法可以练习 Bash shell。

尝试 便携式 Linux 发行版。您不必安装 Linux 即可使用 Linux,所以拿一个备用 U 盘,花您的晚上或周末时间来熟悉基于文本的界面。

在 opensource.com 以及 Enable SysAdmin 上有几篇优秀的 Bash 文章

告诉别人练习 Bash 的问题在于,要练习,您必须有事可做。在您知道如何使用 Bash 之前,您可能想不出任何事情要做。如果那是您的情况,请访问 Over The Wire 并玩 Bandit。这是一个针对绝对初学者的游戏,包含 34 个级别的交互式基础黑客技术,让您熟悉 Linux shell。

Web 服务器设置

一旦您熟悉了 Bash,您应该尝试设置 Web 服务器。并非所有系统管理员都会设置 Web 服务器,甚至维护 Web 服务器,但是您在安装和启动 HTTP 守护程序、配置 Apache 或 Nginx、设置正确的权限以及配置防火墙时获得的技能是您日常需要的技能。经过一点努力,您可能会开始注意到您劳动中的某些模式。在尝试管理生产就绪的软件和硬件之前,您可能认为某些概念是理所当然的,并且您不再在新手的管理员角色中免受它们的干扰。起初可能会令人沮丧,因为每个人都希望擅长他们所做的一切,但这实际上是一件好事。让自己不擅长新技能。这就是您学习的方式。

此外,您在最初的步骤中挣扎得越多,当您最终看到令人振奋的“它工作了!”默认 index.html 时,它就越甜蜜。

资源

David Both 写了一篇关于 Apache Web 服务器 配置的优秀文章。为了获得额外的学分,请逐步阅读他的后续文章,了解如何在一台机器上托管多个站点

DHCP

动态主机配置协议 (DHCP) 是将 IP 地址分配给网络上设备的系统。在家里,您的 ISP(互联网服务提供商)支持的调制解调器或路由器可能内置了 DHCP 服务器,因此它可能超出您的范围。如果您曾经登录到您的家用路由器以调整 IP 地址范围或为您的某些网络设备设置静态地址,那么您至少对这个概念有些熟悉。您可能理解网络上的设备被分配了相当于电话号码的 IP 地址,并且您可能意识到计算机通过广播发送到特定 IP 地址的消息来相互通信。消息标头由路径上的路由器读取,每个路由器都致力于将消息定向到路径上通往其最终目标的最合乎逻辑的下一个路由器。

即使您理解这些概念,对 DHCP 的基本熟悉程度不可避免地会升级为设置 DHCP 服务器。安装和配置您自己的 DHCP 服务器为您提供了在您的家庭网络上引入 DHCP 冲突的机会(如果可以,尽量避免这种情况,因为它肯定会破坏您的网络,直到问题解决),控制地址的分配,创建子网,以及监视连接和租用时间。

更重要的是,设置 DHCP 并尝试不同的配置有助于您理解互联网络。您理解网络如何表示数据传输中的“分区”,以及您必须采取哪些步骤才能将信息从一个分区传递到另一个分区。这对于系统管理员来说至关重要,因为网络很容易成为工作中最重要的方面之一。

资源

在运行您自己的 DHCP 服务器之前,请确保您的家用路由器中的 DHCP 服务器(如果您有路由器)处于非活动状态。一旦您启动并运行它,请阅读 Archit Modi 的 网络命令指南,以获取有关如何探索您的网络的提示。

网线

熟悉网线的工作原理听起来可能很平凡,但这不仅会带来非常有趣的周末,还会让您对数据如何在电线上传输有全新的理解。最好的学习方法是去当地的爱好商店购买 Cat 5 切割器和压线钳以及一些 Cat 5 端接器。然后回家,拿起一根备用的以太网线,然后切掉端接器。花费任何时间,直到将电缆恢复正常工作状态。

一旦您解决了这个难题,请再次执行此操作,这次创建一条工作的 交叉线

您现在也应该开始痴迷于电缆管理。如果您天生就不喜欢沿着地板线脚或桌子边缘整齐地铺设电缆,或者将电缆捆绑在一起以保持整洁,那么请将自己永久性地培养成对杂乱电缆的恐惧症。您一开始不会理解为什么这是必要的,但是当您第一次走进服务器机房时,您会立即知道。

Ansible

Ansible 是配置管理软件,它是系统管理员和 DevOps 之间的一座桥梁。系统管理员使用 Ansible 来配置操作系统的全新安装,并在机器上维护特定状态。DevOps 使用 Ansible 来减少花费在工具上的时间和精力,以便将更多的时间和精力花费在开发上。您应该将学习 Ansible 作为系统管理员培训的一部分,并着眼于 DevOps 的实践,因为 DevOps 现在开创的大部分内容最终将成为您未来系统管理工作流程的一部分。

关于 Ansible 的好处是您可以立即开始使用它。它是跨平台的,并且可以向上和向下扩展。Ansible 对于单用户计算机来说可能有点过分,但话又说回来,Ansible 可能会改变您启动虚拟机的方式,或者它可以帮助您同步家庭或 家庭实验室中所有计算机的状态。

资源

阅读 Jay LaCroix 的“如何使用 Ansible 管理您的工作站配置”,以获得关于在休闲基础上开始使用 Ansible 的典型介绍。

弄坏东西

计算机上出现问题的原因是用户错误、软件错误、管理员(就是您!)错误以及许多其他因素。无法预测什么会发生故障或原因,因此您的个人系统管理员培训方案的一部分应该是戳戳您设置的系统,直到它们发生故障。您对自己的实验室基础设施越苛刻,您就越有可能发现薄弱环节。并且您修复这些薄弱环节的次数越多,您对自己的问题解决能力就越有信心。

除了设置所有常用软件和硬件的严谨性之外,您作为系统管理员的主要工作是找到解决方案。有时您会遇到超出您的工作范围的问题,甚至您可能无法解决它,但您有责任找到解决方法。

您现在弄坏东西并努力修复它的次数越多,您就越能更好地为担任系统管理员做好准备。


您是系统管理员吗?您是否希望自己为某些任务做好更好的准备?在下面的评论中添加它们!

Seth Kenlon
Seth Kenlon 是一位 UNIX 极客、自由文化倡导者、独立多媒体艺术家和 D&D 爱好者。他曾在电影和计算机行业工作,并且经常同时工作。

13 条评论

好的入门列表……我可能会建议将 Vim 编辑器添加到列表中 :)

在所有技巧中,我真的很喜欢“弄坏东西”,因为这种经验方法会将您带到对解决问题技能基础知识的信心状态。

我非常同意 Marco 和 Kim 的观点;我也会将 LVM 添加到列表中,可能还有 DNS 和虚拟化的概念,至少。

这些都是很棒的补充。您可以想象,这篇文章可能会更长,所以很难选择关注什么。

回复 作者 Dave Harding (未验证)

我也同意……除了 LVM 之外,添加如何识别新添加的驱动器(使用热插拔、光纤通道或虚拟附加)对于在磁盘空间不足时保持系统不中断运行至关重要。

回复 作者 Dave Harding (未验证)

我会添加“man 手册页”。参考给定命令的 man 手册页真的很有益。

别告诉我的客户,但我知道的一些重要事情是通过在他们的计算机和服务器上进行实验学到的(有时我修复了它,有时我让它变得更糟);-)

只是在这里回复 Ansible 部分
>> Ansible 对于单用户计算机来说可能有点过分

我强烈建议系统管理员不要因为一台机器的工作量太大而跳过学习某些东西。正是这种行为让我们陷入大量低影响的手动任务中,我们需要记住一遍又一遍地做。

我鼓励人们开始学习 Ansible 用于他们的一两台机器,并使用这些机器来练习您的技能。Ansible 非常简单的剧本语法会自动为您创建关于您所做事情的优秀文档,并最终减少在其他琐碎和单调的任务上花费的大量时间……更不用说您为一台机器开发的任何任务通常都可以轻松地在其他机器上重复使用。

我喜欢它!并且后悔所有我推迟学习它的时间,因为手头的问题“太简单”了。

> 我强烈建议系统管理员不要因为工作量而跳过学习某些东西
> 对于一台机器来说太高了。正是这种行为让我们陷入大量
> 低影响的手动任务中,我们需要记住一遍又一遍地做。

多么棒的观点。谢谢!

回复 作者 JamesF

知识共享许可协议本作品根据知识共享署名-相同方式共享 4.0 国际许可协议获得许可。
© . All rights reserved.