- 关于本指南
- I 常用任务
- II 引导 Linux 系统
- III 系统
- IV 服务
- V 查错
- A 网络示例
- B GNU 许可证
- 3.1 YaST 联机更新
- 5.1 文本方式下 YaST 的主窗口
- 5.2 软件安装模块
- 7.1 引导加载程序:快照
- 8.1 vncviewer
- 8.2 Remmina 的主窗口
- 8.3 远程桌面首选项
- 8.4 快速启动
- 8.5 正在查看 SLES 15 SP1 远程会话的 Remmina
- 8.6 查看配置文件的路径
- 8.7 远程管理
- 8.8 VNC 会话设置
- 8.9 加入持续 VNC 会话
- 11.1 安全引导支持
- 11.2 UEFI:安全引导流程
- 12.1 GRUB 2 引导编辑器
- 12.2 引导代码选项
- 12.3 代码选项
- 12.4 引导加载程序选项
- 12.5 内核参数
- 13.1 服务管理器
- 15.1 YaST systemd 日记
- 17.1 TCP/IP 的简化层次模型
- 17.2 TCP/IP 以太网包
- 17.3 配置网络设置
- 17.4
wicked
体系结构 - 25.1 GNOME 网络连接对话框
- 25.2 NetworkManager 中的
firewalld
区域 - 29.1 NTP 配置窗口
- 29.2 添加时间服务器
- 31.1 Windows 资源管理器 对话框
- 31.2 列有压缩文件的 Windows 资源管理器目录
- 31.3 在启用快照的情况下添加新的 Samba 共享
- 31.4 Windows 资源管理器中的 选项卡
- 34.1 SCA 工具生成的 HTML 报告
- 34.2 SCA 设备生成的 HTML 报告
- 1.1 登录外壳的 Bash 配置文件
- 1.2 非登录外壳的 Bash 配置文件
- 1.3 用于 Bash 的特殊文件
- 1.4 标准目录树概述
- 1.5 有用的环境变量
- 2.1 有用的标志和选项
- 6.1 最重要的 RPM 查询选项
- 6.2 RPM 校验选项
- 13.1 服务管理命令
- 13.2 用于启用和禁用服务的命令
- 13.3 System V 运行级别和
systemd
目标单元 - 17.1 专用 IP 地址域
- 17.2 /etc/host.conf 的参数
- 17.3 通过 /etc/nsswitch.conf 可用的数据库
- 17.4 NSS“数据库”的配置选项
- 17.5 绑定与组合的功能比较
- 19.1 基于 Fontconfig 规则生成 PFL
- 19.2 基于更改了顺序的 Fontconfig 规则生成 PFL 的结果
- 19.3 基于 Fontconfig 规则生成 PFL 的结果
- 24.1
ulimit
:为用户设置资源 - 33.1 手册页—类别和说明
- 34.1 TAR 存档中的功能和文件名对照
- 35.1 日志文件
- 35.2
/proc
文件系统的系统信息 - 35.3
/sys
文件系统的系统信息
- 1.1 用于打印文本的外壳脚本
- 6.1 Zypper — 已知储存库的列表
- 6.2
rpm -q -i wget
- 6.3 搜索包的脚本
- 7.1 时间线配置示例
- 12.1 grub2-mkconfig 用法
- 12.2 grub2-mkrescue 用法
- 12.3 grub2-script-check 用法
- 12.4 grub2-once 用法
- 13.1 列出活动服务
- 13.2 列出失败的服务
- 13.3 列出属于某个服务的所有进程
- 16.1
java
命令的备选项系统 - 17.1 编写 IP 地址
- 17.2 将 IP 地址链接到网络掩码
- 17.3 示例 IPv6 地址
- 17.4 指定前缀长度的 IPv6 地址
- 17.5 通用网络接口和部分静态路由
- 17.6
/var/run/netconfig/resolv.conf
- 17.7
/etc/hosts
- 17.8
/etc/networks
- 17.9
/etc/host.conf
- 17.10
/etc/nsswitch.conf
- 17.11 命令 ping 的输出
- 17.12 网络协作的负载平衡配置
- 17.13 DHCP 网络协作设备的配置
- 18.1 来自
lpd
的错误消息 - 18.2 来自 CUPS 网络服务器的广播
- 19.1 指定渲染算法
- 19.2 别名和系列名称替代
- 19.3 别名和系列名称替代
- 19.4 别名和系列名称替代
- 22.1 示例
udev
规则 - 24.1 /etc/crontab 中的项
- 24.2 /etc/crontab:删除时戳文件
- 24.3
ulimit
:~/.bashrc
中的设置 - 31.1 smb.conf 中的 global 部分
- 31.2 使用
rpcclient
请求 Windows Server 2012 共享快照 - 34.1 以
root
身份登录时的hostinfo
输出
版权所有 © 2006– 2024 SUSE LLC 和贡献者。保留所有权利。
根据 GNU 自由文档许可证 (GNU Free Documentation License) 版本 1.2 或(根据您的选择)版本 1.3 中的条款,在此授予您复制、分发和/或修改本文档的许可权限;本版权声明和许可证附带不可变部分。许可证版本 1.2 的副本包含在题为“GNU 自由文档许可证”的部分。
有关 SUSE 商标,请参见 http://www.suse.com/company/legal/。所有其它第三方商标是其各自所有者的财产。商标符号(®、™ 等)代表 SUSE 及其附属公司的商标。星号 (*) 代表第三方商标。
本指南力求涵盖所有详细信息。但这并不确保本指南准确无误。SUSE LLC 及其附属公司、作者和译者对于可能出现的错误或由此造成的后果皆不承担责任。
关于本指南 #
本指南的目标用户为专业网络管理员和系统管理员,供其在操作 SUSE® Linux Enterprise 的过程中使用。因此,本指南的重点只在于确保 SUSE Linux Enterprise 的配置正确,并且网络上的所需服务都可使用,使其在初始安装后即可正常工作。本指南不包含用于确保 SUSE Linux Enterprise 与用户企业的应用程序软件兼容或者其核心功能符合那些要求的过程。本指南假定已经进行了全面的要求审核,已经请求进行安装或者已经请求进行用于此类审核的测试安装。
本指南包含如下内容:
- 支持任务和常见任务
SUSE Linux Enterprise 提供了大量工具,用于自定义系统的各个方面。本部分介绍其中几个。
- 系统
通过研究本部分了解关于底层操作系统的更多信息。SUSE Linux Enterprise 支持若干种硬件体系结构,您可以参考此信息来调整自己的应用程序,以便在 SUSE Linux Enterprise 上运行。引导加载程序和引导过程信息有助于您了解 Linux 系统的工作方式以及您自己的自定义脚本和应用程序与该系统的调和方式。
- 服务
SUSE Linux Enterprise 被设计为一个网络操作系统。SUSE® Linux Enterprise Desktop 中包含许多网络服务的客户端支持。它可以很好地集成到包括 MS Windows 客户端和服务器在内的异构环境中。
- 移动计算机
需要特别注意便携式计算机、移动设备(如 PDA 或手机)和 SUSE Linux Enterprise 之间的通讯。要注意省电以及将不同设备集成到不断变化的网络环境中。同时要了解提供所需功能的后台技术。
- 查错
概述了当您需要更多信息或要执行特定任务时,如何查找帮助和其他文档。还提供了最常见的问题及其解决方法的列表。
1 可用文档 #
此外,您安装的系统的 /usr/share/doc/manual
下通常会提供产品文档。
针对本产品提供的文档如下:
- Article “安装快速入门”
本《快速入门》引导您逐步完成安装 SUSE® Linux Enterprise Desktop 15 SP1 的过程。
- Book “Deployment Guide”
显示如何安装单个或多个系统,以及如何利用产品继承功能建立部署基础结构。有各种方法可供选择,可以选择使用本地安装或网络安装服务器,也可以选择使用远程控制、高度自定义的自动安装技术进行大规模部署。
- Book “管理指南”
讲述系统管理任务,如维护、监视和自定义初始安装的系统。
- Book “Security and Hardening Guide”
介绍系统安全的基本概念,包括本地安全方面和网络安全方面。说明如何使用产品固有的安全软件(例如 AppArmor),或者能够可靠收集有关任何安全相关事件的信息的审核系统。
- Book “System Analysis and Tuning Guide”
关于问题检测、解决和优化的管理员指南。了解如何使用监视工具检查和优化系统以及如何有效管理资源。还包含常见问题和解决方法的概述以及其他帮助和文档资源。
- Book “GNOME 用户指南”
介绍 SUSE Linux Enterprise Desktop 的 GNOME 桌面。指导您使用和配置桌面并帮助您执行关键任务。它主要面向想要有效使用 GNOME 作为其默认桌面的最终用户。
2 反馈 #
提供了多种反馈渠道:
- 错误和增强请求
有关产品可用的服务和支持选项,请参见 http://www.suse.com/support/。
有关 openSUSE 的帮助由社区提供。有关更多信息,请参考https://en.opensuse.org/Portal:Support。
要报告产品组件的 Bug,请访问 https://scc.suse.com/support/requests 并登录,然后单击 。
- 用户意见
我们希望收到您对本手册和本产品中包含的其他文档的意见和建议。请使用联机文档每页底部的“用户注释”功能或转到 http://www.suse.com/documentation/feedback.html 并在此处输入注释。
- 邮件
如有对本产品文档的反馈,也可以发送邮件至
doc-team@suse.com
。请确保反馈中含有文档标题、产品版本和文档发布日期。要报告错误或给出增强建议,请提供问题的简要说明并指出相应章节编号和页码(或 URL)。
3 文档约定 #
本文档中使用了以下通知和排版约定:
/etc/passwd
:目录名称和文件名PLACEHOLDER:PLACEHOLDER 将会替换为实际的值
PATH
:环境变量 PATHls
、--help
:命令、选项和参数user
:用户和组package name:包名称
Alt、Alt–F1:按键或组合键;这些键以大写形式显示,如在键盘上一样
跳舞的企鹅(企鹅一章,↑其他手册):此内容参见自其他手册中的一章。
必须使用
root
特权运行的命令。您往往还可以在这些命令前加上sudo
命令,以非特权用户身份来运行它们。root #
command
tux >
sudo
command
可以由非特权用户运行的命令。
tux >
command
注意
警告:警告通知在继续操作之前,您必须了解的不可或缺的信息。向您指出有关安全问题、潜在数据丢失、硬件损害或物理危害的警告。
重要:重要通知在继续操作之前,您必须了解的重要信息。
注意:注意通知额外信息,例如有关软件版本差异的信息。
提示:提示通知有用信息,例如指导方针或实用性建议。
4 关于本文档的制作 #
本文档是以 GeekoDoc(DocBook 5 的子集)编写的。XML 源文件用 jing
(请参见 https://code.google.com/p/jing-trang/)加以验证、用 xsltproc
进行处理,并用 Norman Walsh 的样式表的自定义版本转换为 XSL-FO。最终的 PDF 通过 Apache Software Foundation 的 FOP 排版。用于制作本文档的开放源代码工具和环境由 DocBook Authoring and Publishing Suite (DAPS) 提供。项目的主页可以在 https://github.com/openSUSE/daps 中找到。
本文档的 XML 源代码可以在 https://github.com/SUSE/doc-sle 中找到。
第 I 部分 常用任务 #
- 1 Bash 和 Bash 脚本
现今,许多人都在使用装有 GNOME 之类图形用户界面 (GUI) 的计算机。尽管 GUI 可提供许多功能,但执行自动化任务时,这些功能会受到限制。外壳是对 GUI 的很好补充,本章将会概述外壳(在本例中为 Bash 外壳)的某些方面。
- 2 sudo
许多命令和系统实用程序都需要以
root
身份运行才能修改文件和/或执行只有超级用户方能执行的任务。为了确保安全和避免发生意外运行危险命令的情况,通常建议不要直接以root
身份登录。建议的做法是以非特权的普通用户身份工作,并使用sudo
命令来运行需要较高特权的命令。- 3 YaST 联机更新
SUSE 持续为您的产品提供软件安全更新。默认情况下,用更新小程序来保持您的系统是最新的。有关更新小程序的更多信息请参考Book “Deployment Guide”, Chapter 16 “Installing or Removing Software”, Section 16.5 “The GNOME Package Updater”。本章介绍用于更新软件包的备用工具:YaST 联机更新。
- 4 YaST
YaST 是 SUSE Linux Enterprise Desktop 的安装和配置工具。它具有图形界面,并且能够在安装期间和安装之后快速自定义系统。它可用于设置硬件、配置网络、系统服务和调整安全性设置。
- 5 文本方式的 YaST
本章所针对的读者是在其系统上不运行 X 服务器而依赖于基于文本的安装工具的系统管理员和专家。它提供了与以文本方式启动和操作 YaST 有关的基本信息。
- 6 使用命令行工具管理软件
本章描述 Zypper 和 RPM,这是两个用于管理软件的命令行工具。有关此环境中使用的术语定义(例如,
储存库
、增补程序
或更新
),请参见Book “Deployment Guide”, Chapter 16 “Installing or Removing Software”, Section 16.1 “Definition of Terms”。- 7 通过 Snapper 进行系统恢复和快照管理
能够生成文件系统快照以便在 Linux 上实现回滚,这是过去常常要求提供的功能。如今,Snapper 与
Btrfs
文件系统或瘦配置的 LVM 卷相结合,填补了这一空白。Btrfs
是全新的 Linux 写入时复制文件系统。它支持为子卷(每个物理分区中的一或多个单独的可装入文件系统)生成文件系统快照(复制子卷在某个时间点的状态)。XFS、Ext4 或 Ext3 格式的精简 LVM 卷上也支持快照。您可以使用 Snapper 创建并管理这些快照。Snapper 有一个命令行和一个 YaST 界面。从 SUSE Linux Enterprise Server 12 开始,还可以从Btrfs
快照引导。有关详细信息,请参见第 7.3 节 “通过从快照引导来执行系统回滚”。- 8 使用 VNC 远程访问
利用虚拟网络计算(Virtual Network Computing,VNC)可以通过图形桌面控制远程计算机(与远程外壳访问相对)。VNC 是独立于平台的并允许您从任何操作系统访问远程计算机。
SUSE Linux Enterprise Desktop 支持两种不同种类的 VNC 会话:只要客户端的 VNC 连接不中断即会保持“在线”的一次性会话,和始终“在线”直到被明确终止的永久会话。
- 9 使用 RSync 复制文件
当今时代,用户通常都会有数台计算机:家用计算机和办公计算机、笔记本电脑、智能手机或平板电脑。因而,在多个设备之间保持文件和文档同步的任务就变得越发重要。
1 Bash 和 Bash 脚本 #
现今,许多人都在使用装有 GNOME 之类图形用户界面 (GUI) 的计算机。尽管 GUI 可提供许多功能,但执行自动化任务时,这些功能会受到限制。外壳是对 GUI 的很好补充,本章将会概述外壳(在本例中为 Bash 外壳)的某些方面。
1.1 什么是“外壳”? #
通常来说,外壳就是指 Bash(Bourne again 外壳)。在本章中提到“外壳”时,指的是 Bash。除了 Bash 以外,还存在其他一些外壳(ash、csh、ksh、zsh 等),每种外壳都具备不同的功能和特征。如果需要关于其他外壳的更多信息,请在 YaST 中搜索外壳。
1.1.1 了解 Bash 配置文件 #
外壳可调用为:
交互式登录外壳: 当登录计算机时需要使用此方式,即使用
--login
选项调用 Bash 或通过 SSH 登录到远程计算机时。“普通”交互式外壳: 这通常在启动 xterm、konsole、gnome 终端或类似工具时使用。
非交互式外壳: 当在命令行调用外壳脚本时使用。
根据所用外壳的类型,会读取不同的配置文件。下表显示登录和非登录外壳的配置文件。
文件 |
描述 |
---|---|
|
不要修改此文件,否则在下一次更新时可能损坏您的修改! |
|
如果扩展 |
|
包含特定程序的系统范围配置文件 |
|
在此处插入特定于用户的登录外壳配置 |
请注意,登录外壳还会获取表 1.2 “非登录外壳的 Bash 配置文件”中所列的配置文件。
|
不要修改此文件,否则在下一次更新时可能损坏您的修改! |
|
使用此文件插入系统范围的修改(仅 Bash) |
|
在此处插入特定于用户的配置 |
此外,Bash 还使用更多文件:
文件 |
描述 |
---|---|
|
包含已键入的所有命令的列表 |
|
注销时执行 |
|
用户为常用命令定义的别名。有关定义别名的更多细节,请参见 |
1.1.2 目录结构 #
下表简要介绍 Linux 系统上最重要的较高级别目录。以下列表中是关于这些目录和重要子目录的更多详细信息。
目录 |
内容 |
---|---|
|
根目录 — 目录树的起点。 |
|
基本二进制文件,例如系统管理员和普通用户都需要的命令。通常还包含外壳,如 Bash。 |
|
引导加载程序的静态文件。 |
|
访问特定于主机的设备所需的文件。 |
|
特定于主机的系统配置文件。 |
|
储存系统上具有帐户的所有用户的用户主目录。但是, |
|
基本共享库和内核模块。 |
|
可卸媒体的安装点。 |
|
临时装入文件系统的安装点。 |
|
附加应用程序软件包。 |
|
超级用户 |
|
基本系统二进制文件。 |
|
系统提供的服务的数据。 |
|
临时文件。 |
|
具有只读数据的辅助层次结构。 |
|
变量数据,如日志文件。 |
|
只在系统上同时安装了 Microsoft Windows* 和 Linux 时可用。包含 Windows 数据。 |
以下列表提供有关这些目录中有哪些文件和子目录的更多详细信息,并给出一些示例:
/bin
包含
root
和其他用户都可使用的基本 shell 命令。这些命令包括ls
、mkdir
、cp
、mv
、rm
和rmdir
。/bin
也包含 Bash,它是 SUSE Linux Enterprise Desktop 中的默认外壳。/boot
包含引导所需的数据,如引导加载程序、内核以及内核开始执行用户模式程序之前使用的其他数据。
/dev
储存代表硬件组件的设备文件。
/etc
包含控制诸如 X Window 系统等程序操作的本地配置文件。
/etc/init.d
子目录包含引导过程中可执行的 LSB init 脚本。/home/USERNAME
储存在系统中建立帐户的所有用户的私人数据。这里的文件只能由其拥有者或系统管理员修改。默认情况下,电子邮件目录和个人桌面配置以隐藏文件和目录的形式储存在此处,例如
.gconf/
和.config
。注意:网络环境中的用户主目录如果在网络环境中工作,则您的用户主目录可能映射到文件系统中除
/home
之外的其他目录中。/lib
包含引导系统和运行 root 文件系统中的命令所需的基本共享库。共享库相当于 Windows 中的 DLL 文件。
/media
包含 CD-ROM、闪存盘和数码相机(如果它们使用 USB)等可卸媒体的安装点。
/media
通常包含除系统硬盘之外的各类驱动器。可卸媒体插入或连接到系统并装入之后,您便可从此处访问该媒体。/mnt
此目录提供临时装入的文件系统的安装点。
root
可以在此处装入文件系统。/opt
保留用于安装第三方软件。在此处可以找到可选软件和较大附加产品程序包。
/root
root
用户的主目录。root
的个人数据储存在此处。/run
systemd
和各个组件使用的 tmpfs 目录。/var/run
是/run
的符号链接。/sbin
如
s
所表明的,该目录储存超级用户的实用程序。/sbin
包含/bin
中的二进制文件以及引导和恢复系统所需的其他二进制文件。/srv
储存系统提供的服务(如 FTP 和 HTTP)的数据。
/tmp
此目录由需要临时储存文件的程序使用。
重要:在引导时清理/tmp
系统重引导后,之前储存在
/tmp
中的数据无法保证仍然存在。这视情况而定,例如,取决于/etc/tmpfiles.d/tmp.conf
中所做的设置。/usr
/usr
与用户无关,而是 Unix 系统资源 (Unix system resource) 的缩写。/usr
中的数据是可以在符合文件系统层次标准
(FHS) 的各个主机之间共享的静态只读数据。此目录包含所有应用程序(包括 GNOME 等图形桌面),并且会在文件系统中创建次要层次。/usr
储存了多个子目录,例如/usr/bin
、/usr/sbin
、/usr/local
和/usr/share/doc
。/usr/bin
包含一般可访问的程序。
/usr/sbin
包含为系统管理员保留的程序,例如维修功能。
/usr/local
在此目录中,系统管理员可以安装本地的独立于分发包的扩展。
/usr/share/doc
储存系统的各种文档文件和发行描述。在
manual
子目录中可以找到此手册的联机版本。如果安装了多种语言,则此目录可能包含这些手册不同语言的版本。在
packages
下可以找到系统上安装的软件包中包含的文档。对于每个包,都会创建一个子目录/usr/share/doc/packages/PACKAGENAME
,通常用其储存该包的自述文件,有时储存示例、配置文件或附加脚本。如果系统上安装了操作指南,
/usr/share/doc
还会包含howto
子目录,其中有与 Linux 软件的安装和操作相关的许多任务的附加文档。/var
/usr
用于储存静态只读的数据,而/var
用于在系统操作期间写入并成为变量数据的数据,例如日志文件或假脱机数据。有关最重要日志文件的概述,可以在/var/log/
下找到,请参见表 35.1 “日志文件”。/windows
只在系统上同时安装了 Microsoft Windows 和 Linux 时可用。包含系统的 Windows 分区上可用的 Windows 数据。是否可以编辑此目录中的数据取决于 Windows 分区使用的文件系统。如果是 FAT32,则您可以打开和编辑此目录中的文件。对于 NTFS,SUSE Linux Enterprise Desktop 还包含写访问权限支持。但是,NTFS-3g 文件系统的驱动程序只拥有部分功能。
1.2 编写外壳脚本 #
使用外壳脚本可以方便地完成各种任务:收集数据、在文本中搜索单词或短语,以及执行其他有用的操作。以下示例显示用于打印文本的小外壳脚本:
在运行此脚本之前,必须满足几个先决条件:
每个脚本都应包含 Shebang 行(如上面的示例所示)。如果该行缺失,您需要手动调用解释器。
可以将该脚本保存在任何位置。但是,建议将其保存在外壳可以找到的目录中。外壳中的搜索路径由环境变量
PATH
确定。通常,一般用户不具有对/usr/bin
的写权限。因此,建议将脚本保存在用户目录~/bin/
中。在上例中使用名称hello.sh
。该脚本需要可执行权限。使用以下命令设置权限:
tux >
chmod +x ~/bin/hello.sh
如果已满足上述所有先决条件,则可以按如下方式执行此脚本:
作为绝对路径: 可以使用绝对路径执行脚本。在本例中为
~/bin/hello.sh
。所有位置: 如果
PATH
环境变量包含脚本所在目录,则可以使用hello.sh
来执行该脚本。
1.3 重定向命令事件 #
每个命令都可以使用三个通道输入或输出:
标准输出: 这是默认的输出通道。在命令打印某些内容时都会使用标准输出通道。
标准输入: 如果一个命令需要用户或其他命令输入,则使用此通道。
标准错误: 命令使用此通道报告错误。
要重定向这些通道,有以下可行的操作方式:
命令 > 文件
将该命令的输出保存为文件,将删除现有文件。例如,
ls
命令会将其输出写入文件listing.txt
:tux >
ls > listing.txt命令 >> 文件
将命令输出追加到文件。例如,
ls
命令会将其输出追加到文件listing.txt
:tux >
ls >> listing.txt命令 < 文件
读取该文件作为给定命令的输入。例如,
read
命令会将此文件的内容读入变量:tux >
read a < foo命令 1 | 命令 2
将左侧命令的输出重定向为右侧命令的输入。例如,
cat
命令会输出文件/proc/cpuinfo
的内容。grep
使用此输出仅过滤出包含cpu
的行:tux >
cat /proc/cpuinfo | grep cpu
每个通道都有一个文件描述符:0(零)表示标准输入,1 表示标准输出,2 表示标准错误。允许在 <
或 >
字符前插入此文件描述符。例如,以下行搜索以 foo
开头的文件,但通过将错误重定向到 /dev/null
而抑制错误。
tux >
find / -name "foo*" 2>/dev/null
1.4 使用别名 #
别名是一个或多个命令的快捷方式定义。别名的语法为:
alias NAME=DEFINITION
例如,下行定义了一个别名 lt
,它会输出一份较长的列表(选项 -l
),将其按修改时间排序 (-t
),并按排好序的倒序打印 (-r
):
tux >
alias lt='ls -ltr'
要查看所有别名定义,请使用 alias
。使用 unalias
和相应的别名删除别名。
1.5 在 Bash 中使用变量 #
外壳变量可以是全局变量,也可以是局部变量。全局变量(或环境变量)可以在所有外壳中访问。而局部变量仅在当前外壳中可见。
要查看所有环境变量,请使用 printenv
命令。如果需要知道变量的值,请将变量名称作为自变量插入:
tux >
printenv PATH
也可以使用 echo
查看变量(无论是全局或本地变量):
tux >
echo $PATH
要设置局部变量,请使用变量名后加等号和值:
tux >
PROJECT="SLED"
不要在等号两边插入空格,否则会出错。要设置环境变量,请使用 export
:
tux >
export NAME="tux"
要删除变量,请使用 unset
:
tux >
unset NAME
下表包含外壳脚本中可以使用的一些常见环境变量:
|
当前用户的用户主目录 |
|
当前主机名 |
|
当一个工具本地化后,它使用此环境变量中的语言。英语也可以设置为 |
|
外壳的搜索路径,冒号分隔的目录列表 |
|
指定在每个命令前打印的普通提示符 |
|
指定在执行多行命令时打印的辅助提示符 |
|
当前工作目录 |
|
当前用户 |
1.5.1 使用自变量 #
例如,如果具有脚本 foo.sh
,则可以如下执行:
tux >
foo.sh "Tux Penguin" 2000
要访问传递给脚本的所有自变量,您需要定位参数。$1
表示第一个自变量,$2
表示第二个自变量,依此类推。至多可以有九个参数。要获取脚本名称,请使用 $0
。
以下脚本 foo.sh
打印从 1 到 4 的所有自变量:
#!/bin/sh echo \"$1\" \"$2\" \"$3\" \"$4\"
如果使用上述自变量执行此脚本,将获取:
"Tux Penguin" "2000" "" ""
1.5.2 使用变量替换 #
变量替换将一个模式应用于变量的内容(从左侧或从右侧)。以下列表包含可能的语法格式:
${VAR#pattern}
从左侧删除可能的最短匹配:
tux >
file=/home/tux/book/book.tar.bz2tux >
echo ${file#*/} home/tux/book/book.tar.bz2${VAR##pattern}
从左侧删除可能的最长匹配:
tux >
file=/home/tux/book/book.tar.bz2tux >
echo ${file##*/} book.tar.bz2${VAR%pattern}
从右侧删除可能的最短匹配:
tux >
file=/home/tux/book/book.tar.bz2tux >
echo ${file%.*} /home/tux/book/book.tar${VAR%%pattern}
从右侧删除可能的最长匹配:
tux >
file=/home/tux/book/book.tar.bz2tux >
echo ${file%%.*} /home/tux/book/book${VAR/pattern_1/pattern_2}
将来自 PATTERN_1 的 VAR 的内容替代为 PATTERN_2:
tux >
file=/home/tux/book/book.tar.bz2tux >
echo ${file/tux/wilber} /home/wilber/book/book.tar.bz2
1.6 将命令分组和组合 #
外壳允许您对命令执行连接和分组以有条件地执行。每个命令都返回一个退出码,该退出码确定操作是成功还是失败。如果是 0,则命令成功,任何其他值都表示特定于该命令的一个错误。
以下列表显示可以如何将命令分组:
命令 1 ; 命令 2
顺序地执行这些命令。不检查退出码。以下行使用
cat
显示文件的内容,然后使用ls
打印其文件属性,而不考虑退出码:tux >
cat filelist.txt ; ls -l filelist.txt命令 1 && 命令 2
如果左侧命令成功,则运行右侧命令(逻辑运算符 AND)。仅当上一个命令成功时,以下行才显示文件的内容并打印其文件属性(将其与列表中的上一项相比较):
tux >
cat filelist.txt && ls -l filelist.txt命令 1 || 命令 2
当左侧命令失败时运行右侧命令(逻辑运算符 OR)。以下行仅当在
/home/tux/foo
中创建目录失败时才会在/home/wilber/bar
中创建目录:tux >
mkdir /home/tux/foo || mkdir /home/wilber/barfuncname(){ ... }
创建外壳函数。您可以使用定位参数访问其自变量。以下行定义用于打印短消息的函数
hello
:tux >
hello() { echo "Hello $1"; }您可以如下调用此函数:
tux >
hello Tux它会打印:
Hello Tux
1.7 使用通用流程构造语句 #
为了控制脚本的流程,外壳有 while
、if
、for
和 case
等构造语句。
1.7.1 if 控制命令 #
if
命令用于检查表达式。例如,以下代码测试当前用户是否是 Tux:
if test $USER = "tux"; then echo "Hello Tux." else echo "You are not Tux." fi
测试表达式既可以复杂也可以简单。以下表达式检查文件 foo.txt
是否存在:
if test -e /tmp/foo.txt ; then echo "Found foo.txt" fi
测试表达式也可以缩写在方括号中:
if [ -e /tmp/foo.txt ] ; then echo "Found foo.txt" fi
在 https://bash.cyberciti.biz/guide/If..else..fi 上可以找到更多有用表达式。
1.7.2 使用 for
命令创建循环 #
for
循环允许您对一系列项执行命令。例如,以下代码打印关于当前工作目录中 PNG 文件的某些信息:
for i in *.png; do ls -l $i done
1.8 更多信息 #
关于 Bash 的重要信息在手册页 man bash
中提供。可以在以下列表中找到关于此主题的更多信息:
http://tldp.org/LDP/Bash-Beginners-Guide/html/index.html — Bash 入门者指南
http://tldp.org/HOWTO/Bash-Prog-Intro-HOWTO.html — BASH 编程 - 简介操作指南
http://tldp.org/LDP/abs/html/index.html — 高级 Bash 脚本编写指南
http://www.grymoire.com/Unix/Sh.html — Sh - Bourne 外壳
2 sudo #
许多命令和系统实用程序都需要以 root
身份运行才能修改文件和/或执行只有超级用户方能执行的任务。为了确保安全和避免发生意外运行危险命令的情况,通常建议不要直接以 root
身份登录。建议的做法是以非特权的普通用户身份工作,并使用 sudo
命令来运行需要较高特权的命令。
在 SUSE Linux Enterprise Desktop 上,sudo
默认配置为以与 su 类似的方式工作。但是,sudo
可让用户以高度可配置的方式使用任何其他用户的特权来运行命令。这样,便可为某些用户和组指派具有特定特权的角色。举例来说,可以允许组 users
的成员使用 wilber
的特权运行命令。例如,通过禁止指定任何命令选项,可以进一步限制对命令的权限。虽然 su 始终需要 root
口令才能使用 PAM 进行身份验证,但是您可以将 sudo
配置为使用您自己的身份凭证进行身份验证。这样就不需要共享 root
口令,从而提高了安全性。例如,您可以允许 users
组的成员以 wilber
身份运行 frobnicate
命令,但限制其不能指定自变量。这样,便可为某些用户和组指派具有特定能力的角色。
2.1 sudo
基本用法 #
虽然 sudo
简单易用,功能却十分强大。
2.1.1 运行单个命令 #
以普通用户身份登录后,您可以在命令前加上 sudo
以 root
身份运行任何命令。按照提示输入 root 口令后,如果身份验证成功,您便能以 root
身份运行命令:
tux >
id -un
1 tuxtux >
sudo
id -un
root's password:2 roottux >
id -un
tux3tux >
sudo
id -un
4 root
| |
在输入过程中不会显示口令,无论是明文还是密文均不显示。 | |
只有以 | |
在限定时间内,您无需再次输入 |
I/O 重定向的工作方式与您预期的可能不同:
tux >
sudo
echo s > /proc/sysrq-trigger bash: /proc/sysrq-trigger: Permission deniedtux >
sudo
cat < /proc/1/maps bash: /proc/1/maps: Permission denied
只有 echo
/cat
二进制会使用较高特权运行,重定向则由用户外壳使用用户特权执行。您可以按第 2.1.2 节 “启动外壳”中所述启动外壳,也可以使用 dd
实用程序来启动:
echo s | sudo dd of=/proc/sysrq-trigger sudo dd if=/proc/1/maps | cat
2.1.2 启动外壳 #
必须在每条命令前加上 sudo
可能很繁琐。虽然可以将外壳指定为命令 sudo bash
,但还是建议您使用以下其中一种内置机制来启动外壳:
sudo -s (<命令>)
启动
SHELL
环境变量所指定的外壳或目标用户的默认外壳。如果给定了命令,则会将该命令传递给外壳(使用-c
选项),否则外壳会以交互模式运行。tux:~ >
sudo -i root's password:root:/home/tux #
exittux:~ >
sudo -i (<命令>)
与
-s
类似,但是会将外壳启动为登录外壳。也就是说,系统会对外壳的启动文件(.profile
等)进行处理,并会将当前的工作目录设置为目标用户的主目录。tux:~ >
sudo -i root's password:root:~ #
exittux:~ >
2.1.3 环境变量 #
默认情况下,sudo
不会传播环境变量:
tux >
ENVVAR=test env | grep ENVVAR ENVVAR=testtux >
ENVVAR=test sudo env | grep ENVVAR root's password: 1tux >
输出为空即表明在使用 |
此行为可通过 env_reset
选项进行更改,请参见表 2.1 “有用的标志和选项”。
2.2 配置 sudo
#
sudo
是一个非常灵活的工具,提供各种配置选项。
如果您不小心将自己锁定在 sudo
之外,则可以使用 su -
及 root
口令来获取 root 外壳。要修复该错误,请运行 visudo
。
2.2.1 编辑配置文件 #
sudo
的主要策略配置文件为 /etc/sudoers
。如果此文件中存在错误,您可能便会无法进入系统,因此强烈建议您使用 visudo
来编辑配置文件。此举可防止同时更改打开的文件,并会在保存修改之前检查语法错误。
您还可以通过设置 EDITOR
环境变量来使用除 vi 以外的编辑器(不论名字如何),例如:
sudo EDITOR=/usr/bin/nano visudo
不过,/etc/sudoers
文件本身是由系统包提供的,更新时这些修改可能会取消。因此,建议您将自定义配置放到 /etc/sudoers.d/
目录下的文件中。该目录下的任何文件都会自动纳入系统中。要在该子目录下创建或编辑文件,请运行:
sudo visudo -f /etc/sudoers.d/NAME
或者,使用其他编辑器(例如 nano
):
sudo EDITOR=/usr/bin/nano visudo -f /etc/sudoers.d/NAME
/etc/sudoers.d
中忽略的文件
/etc/sudoers
中的 #includedir
命令(用于 /etc/sudoers.d
)会忽略以 ~
(波浪号)结尾或包含 .
(点)的文件。
关于 visudo
命令的详细信息,请运行 man 8 visudo
。
2.2.2 sudoers 基本配置语法 #
在 sudoers 配置文件中,有两种类型的选项:字符串和标志。字符串可以包含任何值,而标志则只能在“ON”或“OFF”之间切换。sudoers 配置文件最重要的语法构造为:
# Everything on a line after a # gets ignored 1 Defaults !insults # Disable the insults flag 2 Defaults env_keep += "DISPLAY HOME" # Add DISPLAY and HOME to env_keep tux ALL = NOPASSWD: /usr/bin/frobnicate, PASSWD: /usr/bin/journalctl 3
| |
去除 | |
选项名称 |
说明 |
示例 |
---|---|---|
targetpw
|
此标志控制调用用户是需要输入目标用户(例如 |
Defaults targetpw # Turn targetpw flag ON |
rootpw
|
如果设置了该选项, |
Defaults !rootpw # Turn rootpw flag OFF |
env_reset
|
如果设置了该选项, |
Defaults env_reset # Turn env_reset flag ON |
env_keep
|
|
# Set env_keep to contain EDITOR and PROMPT Defaults env_keep = "EDITOR PROMPT" Defaults env_keep += "JRE_HOME" # Add JRE_HOME Defaults env_keep -= "JRE_HOME" # Remove JRE_HOME |
env_delete
|
|
# Set env_delete to contain EDITOR and PROMPT Defaults env_delete = "EDITOR PROMPT" Defaults env_delete += "JRE_HOME" # Add JRE_HOME Defaults env_delete -= "JRE_HOME" # Remove JRE_HOME |
还可以使用 Defaults
令牌为用户、主机和命令集合创建别名。并且,可以仅将选项应用到特定用户集。
关于 /etc/sudoers
配置文件的详细信息,请参见 man 5 sudoers
。
2.2.3 sudoers 中的规则 #
sudoers 配置中的规则可能会非常复杂,因此本节仅涉及基本内容。每个规则都遵循基本模式([]
标记的是可选部分):
#Who Where As whom Tag What User_List Host_List = [(User_List)] [NOPASSWD:|PASSWD:] Cmnd_List
User_List
一个或多个(用
,
分隔)标识符:用户名、格式为%GROUPNAME
的组或格式为#UID
的用户 ID。可以使用!
前缀来取反。Host_List
一个或多个(用
,
分隔)标识符:(完全限定的)主机名或 IP 地址。可以使用!
前缀来取反。Host_List
的惯常选项为ALL
。NOPASSWD:|PASSWD:
如果用户在
NOPASSWD:
后面运行的命令与CMDSPEC
匹配,系统不会提示用户输入口令。PASSWD
为默认选项,仅当两个选项位于同一行时才需要指定它:tux ALL = PASSWD: /usr/bin/foo, NOPASSWD: /usr/bin/bar
Cmnd_List
一个或多个(用
,
分隔)区分符:可执行文件的路径,后跟允许使用的自变量或什么也不跟。/usr/bin/foo # Anything allowed /usr/bin/foo bar # Only "/usr/bin/foo bar" allowed /usr/bin/foo "" # No arguments allowed
ALL
可以用作 User_List
、Host_List
和 Cmnd_List
。
允许 tux
在无需输入口令的情况下以 root 身份运行所有命令的规则:
tux ALL = NOPASSWD: ALL
允许 tux
运行 systemctl restart apache2
的规则:
tux ALL = /usr/bin/systemctl restart apache2
允许 tux
在不带自变量的情况下以 admin
身份运行 wall
的规则:
tux ALL = (admin) /usr/bin/wall ""
以下类型的构造
ALL ALL = ALL
在没有 Defaults targetpw
的情况下切勿使用,否则任何人都能以 root
身份运行命令。
2.3 常见使用情况 #
尽管默认配置对于简单的设置和桌面环境通常已经够用,但是自定义配置非常有用。
2.3.1 在无需 root
口令的情况下使用 sudo
#
在具有特殊限制(“用户 X 只能以 root
” 身份运行命令 Y)的情况下,无法实现此目的。在其他情况下,还是建议进行某种分隔。按照惯例,组 wheel
的成员能以 root 身份运行所有带有 sudo
的命令。
将自己添加到
wheel
组如果您自己的用户帐户尚不是
wheel
组的成员,请添加该帐户,具体做法是运行sudo usermod -a -G wheel 用户名
然后注销并再次登录。运行groups 用户名
以确认更改是否成功。将使用调用用户的口令进行身份验证的选项设为默认设置。
使用
visudo
创建文件/etc/sudoers.d/userpw
(请参见第 2.2.1 节 “编辑配置文件”)并添加:Defaults !targetpw
选择新默认规则。
根据是否想要用户重新输入口令,取消对
/etc/sudoers
中特定行的注释,并将默认规则注释掉。## Uncomment to allow members of group wheel to execute any command # %wheel ALL=(ALL) ALL ## Same thing without a password # %wheel ALL=(ALL) NOPASSWD: ALL
提高默认规则的限制性
将
/etc/sudoers
中允许一切操作的规则注释掉或去除:ALL ALL=(ALL) ALL # WARNING! Only use this together with 'Defaults targetpw'!
警告:sudoers 中的危险规则切勿漏掉这一步,否则任何用户都能以
root
身份执行任何命令。测试配置
尝试以
wheel
的成员和非成员身份运行sudo
。tux:~ >
groups users wheeltux:~ >
sudo id -un tux's password: rootwilber:~ >
groups userswilber:~ >
sudo id -un wilber is not in the sudoers file. This incident will be reported.
2.3.2 对 X.Org 应用程序使用 sudo
#
在使用 sudo
启动图形应用程序时,可能会出现以下错误:
tux >
sudo
xterm xterm: Xt error: Can't open display: %s xterm: DISPLAY is not set
YaST 会选择 ncurses 界面而非图形界面。
要在通过 sudo
启动的应用程序中使用 X.Org,需要传播环境变量 DISPLAY
和 XAUTHORITY
。要进行此项配置,请创建文件 /etc/sudoers.d/xorg
(请参见第 2.2.1 节 “编辑配置文件”)并添加下面一行:
Defaults env_keep += "DISPLAY XAUTHORITY"
如尚未设置 XAUTHORITY
变量,请按如下方式设置:
export XAUTHORITY=~/.Xauthority
现在,X.Org 应用程序便可正常运行:
sudo yast2
2.4 更多信息 #
使用 sudo --help
可检索有关可用命令行开关的简要概述。如需说明和其他重要信息,请参见手册页:man 8 sudo
,配置相关信息详见 man 5 sudoers
。
3 YaST 联机更新 #
SUSE 持续为您的产品提供软件安全更新。默认情况下,用更新小程序来保持您的系统是最新的。有关更新小程序的更多信息请参考Book “Deployment Guide”, Chapter 16 “Installing or Removing Software”, Section 16.5 “The GNOME Package Updater”。本章介绍用于更新软件包的备用工具:YaST 联机更新。
更新软件储存库提供了 SUSE® Linux Enterprise Desktop 的最新增补程序。如果安装时已注册您的产品,则更新储存库已配置。如果您尚未注册 SUSE Linux Enterprise Desktop,可通过在 YaST 中启动 来完成注册。或者,可以从信任的源中手动添加更新储存库。要添加或去除储存库,请使用 YaST 中的 › 来启动储存库管理器。请在Book “Deployment Guide”, Chapter 16 “Installing or Removing Software”, Section 16.4 “Managing Software Repositories and Services”中了解更多有关储存库管理器的内容。
如果您不能访问更新编目,可能是由于订阅已过期。通常,SUSE Linux Enterprise Desktop 会附带一年或三年的订阅,在此期间您可以访问更新编目。订阅结束后,将拒绝您访问更新编目。
如果访问更新编目时遭到拒绝,您将看到一条警告讯息,提示您访问 SUSE Customer Center 并查看您的订阅。可通过 https://scc.suse.com// 访问 SUSE Customer Center。
SUSE 提供了不同相关级别的更新:
- 安全性更新
修复严重的安全性危害,请务必安装。
- 推荐更新
修复可能危及计算机安全的问题。
- 可选更新
修复非安全性相关的问题或提供增强功能。
3.1 联机更新对话框 #
要打开 YaST yast2 online_update
来启动该对话框。
窗口由四部分组成。
左侧的SUSE Linux Enterprise Desktop 可用的增补程序。增补程序按安全相关性(安全性
、推荐
和可选
)排序。您可以从 中选择以下某个选项来更改 部分的视图:
- (默认视图)
当前未安装的适用于系统上已安装的包的增补程序。
适用于系统上未安装的包的增补程序,或要求已满足的增补程序(因为已从另一源对相关包进行了更新)。
SUSE Linux Enterprise Desktop 的所有可用增补程序。
Shift–F1。安全性
和建议
增补程序需要的操作是自动预设置的。这些操作有 、 和 。
如果从非更新储存库的某个储存库安装最新包,此安装可能满足此包的某个增补程序的要求。在这种情况下,在增补程序摘要前会显示一个复选标记。该增补程序将显示在列表中,直到将其标记用于安装。这实际上不会安装增补程序(因为该包已经是最新的),而是将该增补程序标记为已安装。
在
部分选择一个项,可在对话框左下角的 中查看简短描述。右上部分列出所选增补程序中包含的包(一个增补程序可以由多个包组成)。单击右上部分中的项可以查看有关增补程序中包含的各个包的细节。3.2 安装增补程序 #
在 YaST 的“联机更新”对话框中,您可以一次性安装所有可用的增补程序,也可以手动选择所需的增补程序。还可以还原已应用于系统的增补程序。
默认情况下,您的系统当前可用的所有新增补程序(可选
增补程序除外)都已标记为可安装。一旦您单击 或 ,将自动应用它们。如果一个或多个增补程序需要重引导系统,在开始安装增补程序之前,系统会发出相关通知。此时,您可以选择继续安装所选增补程序、跳过需要重引导的所有增补程序的安装并安装剩余的增补程序,或者返回增补程序手动选择屏幕。
启动 YaST 并选择
› 。要自动应用您的系统当前可用的所有新增补程序(
可选
增补程序除外),请单击 或 。首先请修改要应用的增补程序选择:
使用界面中提供的相应过滤器和视图。有关详细信息,请参见第 3.1 节 “联机更新对话框”。
根据您的需要和喜好选择或取消选择增补程序,方法是右键单击增补程序并从上下文菜单中选择相应操作。
重要:始终应用安全性更新除非很有必要,否则请不要取消选择任何
安全性
相关的增补程序。因为这些增补程序可修复严重的安全性危害,防止系统遭受攻击。多数增补程序包含几个包的更新。要更改对单个包执行的操作,请在包视图中右键单击某个包,并选择一项操作。
要确认您的选择并应用所选增补程序,请单击
或 以继续。
安装完成后,单击
退出 YaST 。您的系统现在已是最新的了。
3.3 自动联机更新 #
YaST 还提供设置每日、每周或每月自动更新的选项。要使用相应模块,需要先安装 yast2-online-update-configuration
包。
默认情况下,更新将以增量 RPM 的形式供您下载。由于基于增量 RPM 重构建 RPM 包需要占用大量内存和处理器资源,出于性能考虑,某些设置或硬件配置可能要求您禁用增量 RPM。
某些增补程序(如需要许可协议的内核更新或包)需要用户交互,这可能会导致自动更新过程停止。您可以配置为跳过需要用户交互的增补程序。
安装后,启动 YaST 并选择
› 。也可以从命令行输入
yast2 online_update_configuration
来启动该模块。激活
。选择更新间隔:
、 或 。要自动接受任何许可协议,请激活
。有时,增补程序可能需要引起管理员的注意,例如,在重启动关键服务时。而此增补程序可能是适用于 Docker 开放源代码引擎的更新,运行此更新需要重启动所有容器。在安装增补程序之前,系统会向用户告知此操作的后果,并要求他们确认是否安装该增补程序。此类增补程序称为“交互式增补程序”。
自动安装增补程序时,系统会假设您已确认要安装交互式增补程序。如果您希望在安装之前先检查这些增补程序,请选择
。在这种情况下,自动增补期间会跳过交互式增补程序。请确保定期运行手动联机更新,以检查是否有交互式增补程序正在等待安装。要自动安装更新包推荐的所有软件包,请激活
。要禁用增量 RPM(出于性能方面的考虑),请停用
。要按照类别(例如安全性或推荐)过滤增补程序,请激活
,并从列表中添加适当的增补程序类别。只会安装选中类别的增补程序,而将跳过其他类别的增补程序。单击
确认您的配置。
之后,自动联机更新将不会自动重启动系统。如果有的包更新需要重引导系统,您需要手动重引导。
4 YaST #
YaST 是 SUSE Linux Enterprise Desktop 的安装和配置工具。它具有图形界面,并且能够在安装期间和安装之后快速自定义系统。它可用于设置硬件、配置网络、系统服务和调整安全性设置。
4.1 高级组合键 #
YaST 具有一套高级组合键。
- Print Screen
截图并保存。当 YaST 在某些桌面环境下运行时可能不可用。
- Shift–F4
启用/禁用为视力受损的用户专门优化的配色。
- Shift–F7
启用/禁用记录调试讯息。
- Shift–F8
打开一个文件对话框,以将日志文件保存到非标准位置。
- Ctrl–Shift–Alt–D
发送一个调试事件。YaST 模块可执行特殊的调试操作来对此作出反应。结果取决于具体的 YaST 模块。
- Ctrl–Shift–Alt–M
启动/停止宏记录器。
- Ctrl–Shift–Alt–P
重新播放宏。
- Ctrl–Shift–Alt–S
显示样式表编辑器。
- Ctrl–Shift–Alt–T
将控件树转储到日志文件。
- Ctrl–Shift–Alt–X
打开一个终端窗口 (xterm)。当通过 VNC 安装时很有用。
- Ctrl–Shift–Alt–Y
显示控件树浏览器。
5 文本方式的 YaST #
本章所针对的读者是在其系统上不运行 X 服务器而依赖于基于文本的安装工具的系统管理员和专家。它提供了与以文本方式启动和操作 YaST 有关的基本信息。
文本模式的 YaST 使用 ncurses 库提供简单的伪图形用户界面。默认情况下已安装 ncurses 库。用于运行 YaST 的终端仿真器支持的最小大小为 80x25 个字符。
以文本模式启动 YaST 时,会显示 YaST 控制中心(请参见图 5.1)。该窗口包含三个区域。左侧方框中显示各种模块所属的类别。此方框在 YaST 启动后处于活动状态,因此以白色粗边框进行标记。活动类别处于选中状态。右侧方框提供活动类别中可用模块的概述。底部框架中包含 和 按钮。
启动 YaST 控制中心时,会自动选择↓ 和 ↑ 可更改类别。要从类别中选择某个模块,请使用 → 激活右侧方框,然后使用 ↓ 和 ↑ 选择该模块。按住箭头键在可用模块列表中滚动。选择模块后,按 Enter 将其启动。
类别。使用模块中的各种按钮和选择字段包含一个高亮显示的字母(默认为黄色)。使用 Alt–highlighted_letter 可直接选择按钮,而无需使用 →| 键导航。要退出 YaST 控制中心,请按 Alt–Q,或者选择 并按 Enter。
如果 YaST 对话框损坏或变形(例如在调整窗口大小时),请按 Ctrl–L 来刷新并恢复其内容。
5.2 高级组合键 #
文本模式的 YaST 具有一套高级组合键。
- Shift–F1
列出高级热键。
- Shift–F4
更改颜色方案。
- Ctrl–\
退出应用程序。
- Ctrl–L
刷新屏幕。
- Ctrl–DF1
列出高级热键。
- Ctrl–DShift– D
以屏幕截图的形式将对话框转储到日志文件。
- Ctrl–DShift–Y
打开 YDialogSpy 以查看控件层次结构。
5.3 组合键的限制 #
如果您的窗口管理器使用全局 Alt 组合键,则 YaST 中的 Alt 组合键可能无效。像 Alt 或 Shift 这样的键也可能会被终端设置占用。
- 使用 Esc 取代 Alt
可以代替 Alt 而使用 EscAlt 快捷键。例如,Esc–H 可代替 Alt–H。(首先按 Esc,然后按 H 键。)
- 使用 Ctrl–F 和 Ctrl–B 执行向后和向前导航
如果 Alt 和 Shift 组合键由窗口管理器或终端占用,可改用组合键 Ctrl–F(向前)和 Ctrl–B(向后)。
- 功能键的限制
功能键 (F1 ... F12) 也用于执行多种功能。某些功能键可能会被终端占用而不能用于 YaST。但 Alt 组合键和功能键应该始终在纯文本控制台上完全可用。
5.4 YaST 命令行选项 #
除了文本模式界面以外,YaST 还提供了一个纯命令行界面。要获取 YaST 命令行选项列表,请输入:
tux >
sudo
yast -h
5.4.1 从命令行安装包 #
如果您知道包名称,且该包是由您的某个活动安装储存库提供的,则可以使用命令行选项 -i
安装该包:
tux >
sudo
yast -i package_name
或者
tux >
sudo
yast --install -i package_name
package_name 可以是安装时经过依赖项检查的单个简短包名(例如 gvim),也可以是安装时未经过依赖项检查的 RPM 包的完整路径。
如果需要具有 YaST 未提供的功能的,基于命令行的软件管理实用程序,请考虑使用 Zypper。此实用程序使用相同的软件管理库,这也是 YaST 包管理器的基础。第 6.1 节 “使用 Zypper”中介绍了 Zypper 的基本用法。
5.4.2 启动单个模块 #
为了节省时间,可以直接启动单个 YaST 模块。要启动模块,请输入:
tux >
sudo
yast module_name
要查看系统上所有可用模块名称的列表,请使用 yast -l
或 yast --list
。例如,要启动网络模块,请输入 yast lan
。
5.4.3 YaST 模块的命令行参数 #
为了在脚本中使用 YaST 功能,YaST 提供了对单个模块的命令行支持。并非所有模块都具有命令行支持。要显示某个模块的可用选项,请输入:
tux >
sudo
yast module_name help
如果某个模块未提供命令行支持,将以文本模式启动,并显示以下讯息:
This YaST module does not support the command line interface.
下列各节介绍所有 YaST 模块及命令行支持,并简要说明了其所有命令和可用选项。
5.4.3.1 常用 YaST 模块命令 #
所有 YaST 模块都支持以下命令:
- help
列出各模块支持的命令及其说明:
tux >
sudo
yast lan help- longhelp
与
help
作用相同,但添加了每个命令的选项及其说明的详细列表:tux >
sudo
yast lan longhelp- xmlhelp
与
longhelp
作用相同,但输出采用 XML 文本结构并重定向至某个文件:tux >
sudo
yast lan xmlhelp xmlfile=/tmp/yast_lan.xml- interactive
如果您需要花更多时间查询模块的设置,请以交互模式运行。YaST 外壳将会打开,您可以在该处输入所有模块的命令,无需带
sudo yast ...
前缀。要退出交互模式,请输入exit
。
5.4.3.2 yast add-on #
从指定的路径添加新附加产品:
tux >
sudo
yast add-on http://server.name/directory/Lang-AddOn-CD1/
您可以使用以下协议来指定来源路径:http:// ftp:// nfs:// disk:// cd:// 或 dvd://。
5.4.3.3 yast audit-laf #
显示和配置 Linux Audit Framework。有关更多细节,请参见Book “Security and Hardening Guide”。yast audit-laf
接受以下命令:
- set
设置选项:
tux >
sudo
yast audit-laf set log_file=/tmp/audit.log要显示完整的选项列表,请运行
yast audit-laf set help
。- show
显示选项的设置:
tux >
sudo
yast audit-laf show diskspace space_left: 75 space_left_action: SYSLOG admin_space_left: 50 admin_space_left_action: SUSPEND action_mail_acct: root disk_full_action: SUSPEND disk_error_action: SUSPEND要显示完整的选项列表,请运行
yast audit-laf show help
。
5.4.3.4 yast dhcp-server #
管理 DHCP 服务器以及配置其设置。yast dhcp-server
接受以下命令:
- disable
禁用 DHCP 服务器服务。
- enable
启用 DHCP 服务器服务。
- host
配置单个主机的设置。
- interface
指定要侦听的网络接口:
tux >
sudo
yast dhcp-server interface current Selected Interfaces: eth0 Other Interfaces: bond0, pbu, eth1要显示完整的选项列表,请运行
yast dhcp-server interface help
。- options
管理全局 DHCP 选项。要显示完整的选项列表,请运行
yast dhcp-server options help
。- status
打印 DHCP 服务的状态。
- subnet
管理 DHCP 子网选项。要显示完整的选项列表,请运行
yast dhcp-server subnet help
。
5.4.3.5 yast dns-server #
管理 DNS 服务器配置。yast dns-server
接受以下命令:
- acls
显示访问控制列表设置:
tux >
sudo
yast dns-server acls show ACLs: ----- Name Type Value ---------------------------- any Predefined localips Predefined localnets Predefined none Predefined- dnsrecord
配置区域资源记录:
tux >
sudo
yast dnsrecord add zone=example.org query=office.example.org type=NS value=ns3要显示完整的选项列表,请运行
yast dns-server dnsrecord help
。- forwarders
配置 DNS 转发器:
tux >
sudo
yast dns-server forwarders add ip=10.0.0.100tux >
sudo
yast dns-server forwarders show [...] Forwarder IP ------------ 10.0.0.100要显示完整的选项列表,请运行
yast dns-server forwarders help
。- host
立即处理“A”及其相关的“PTR”记录:
tux >
sudo
yast dns-server host show zone=example.org要显示完整的选项列表,请运行
yast dns-server host help
。- logging
配置日志记录设置:
tux >
sudo
yast dns-server logging set updates=no transfers=yes要显示完整的选项列表,请运行
yast dns-server logging help
。- mailserver
配置区域邮件服务器:
tux >
sudo
yast dns-server mailserver add zone=example.org mx=mx1 priority=100要显示完整的选项列表,请运行
yast dns-server mailserver help
。- nameserver
配置区域名称服务器:
tux >
sudo
yast dns-server nameserver add zone=example.com ns=ns1要显示完整的选项列表,请运行
yast dns-server nameserver help
。- soa
配置授权起始 (SOA) 记录:
tux >
sudo
yast dns-server soa set zone=example.org serial=2006081623 ttl=2D3H20S要显示完整的选项列表,请运行
yast dns-server soa help
。- startup
管理 DNS 服务器服务:
tux >
sudo
yast dns-server startup atboot要显示完整的选项列表,请运行
yast dns-server startup help
。- transport
配置区域传输规则。要显示完整的选项列表,请运行
yast dns-server transport help
。- zones
管理 DNS 区域:
tux >
sudo
yast dns-server zones add name=example.org zonetype=master要显示完整的选项列表,请运行
yast dns-server zones help
。
5.4.3.6 yast disk #
打印所有磁盘或分区的相关信息。唯一支持的命令是 list
,后跟以下任一选项:
- disks
列出系统中配置的所有磁盘:
tux >
sudo
yast disk list disks Device | Size | FS Type | Mount Point | Label | Model ---------+------------+---------+-------------+-------+------------- /dev/sda | 119.24 GiB | | | | SSD 840 /dev/sdb | 60.84 GiB | | | | WD1003FBYX-0- partitions
列出系统中的所有分区:
tux >
sudo
yast disk list partitions Device | Size | FS Type | Mount Point | Label | Model ---------------+------------+---------+-------------+-------+------ /dev/sda1 | 1.00 GiB | Ext2 | /boot | | /dev/sdb1 | 1.00 GiB | Swap | swap | | /dev/sdc1 | 698.64 GiB | XFS | /mnt/extra | | /dev/vg00/home | 580.50 GiB | Ext3 | /home | | /dev/vg00/root | 100.00 GiB | Ext3 | / | | [...]
5.4.3.7 yast firewall #
显示有关防火墙设置的信息。yast firewall
接受以下命令:
- broadcast
显示广播数据包的设置。
- disable
禁用防火墙。
- enable
启用防火墙。
- interfaces
显示与网络接口相关的配置。
- logging
显示日志记录设置。
- masqredirect
将请求重定向到掩蔽的 IP。
- masquerade
显示掩蔽设置。
- services
显示有关允许的服务、端口和协议的信息。
- startup
显示启动设置。
- summary
显示防火墙配置摘要。
- zones
列出已知的防火墙区域。
5.4.3.8 yast ftp-server #
配置 FTP 服务器设置。yast ftp-server
接受以下选项:
- SSL、SSLv2、SSLv3、TLS
控制通过 SSL 到 SSL 版本 3 及 TLS 进行的安全连接。SSL 选项仅对
vsftpd
有效。tux >
sudo
yast ftp-server SSLv2 enabletux >
sudo
yast ftp-server TLS disable- access
配置访问权限:
tux >
sudo
yast ftp-server access authen_only要显示完整的选项列表,请运行
yast ftp-server access help
。- anon_access
配置匿名用户的访问权限:
tux >
sudo
yast ftp-server anon_access can_upload要显示完整的选项列表,请运行
yast ftp-server anon_access help
。- anon_dir
指定匿名用户的目录。服务器上必须已存在该目录:
tux >
sudo
yast ftp-server anon_dir set_anon_dir=/srv/ftp要显示完整的选项列表,请运行
yast ftp-server anon_dir help
。- chroot
控制 change root 环境 (chroot):
tux >
sudo
yast ftp-server chroot enabletux >
sudo
yast ftp-server chroot disable- idle-time
设置最大闲置时间(分钟),经过该时间后 FTP 服务器会终止当前的连接:
tux >
sudo
yast ftp-server idle-time set_idle_time=15- logging
控制是否将日志讯息保存到日志文件中:
tux >
sudo
yast ftp-server logging enabletux >
sudo
yast ftp-server logging disable- max_clients
指定并行连接的客户端的最大数目:
tux >
sudo
yast ftp-server max_clients set_max_clients=1500- max_clients_ip
指定通过 IP 并行连接的客户端的最大数目:
tux >
sudo
yast ftp-server max_clients_ip set_max_clients=20- max_rate_anon
指定匿名客户端允许使用的最大数据传输速度 (KB/s):
tux >
sudo
yast ftp-server max_rate_anon set_max_rate=10000- max_rate_authen
指定通过本地身份验证的用户允许使用的最大数据传输速度 (KB/s):
tux >
sudo
yast ftp-server max_rate_authen set_max_rate=10000- port_range
指定被动连接答复的端口范围:
tux >
sudo
yast ftp-server port_range set_min_port=20000 set_max_port=30000要显示完整的选项列表,请运行
yast ftp-server port_range help
。- show
显示 FTP 服务器设置。
- startup
控制 FTP 启动方法:
tux >
sudo
yast ftp-server startup atboot要显示完整的选项列表,请运行
yast ftp-server startup help
。- umask
指定
authenticated:anonymous
用户的文件权限掩码:tux >
sudo
yast ftp-server umask set_umask=177:077- welcome_message
指定当用户连接到 FTP 服务器时显示的文本:
tux >
sudo
yast ftp-server welcome_message set_message="hello everybody"
5.4.3.9 yast http-server #
配置 HTTP 服务器 (Apache2)。yast http-server
接受以下命令:
- configure
配置 HTTP 服务器主机设置:
tux >
sudo
yast http-server configure host=main servername=www.example.com \ serveradmin=admin@example.com要显示完整的选项列表,请运行
yast http-server configure help
。
- hosts
配置虚拟主机:
tux >
sudo
yast http-server hosts create servername=www.example.com \ serveradmin=admin@example.com documentroot=/var/www要显示完整的选项列表,请运行
yast http-server hosts help
。
- listen
指定 HTTP 服务器应该侦听的端口和网络地址:
tux >
sudo
yast http-server listen add=81tux >
sudo
yast http-server listen list Listen Statements: ================== :80 :81tux >
sudo
yast http-server delete=80要显示完整的选项列表,请运行
yast http-server listen help
。
- mode
启用或禁用向导模式:
tux >
sudo
yast http-server mode wizard=on
- modules
控制 Apache2 服务器模块:
tux >
sudo
yast http-server modules enable=php5,rewritetux >
sudo
yast http-server modules disable=ssltux >
sudo
http-server modules list [...] Enabled rewrite Disabled ssl Enabled php5 [...]
5.4.3.10 yast kdump #
配置 kdump
设置。有关 kdump
的详细信息,请参见Book “System Analysis and Tuning Guide”, Chapter 17 “Kexec and Kdump”, Section 17.7 “Basic Kdump Configuration”。yast kdump
接受以下命令:
- copykernel
将内核复制到转储目录。
- customkernel
指定自定义内核名称的 kernel_string 部分。命名模式为
/boot/vmlinu[zx]-kernel_string[.gz]
。tux >
sudo
yast kdump customkernel kernel=kdump要显示完整的选项列表,请运行
yast kdump customkernel help
。- dumpformat
指定转储内核映像的(压缩)格式。可用格式有“none”、“ELF”、“compressed”或“lzo”:
tux >
sudo
yast kdump dumpformat dump_format=ELF- dumplevel
指定转储级别,范围从 0 到 31:
tux >
sudo
yast kdump dumplevel dump_level=24- dumptarget
指定用于保存转储映像的目标:
tux >
sudo
kdump dumptarget taget=ssh server=name_server port=22 \ dir=/var/log/dump user=user_name要显示完整的选项列表,请运行
yast kdump dumptarget help
。- immediatereboot
控制系统是否应该在将核心保存到 kdump 内核中后立即重引导:
tux >
sudo
yast kdump immediatereboot enabletux >
sudo
yast kdump immediatereboot disable- keepolddumps
指定保留旧转储映像的数量。可指定保留零个到全部保留:
tux >
sudo
yast kdump keepolddumps no=5- kernelcommandline
指定需要传递到 kdump 内核的命令行:
tux >
sudo
yast kdump kernelcommandline command="ro root=LABEL=/"- kernelcommandlineappend
指定需要追加到默认命令行字符串的命令行:
tux >
sudo
yast kdump kernelcommandlineappend command="ro root=LABEL=/"- notificationcc
指定用于抄送通知邮件的电子邮件地址:
tux >
sudo
yast kdump notificationcc email="user1@example.com user2@example.com"- notificationto
指定用于发送通知邮件的电子邮件地址:
tux >
sudo
yast kdump notificationto email="user1@example.com user2@example.com"- show
显示
kdump
设置:tux >
sudo
yast kdump show Kdump is disabled Dump Level: 31 Dump Format: compressed Dump Target Settings target: file file directory: /var/crash Kdump immediate reboots: Enabled Numbers of old dumps: 5- smtppass
指定含有用于发送通知邮件的纯文本 SMTP 口令的文件:
tux >
sudo
yast kdump smtppass pass=/path/to/file- smtpserver
指定用于发送通知邮件的 SMTP 服务器主机名:
tux >
sudo
yast kdump smtpserver server=smtp.server.com- smtpuser
指定用于发送通知邮件的 SMTP 用户名:
tux >
sudo
yast kdump smtpuser user=smtp_user- startup
启用或禁用启动选项:
tux >
sudo
yast kdump startup enable alloc_mem=128,256tux >
sudo
yast kdump startup disable
5.4.3.11 yast keyboard #
配置虚拟控制台的系统键盘。它不会影响图形桌面环境(例如 GNOME 或 KDE)中的键盘设置。yast keyboard
接受以下命令:
- list
列出所有可用的键盘布局。
- set
激活新的键盘布局设置:
tux >
sudo
yast keyboard set layout=czech- summary
显示当前的键盘配置。
5.4.3.12 yast lan #
配置网卡。yast lan
接受以下命令:
- add
配置新网卡:
tux >
sudo
yast lan add name=vlan50 ethdevice=eth0 bootproto=dhcp要显示完整的选项列表,请运行
yast lan add help
。- delete
删除某个现有网卡:
tux >
sudo
yast lan delete id=0- edit
更改某个现有网卡的配置:
tux >
sudo
yast lan edit id=0 bootproto=dhcp- list
显示网卡配置摘要:
tux >
sudo
yast lan list id name, bootproto 0 Ethernet Card 0, NONE 1 Network Bridge, DHCP
5.4.3.13 yast language #
配置系统语言。yast language
接受以下命令:
- list
列出所有可用的语言。
- set
指定系统的主要语言和次要语言:
tux >
sudo
yast language set lang=cs_CZ languages=en_US,es_ES no_packages
5.4.3.14 yast mail #
显示邮件系统的配置:
tux >
sudo
yast mail summary
5.4.3.15 yast nfs #
控制 NFS 客户端。yast nfs
接受以下命令:
- add
添加新 NFS 载具:
tux >
sudo
yast nfs add spec=remote_host:/path/to/nfs/share file=/local/mount/point要显示完整的选项列表,请运行
yast nfs add help
。- delete
删除现有的 NFS 载具:
tux >
sudo
yast nfs delete spec=remote_host:/path/to/nfs/share file=/local/mount/point要显示完整的选项列表,请运行
yast nfs delete help
。- edit
更改现有的 NFS 载具:
tux >
sudo
yast nfs edit spec=remote_host:/path/to/nfs/share \ file=/local/mount/point type=nfs4要显示完整的选项列表,请运行
yast nfs edit help
。- list
列出现有的 NFS 载具:
tux >
sudo
yast nfs list Server Remote File System Mount Point Options ---------------------------------------------------------------- nfs.example.com /mnt /nfs/mnt nfs nfs.example.com /home/tux/nfs_share /nfs/tux nfs
5.4.3.16 yast nfs-server #
配置 NFS 服务器。yast nfs-server
接受以下命令:
- add
将目录添加到导出中:
tux >
sudo
yast nfs-server add mountpoint=/nfs/export hosts=*.allowed_hosts.com要显示完整的选项列表,请运行
yast nfs-server add help
。- delete
从 NFS 导出中删除目录:
tux >
sudo
yast nfs-server delete mountpoint=/nfs/export- set
指定 NFS 服务器的其他参数:
tux >
sudo
yast nfs-server set enablev4=yes security=yes要显示完整的选项列表,请运行
yast nfs-server set help
。- start
启动 NFS 服务器服务:
tux >
sudo
yast nfs-server start- stop
停止 NFS 服务器服务:
tux >
sudo
yast nfs-server stop- summary
显示 NFS 服务器配置摘要:
tux >
sudo
yast nfs-server summary NFS server is enabled NFS Exports * /mnt * /home NFSv4 support is enabled. The NFSv4 domain for idmapping is localdomain. NFS Security using GSS is enabled.
5.4.3.17 yast nis #
配置 NIS 客户端。yast nis
接受以下命令:
- configure
更改 NIS 客户端的全局设置:
tux >
sudo
yast nis configure server=nis.example.com broadcast=yes要显示完整的选项列表,请运行
yast nis configure help
。- disable
禁用 NIS 客户端:
tux >
sudo
yast nis disable- enable
允许您的计算机作为 NIS 客户端:
tux >
sudo
yast nis enable server=nis.example.com broadcast=yes automounter=yes要显示完整的选项列表,请运行
yast nis enable help
。- find
显示给定域的可用 NIS 服务器:
tux >
sudo
yast nis find domain=nisdomain.com- summary
显示 NIS 客户端的配置摘要。
5.4.3.18 yast nis-server #
配置 NIS 服务器。yast nis-server
接受以下命令:
- master
配置 NIS 主服务器:
tux >
sudo
yast nis-server master domain=nisdomain.com yppasswd=yes要显示完整的选项列表,请运行
yast nis-server master help
。- slave
配置 NIS 从属服务器:
tux >
sudo
yast nis-server slave domain=nisdomain.com master_ip=10.100.51.65要显示完整的选项列表,请运行
yast nis-server slave help
。- stop
停止 NIS 服务器:
tux >
sudo
yast nis-server stop- summary
显示 NIS 服务器配置摘要:
tux >
sudo
yast nis-server summary
5.4.3.19 yast proxy #
配置代理设置。yast proxy
接受以下命令:
- authentication
指定代理的身份验证选项:
tux >
sudo
yast proxy authentication username=tux password=secret要显示完整的选项列表,请运行
yast proxy authentication help
。- enable、disable
启用或禁用代理设置。
- set
更改当前代理设置:
tux >
sudo
yast proxy set https=proxy.example.com要显示完整的选项列表,请运行
yast proxy set help
。- summary
显示代理设置。
5.4.3.20 yast rdp #
控制远程桌面设置。yast rdp
接受以下命令:
- allow
允许远程访问服务器的桌面:
tux >
sudo
yast rdp allow set=yes- list
显示远程桌面配置摘要。
5.4.3.21 yast samba-client #
配置 Samba 客户端设置。yast samba-client
接受以下命令:
- configure
更改 Samba 的全局设置:
tux >
sudo
yast samba-client configure workgroup=FAMILY- isdomainmember
校验计算机是否为域成员:
tux >
sudo
yast samba-client isdomainmember domain=SMB_DOMAIN- joindomain
让计算机成为域成员:
tux >
sudo
yast samba-client joindomain domain=SMB_DOMAIN user=username password=pwd- winbind
启用或禁用 Winbind 服务(
winbindd
守护程序):tux >
sudo
yast samba-client winbind enabletux >
sudo
yast samba-client winbind disable
5.4.3.22 yast samba-server #
配置 Samba 服务器设置。yast samba-server
接受以下命令:
- backend
指定储存用户信息的后端:
tux >
sudo
yast samba-server backend smbpasswd要显示完整的选项列表,请运行
yast samba-server backend help
。- configure
配置 Samba 服务器的全局设置:
tux >
sudo
yast samba-server configure workgroup=FAMILY description='Home server'要显示完整的选项列表,请运行
yast samba-server configure help
。- list
显示可用共享列表:
tux >
sudo
yast samba-server list Status Type Name ============================== Disabled Disk profiles Enabled Disk print$ Enabled Disk homes Disabled Disk groups Enabled Disk movies Enabled Printer printers- role
指定 Samba 服务器的角色:
tux >
sudo
yast samba-server role standalone要显示完整的选项列表,请运行
yast samba-server role help
。- service
启用或禁用 Samba 服务(
smb
和nmb
):tux >
sudo
yast samba-server service enabletux >
sudo
yast samba-server service disable- share
操作单个 Samba 共享:
tux >
sudo
yast samba-server share name=movies browseable=yes guest_ok=yes要显示完整的选项列表,请运行
yast samba-server share help
。
5.4.3.23 yast security #
控制主机的安全级别。yast security
接受以下命令:
- level
指定主机的安全级别:
tux >
sudo
yast security level server要显示完整的选项列表,请运行
yast security level help
。- set
设置特定选项的值:
tux >
sudo
yast security set passwd=sha512 crack=yes要显示完整的选项列表,请运行
yast security set help
。- summary
显示当前安全配置的摘要:
sudo
yast security summary
5.4.3.24 yast sound #
配置声卡设置。yast sound
接受以下命令:
- add
配置新声卡。不使用任何参数时,该命令会添加检测到的第一个声卡。
tux >
sudo
yast sound add card=0 volume=75要显示完整的选项列表,请运行
yast sound add help
。- channels
列出声卡的可用音量声道:
tux >
sudo
yast sound channels card=0 Master 75 PCM 100- modules
列出所有可用的声音内核模块:
tux >
sudo
yast sound modules snd-atiixp ATI IXP AC97 controller (snd-atiixp) snd-atiixp-modem ATI IXP MC97 controller (snd-atiixp-modem) snd-virtuoso Asus Virtuoso driver (snd-virtuoso) [...]- playtest
在声卡上播放测试声音:
tux >
sudo
yast sound playtest card=0- remove
去除配置的声卡:
tux >
sudo
yast sound remove card=0tux >
sudo
yast sound remove all- set
为声卡指定新值:
tux >
sudo
yast sound set card=0 volume=80- show
显示有关声卡的详细信息:
tux >
sudo
yast sound show card=0 Parameters of card 'ThinkPad X240' (using module snd-hda-intel): align_buffer_size Force buffer and period sizes to be multiple of 128 bytes. bdl_pos_adj BDL position adjustment offset. beep_mode Select HDA Beep registration mode (0=off, 1=on) (default=1). Default Value: 0 enable_msi Enable Message Signaled Interrupt (MSI) [...]- summary
打印系统上所有声卡的配置摘要:
tux >
sudo
yast sound summary- volume
指定声卡的音量级别:
sudo
yast sound volume card=0 play
5.4.3.25 yast sysconfig #
控制 /etc/sysconfig
下的文件中的变量。yast sysconfig
接受以下命令:
- clear
为变量设置空值:
tux >
sudo
yast sysconfig clear=POSTFIX_LISTEN提示:多个文件中的变量如果变量在多个文件中可用,请使用 VARIABLE_NAME$FILE_NAME 语法:
tux >
sudo
yast sysconfig clear=CONFIG_TYPE$/etc/sysconfig/mail- details
显示有关变量的详细信息:
tux >
sudo
yast sysconfig details variable=POSTFIX_LISTEN Description: Value: File: /etc/sysconfig/postfix Possible Values: Any value Default Value: Configuration Script: postfix Description: Comma separated list of IP's NOTE: If not set, LISTEN on all interfaces- list
显示已修改变量的摘要。使用
all
可列出所有变量及相应的值:tux >
sudo
yast sysconfig list all AOU_AUTO_AGREE_WITH_LICENSES="false" AOU_ENABLE_CRONJOB="true" AOU_INCLUDE_RECOMMENDS="false" [...]- set
为变量设置值:
tux >
sudo
yast sysconfig set DISPLAYMANAGER=gdm提示:多个文件中的变量如果变量在多个文件中可用,请使用 VARIABLE_NAME$FILE_NAME 语法:
tux >
sudo
yast sysconfig set CONFIG_TYPE$/etc/sysconfig/mail=advanced
5.4.3.26 yast tftp-server #
配置 TFTP 服务器。yast tftp-server
接受以下命令:
- directory
指定 TFTP 服务器的目录:
tux >
sudo
yast tftp-server directory path=/srv/tftptux >
sudo
yast tftp-server directory list Directory Path: /srv/tftp- status
控制 TFTP 服务器服务的状态:
tux >
sudo
yast tftp-server status disabletux >
sudo
yast tftp-server status show Service Status: falsetux >
sudo
yast tftp-server status enable
5.4.3.27 yast timezone #
配置时区。yast timezone
接受以下命令:
- list
按地区分组列出所有可用的时区:
tux >
sudo
yast timezone list Region: Africa Africa/Abidjan (Abidjan) Africa/Accra (Accra) Africa/Addis_Ababa (Addis Ababa) [...]- set
为时区配置指定新值:
tux >
sudo
yast timezone set timezone=Europe/Prague hwclock=local- summary
显示时区配置摘要:
tux >
sudo
yast timezone summary Current Time Zone: Europe/Prague Hardware Clock Set To: Local time Current Time and Date: Mon 12. March 2018, 11:36:21 CET
5.4.3.28 yast users #
管理用户帐户。yast users
接受以下命令:
- add
添加新用户:
tux >
sudo
yast users add username=user1 password=secret home=/home/user1要显示完整的选项列表,请运行
yast users add help
。- delete
删除现有用户帐户:
tux >
sudo
yast users delete username=user1 delete_home要显示完整的选项列表,请运行
yast users delete help
。- edit
更改现有用户帐户:
tux >
sudo
yast users edit username=user1 password=new_secret要显示完整的选项列表,请运行
yast users edit help
。- list
列出按用户类型过滤的现有用户:
tux >
sudo
yast users list system要显示完整的选项列表,请运行
yast users list help
。- show
显示有关某个用户的细节:
tux >
sudo
yast users show username=wwwrun Full Name: WWW daemon apache List of Groups: www Default Group: wwwrun Home Directory: /var/lib/wwwrun Login Shell: /sbin/nologin Login Name: wwwrun UID: 456要显示完整的选项列表,请运行
yast users show help
。
6 使用命令行工具管理软件 #
本章描述 Zypper 和 RPM,这是两个用于管理软件的命令行工具。有关此环境中使用的术语定义(例如,储存库
、增补程序
或更新
),请参见Book “Deployment Guide”, Chapter 16 “Installing or Removing Software”, Section 16.1 “Definition of Terms”。
6.1 使用 Zypper #
Zypper 是用于安装、更新和去除包的命令行包管理器。它还可管理储存库。这一点对于完成远程软件管理任务或从外壳脚本管理软件尤其有用。
6.1.1 一般使用 #
Zypper 的常用语法为:
zypper[--global-options]
COMMAND[--command-options]
[arguments]
不需要括在括号中的组件。有关常规选项和所有命令的列表,请参见 zypper help
。要获取有关特定命令的帮助,请键入 zypper help
命令。
- Zypper 命令
执行 Zypper 最简单的方式是,键入其名称后跟一个命令。例如,要将所有需要的增补程序应用于系统,请使用:
tux >
sudo
zypper patch- 全局选项
此外,您还可以选择使用一个或多个全局选项,只需在命令前面键入它们即可:
tux >
sudo
zypper --non-interactive patch在上面的示例中,选项
--non-interactive
表示在不询问任何问题的情况下运行命令(自动应用默认回答)。- 命令特定的选项
要使用特定于某个命令的选项,请紧接在该命令后面键入这些选项:
tux >
sudo
zypper patch --auto-agree-with-licenses在上面的示例中,
--auto-agree-with-licenses
用于将所有需要的增补程序应用于系统,不要求您确认任何许可条款,而是自动接受许可条款。- 自变量
某些命令需要一个或多个自变量。例如,使用
install
命令时,需要指定您要安装的一个或多个包:tux >
sudo
zypper install mplayer某些选项还需要单个自变量。用以下命令可列出所有已知模式:
tux >
zypper search -t pattern
您可以组合上述所有模式。例如,下面的命令在冗长模式下运行时将安装 mc and vim 包(来自 factory
储存库):
tux >
sudo
zypper -v install --from factory mc vim
--from
选项确保了在从指定储存库请求包时保留所有储存库的启用状态(用于解析任何依赖项)。
多数 Zypper 命令都有 dry-run
选项,它模拟给定的命令。它可用于测试。
tux >
sudo
zypper remove --dry-run MozillaFirefox
Zypper 支持 --userdata 字符串
全局选项。您可以使用此选项指定一个将会写入 Zypper 的日志文件和插件(例如 Btrfs 插件)的字符串。它可以用于标记和标识日志文件中的事务。
tux >
sudo
zypper --userdata STRING patch
6.1.2 使用 Zypper 安装和删除软件 #
要安装或去除包,请使用以下命令:
tux >
sudo
zypper install PACKAGE_NAME sudo zypper remove PACKAGE_NAME
不要去除必需的系统包,例如 glibc 、 zypper 、 kernel 。如果去除这些包,系统可能会变得不稳定,或完全停止工作。
6.1.2.1 选择要安装或去除的包 #
可以使用 zypper install
和 zypper remove
命令通过多种方法来找到包。
- 按确切的包名称
tux >
sudo
zypper install MozillaFirefox- 按确切的包名称和版本号
tux >
sudo
zypper install MozillaFirefox-52.2- 按储存库别名和包名称
tux >
sudo
zypper install mozilla:MozillaFirefox其中
mozilla
是用于安装的储存库别名。- 使用通配符按包名称
您可以选择名称以特定字符串开头或结尾的所有包。使用通配符要小心,特别是去除包的时候。以下命令将安装名称以“Moz”开头的所有包:
tux >
sudo
zypper install 'Moz*'提示:去除所有-debuginfo
包在调试问题时,您有时需要临时安装大量的
-debuginfo
包,以获取有关正在运行的进程的详细信息。在调试会话完成后,如果您需要清理环境,请运行以下命令:tux >
sudo
zypper remove '*-debuginfo'- 按功能
例如,要安装不知道名称的包,这些功能就很有用。下面的命令将安装包 MozillaFirefox:
tux >
sudo
zypper install firefox- 按功能、硬件体系结构或版本
可以结合功能指定硬件体系结构和版本:
所需硬件体系结构的名称需要追加在功能的后面,两者以句点分隔。例如,要指定 AMD64/Intel 64 体系结构(在 Zypper 中命名为
x86_64
),请使用:tux >
sudo
zypper install 'firefox.x86_64'版本必须追加到字符串的末尾,并且前面必须带有一个运算符:
<
(小于)、<=
(小于等于)、=
(等于)、>=
(大于等于)或>
(大于)。tux >
sudo
zypper install 'firefox>=52.2'还可以指定硬件体系结构与版本组合要求:
tux >
sudo
zypper install 'firefox.x86_64>=52.2'
- 按 RPM 文件的路径
您还可以指定包的本地或远程路径:
tux >
sudo
zypper install /tmp/install/MozillaFirefox.rpmtux >
sudo
zypper install http://download.example.com/MozillaFirefox.rpm
6.1.2.2 同时安装和去除包 #
要同时安装和去除包,请使用 +/-
修饰符。要安装
emacs
并同时去除
vim
,请使用:
tux >
sudo
zypper install emacs -vim
要去除 emacs 并同时安装 vim ,请使用:
tux >
sudo
zypper remove emacs +vim
为避免 -
开头的包名称被解释为命令行选项,要始终把它用作第二个自变量。如果做不到这点,在它之前加上 --
:
tux >
sudo
zypper install -emacs +vim # Wrongtux >
sudo
zypper install vim -emacs # Correcttux >
sudo
zypper install -- -emacs +vim # Correcttux >
sudo
zypper remove emacs +vim # Correct
6.1.2.3 清理已去除包的依赖项 #
如果您想将在指定的包去除后不再需要的所有包(随指定的包)自动去除,请使用 --clean-deps
选项:
tux >
sudo
zypper rm PACKAGE_NAME --clean-deps
6.1.2.4 在脚本中使用 Zypper #
默认情况下,在安装或删除选定包之前或发生问题时,Zypper 会要求确认。您可以使用 --non-interactive
选项覆盖此行为。必须在实际命令(install
、remove
和 patch
)的前面指定此选项,如下所示:
tux >
sudo
zypper--non-interactive
install PACKAGE_NAME
该选项允许在脚本和 cron 任务中使用 Zypper。
6.1.2.5 安装或下载源包 #
要安装某个包的对应源代码包,请使用:
tux >
zypper source-install PACKAGE_NAME
以 root
身份执行时,源包的默认安装位置为 /usr/src/packages/
;以用户身份运行时,则为 ~/rpmbuild
。可以在本地 rpm
配置中更改这些值。
使用此命令还会安装指定包的版本依赖项。如果不想执行此操作,请添加开关 -D
:
tux >
sudo
zypper source-install -D PACKAGE_NAME
要只安装版本依赖项,请使用 -d
。
tux >
sudo
zypper source-install -d PACKAGE_NAME
当然,只有当储存库列表中启用了含有源包的储存库时,才能这样做(默认添加但不启用它)。请参见第 6.1.5 节 “用 Zypper 管理安装源” 了解有关储存库管理的细节。
可使用以下方法来获取储存库中所有源包的列表:
tux >
zypper search -t srcpackage
您也可以将所有已安装软件包的源包下载到本地目录。要下载源包,请使用:
tux >
zypper source-download
默认的下载目录是 /var/cache/zypper/source-download
。您可以使用 --directory
选项更改下载目录。若只想显示缺失或多余的包而不进行下载或删除任何内容,请使用 --status
选项。要删除多余的源包,请使用 --delete
选项。要禁用删除,请使用 --no-delete
选项。
6.1.2.6 从禁用的储存库安装包 #
通常,您只能安装或刷新来自启用的储存库的包。--plus-content 标记
选项可帮助您指定要刷新的、要在当前 Zypper 会话期间暂时启用的,以及要在会话完成后禁用的储存库。
例如,要启用可以提供其他 -debuginfo
或 -debugsource
包的储存库,请使用 --plus-content debug
。可以多次指定此选项。
要暂时启用此类“调试”储存库以安装特定的 -debuginfo
包,请按如下所示使用该选项:
tux >
sudo
zypper --plus-content debug \ install "debuginfo(build-id)=eb844a5c20c70a59fc693cd1061f851fb7d046f4"
对于缺少的 debuginfo 包,gdb
将会报告 build-id
字符串。
6.1.2.7 实用程序 #
要校验所有依赖项是否仍然满足,并修复缺少的依赖项,请使用:
tux >
zypper verify
除了依赖项必须满足外,某些包还“推荐”其他包。只有在实际可用并可安装时才会安装这些推荐包。如果推荐的包在推荐它们的包已安装(通过添加其他包或硬件)之后才可用,请使用以下命令:
tux >
sudo
zypper install-new-recommends
此命令在插入网络摄像头或 Wi-Fi 设备后非常有用。如果可用,它将安装设备驱动程序和相关软件。只有在满足特定硬件依赖项后,才可安装驱动程序和相关软件。
6.1.3 使用 Zypper 更新软件 #
用 Zypper 更新软件有三种方式:安装包、安装包的新版本或更新整个分发包。最后一种方式可通过 zypper dist-upgrade
来实现。中介绍了如何升级 SUSE Linux Enterprise DesktopBook “Upgrade Guide”, Chapter 1 “Upgrade Paths and Methods”。
6.1.3.1 安装全部所需的增补程序 #
要安装所有适用于您系统的正式发布的增补程序,请运行:
tux >
sudo
zypper patch
系统将会检查您计算机上配置的储存库中提供的所有增补程序是否与您的安装相关。如果相关(未分为可选
或功能
类别),则会立即安装这些增补程序。请注意,正式的更新储存库仅在注册 SUSE Linux Enterprise Desktop 安装后才可用。
如果即将安装的增补程序所包含的更改要求重引导系统,您会在重引导前收到警告。
单纯使用 zypper patch
命令不会应用来自第三方储存库的包。要同时更新第三方储存库,请使用 with-update
命令选项,如下所示:
tux >
sudo
zypper patch --with update
要额外安装可选增补程序,请使用:
tux >
sudo
zypper patch --with-optional
要安装与特定 Bugzilla 问题相关的所有增补程序,请使用:
tux >
sudo
zypper patch --bugzilla=NUMBER
要安装与特定 CVE 数据库项相关的所有增补程序,请使用:
tux >
sudo
zypper patch --cve=NUMBER
例如,要安装 CVE 编号为 CVE-2010-2713
的安全增补程序,请执行:
tux >
sudo
zypper patch --cve=CVE-2010-2713
如果只想安装影响 Zypper 和包管理本身的增补程序,请使用:
tux >
sudo
zypper patch --updatestack-only
请记住,如果您使用了 updatestack-only
命令选项,将会丢弃原本还会更新其他储存库的其他命令选项。
6.1.3.2 列出增补程序 #
为了让您确定增补程序是否可用,Zypper 允许您查看以下信息:
- 所需增补程序的数目
要列出所需增补程序(适用于您的系统但尚未安装的增补程序)的数目,请使用
patch-check
:tux >
zypper patch-check Loading repository data... Reading installed packages... 5 patches needed (1 security patch)可以结合
--updatestack-only
选项使用此命令,以便仅列出影响 Zypper 和包管理本身的增补程序。- 所需增补程序的列表
要列出全部所需的增补程序(适用于您的系统但尚未安装的增补程序),请使用
list-patches
:tux >
zypper list-patches Loading repository data... Reading installed packages... Repository | Name | Version | Category | Status | Summary ---------------+-------------+---------+----------+---------+--------- SLES12-Updates | SUSE-2014-8 | 1 | security | needed | openssl: Update for OpenSSL- 所有增补程序的列表
要列出 SUSE Linux Enterprise Desktop 可用的所有增补程序,而不管它们是否已安装或适用于您的安装,请使用
zypper patches
。
还可以列出并安装与特定问题相关的增补程序。要列出特定的增补程序,请使用带以下选项的 zypper list-patches
命令:
- 按 Bugzilla 问题
要列出与 Bugzilla 问题相关的全部所需增补程序,请使用
--bugzilla
选项。要列出针对特定 Bug 的增补程序,您也可以指定 Bug 编号:
--bugzilla=编号
。要搜索与多个 Bugzilla 问题相关的增补程序,请在 bug 编号之间添加逗号,例如:tux >
zypper list-patches --bugzilla=972197,956917- 按 CVE 编号
要列出与 CVE(公共漏洞和披露)数据库中某个项相关的全部所需增补程序,请使用
--cve
选项。要列出针对特定 CVE 数据库项的增补程序,您也可以指定 CVE 编号:
--cve=编号
。要搜索与多个 CVE 数据库项相关的增补程序,请在 CVE 编号之间添加逗号,例如:tux >
zypper list-patches --bugzilla=CVE-2016-2315,CVE-2016-2324
要列出所有增补程序而不管是否需要安装它们,请另外使用 --all
选项。例如,要列出指派有 CVE 编号的所有增补程序,请使用:
tux >
zypper list-patches --all --cve
Issue | No. | Patch | Category | Severity | Status
------+---------------+-------------------+-------------+-----------+----------
cve | CVE-2015-0287 | SUSE-SLE-Module.. | recommended | moderate | needed
cve | CVE-2014-3566 | SUSE-SLE-SERVER.. | recommended | moderate | not needed
[...]
6.1.3.3 安装新的包版本 #
如果某个安装源只包含新包,但未提供增补程序,则 zypper patch
不会产生任何作用。要使用可用的较新版本更新所有已安装的包(同时还要保持系统完整性),请使用︰
tux >
sudo
zypper update
要更新个别包,请用更新或安装命令指定包:
tux >
sudo
zypper update PACKAGE_NAME sudo zypper install PACKAGE_NAME
可使用此命令来获取所有新的可安装包的列表:
tux >
zypper list-updates
请注意,此命令只会列出符合以下准则的包︰
与已安装的包拥有相同的供应商,
由至少与已安装包拥有相同优先级的储存库提供,
可安装(满足所有依赖项)。
所有新的可用包(无论是否可安装)的列表可通过以下方式获取:
tux >
sudo
zypper list-updates --all
要找出新包无法安装的原因,请使用上面所述的 zypper install
或 zypper update
命令。
6.1.3.4 识别孤立的包 #
每当您从 Zypper 中去除某个储存库或者升级系统时,某些包可能会进入“孤立”状态。这些孤立的包不再属于任何活动储存库。以下命令可以列出这些包:
tux >
sudo
zypper packages --orphaned
借助此列表,您可以确定是否仍然需要某个包,或者是否可以安全去除某个包。
6.1.4 识别使用已删除文件的进程和服务 #
在增补、更新或去除包时,系统上可能有一些正在运行的进程会继续使用更新或去除后已被删除的文件。运行 zypper ps
可以列出使用已删除文件的进程。如果此类进程属于某个已知的服务,则会列出服务名称,方便您重启动该服务。默认情况下,zypper ps
会显示一个表:
tux >
zypper ps
PID | PPID | UID | User | Command | Service | Files
------+------+-----+-------+--------------+--------------+-------------------
814 | 1 | 481 | avahi | avahi-daemon | avahi-daemon | /lib64/ld-2.19.s->
| | | | | | /lib64/libdl-2.1->
| | | | | | /lib64/libpthrea->
| | | | | | /lib64/libc-2.19->
[...]
PID:进程的 ID |
PPID:父进程的 ID |
UID:运行进程的用户的 ID |
User:运行进程的用户的登录名 |
Command:用于执行进程的命令 |
Service:服务名称(仅当命令与系统服务关联时才显示) |
Files:已删除文件的列表 |
通过如下方式可控制 zypper ps
的输出格式:
zypper ps
-s
创建一份简短表格,其中不会显示已删除的文件。
tux >
zypper ps -s PID | PPID | UID | User | Command | Service ------+------+------+---------+--------------+-------------- 814 | 1 | 481 | avahi | avahi-daemon | avahi-daemon 817 | 1 | 0 | root | irqbalance | irqbalance 1567 | 1 | 0 | root | sshd | sshd 1761 | 1 | 0 | root | master | postfix 1764 | 1761 | 51 | postfix | pickup | postfix 1765 | 1761 | 51 | postfix | qmgr | postfix 2031 | 2027 | 1000 | tux | bash |zypper ps
-ss
仅显示与系统服务关联的进程。
PID | PPID | UID | User | Command | Service ------+------+------+---------+--------------+-------------- 814 | 1 | 481 | avahi | avahi-daemon | avahi-daemon 817 | 1 | 0 | root | irqbalance | irqbalance 1567 | 1 | 0 | root | sshd | sshd 1761 | 1 | 0 | root | master | postfix 1764 | 1761 | 51 | postfix | pickup | postfix 1765 | 1761 | 51 | postfix | qmgr | postfix
zypper ps
-sss
仅显示使用已删除文件的系统服务。
avahi-daemon irqbalance postfix sshd
zypper ps
--print "systemctl status %s"
显示用于检索可能需要重启动的服务状态信息的命令。
systemctl status avahi-daemon systemctl status irqbalance systemctl status postfix systemctl status sshd
有关服务处理的详细信息,请参见第 13 章 “systemd
守护程序”。
6.1.5 用 Zypper 管理安装源 #
Zypper 的所有安装或增补程序命令均基于已知安装源列表。要列出系统已知的所有储存库,请使用命令:
tux >
zypper repos
结果将类似于与以下输出:
tux >
zypper repos
# | Alias | Name | Enabled | Refresh
--+--------------+---------------+---------+--------
1 | SLEHA-12-GEO | SLEHA-12-GEO | Yes | No
2 | SLEHA-12 | SLEHA-12 | Yes | No
3 | SLES12 | SLES12 | Yes | No
当在各个命令中指定储存库时,可以使用别名、URI 或 zypper repos
命令输出中的储存库编号。储存库别名是用于储存库处理命令中的储存库名称的简短版本。请注意,在修改储存库列表后,储存库编号可能会更改。别名本身不会更改。
默认情况下不显示储存库的 URI 或优先级之类的细节。用以下命令可以列出所有细节:
tux >
zypper repos -d
6.1.5.1 添加安装源 #
要添加安装源,请运行
tux >
sudo
zypper addrepo URI ALIAS
URI 可以是因特网储存库、网络资源、目录、CD 或 DVD(有关细节请参见 http://en.opensuse.org/openSUSE:Libzypp_URIs)。ALIAS 是储存库的唯一简写标识符。您可以随意选择别名,前提是它必须唯一。如果指定的别名已在使用,Zypper 将发出警告。
6.1.5.2 刷新储存库 #
zypper
可让您从配置的储存库中提取包的更改。要提取更改,请运行:
tux >
sudo
zypper refresh
zypper
的默认行为
有些命令默认会自动执行 refresh
,因此您不需要明确运行该命令。
使用 refresh
命令时搭配 --plus-content
选项还可查看已禁用储存库中的更改:
tux >
sudo
zypper --plus-content refresh
该选项虽然会提取储存库中的更改,但会使禁用储存库的状态保持不变,即仍为禁用。
6.1.5.3 删除储存库 #
要从列表中去除某个储存库,请将命令 zypper removerepo
与要删除的储存库的别名或编号结合使用。例如,要从例 6.1 “Zypper — 已知储存库的列表”中去除储存库 SLEHA-12-GEO
,请使用下列命令之一:
tux >
sudo
zypper removerepo 1tux >
sudo
zypper removerepo "SLEHA-12-GEO"
6.1.5.4 修改储存库 #
用 zypper modifyrepo
启用或禁用储存库。您还可以用该命令更改储存库的属性(例如刷新行为、名称或优先级)。以下命令将会启用名为 updates
的储存库、打开自动刷新并将其优先级设置为 20:
tux >
sudo
zypper modifyrepo -er -p 20 'updates'
修改储存库并不局限于单个储存库 — 您也可以对组执行该操作︰
-a :所有储存库 |
-l :本地储存库 |
-t :远程储存库 |
-m 类型 :特定类型的储存库(其中类型可以是以下之一:http 、https 、ftp 、cd 、dvd 、dir 、file 、cifs 、smb 、nfs 、hd 和 iso ) |
要重命名安装源别名,请使用 renamerepo
命令。以下示例将别名从 Mozilla Firefox
更改为 firefox
:
tux >
sudo
zypper renamerepo 'Mozilla Firefox' firefox
6.1.6 用 Zypper 查询储存库和包 #
Zypper 提供各种查询储存库或包的方式。要获取所有可用的产品、模式、包或增补程序的列表,请使用以下命令:
tux >
zypper productstux >
zypper patternstux >
zypper packagestux >
zypper patches
要查询特定包的所有储存库,请使用 search
。要获得有关特定包的信息,请使用 info
命令。
6.1.6.1 搜索软件 #
zypper search
命令可对包名或(视情况)对包摘要和说明执行搜索。括在 /
中的字符串会解译为正则表达式。默认情况下搜索不区分大小写。
- 执行简单搜索来查找包含
fire
的包名称 tux >
zypper search "fire"- 执行简单搜索来查找确切的包
MozillaFirefox
tux >
zypper search --match-exact "MozillaFirefox"- 同时在包描述和摘要中搜索
tux >
zypper search -d fire- 仅显示尚未安装的包
tux >
zypper search -u fire- 显示包含字符串
fir
且该字符串后面不是e
的包 tux >
zypper se "/fir[^e]/"
6.1.6.2 在所有 SLE 模块中搜索包 #
要搜索当前已启用的 SLE 模块内部和外部的包,请使用命令 zypper search-packages
。此命令会联系 SUSE Customer Center,并在所有模块中搜索匹配的包。
6.1.6.3 搜索特定功能 #
要搜索提供特殊功能的包,请使用命令 what-provides
。例如,如果您想知道哪个包提供 Perl 模块 SVN::Core
,请使用以下命令:
tux >
zypper what-provides 'perl(SVN::Core)'
what-provides 包名
与 rpm -q --whatprovides
包名类似,不过 RPM 只能查询 RPM 数据库(即所有已安装的包的数据库)。另一方面,Zypper 将告诉您任意储存库的功能的提供商,而非仅已安装的储存库功能的提供商。
6.1.6.4 显示包信息 #
要查询个别包,请使用 info
命令,并用完整包名称作为自变量。这会显示有关某个包的详细信息。如果包名与储存库中的所有包名都不匹配,该命令会输出非包匹配项的详细信息。如果您请求特定类型(通过使用 -t
选项),但该类型不存在,该命令会输出其他可用的匹配项,但不提供详细信息。
如果您指定源包,该命令会显示基于该源包构建的二进制包。如果您指定二进制包,该命令会输出用来构建该二进制包的源包。
如果还要显示该包必需/推荐的包,则使用选项 --requires
和 --recommends
:
tux >
zypper info --requires MozillaFirefox
6.1.7 显示生命周期信息 #
SUSE 产品的支持周期一般为 10 年。通常,您可以使用 SUSE 的延长支持产品将标准生命周期延长三年。根据您的产品,在 https://www.suse.com/lifecycle 中找到具体的支持生命周期。
要检查您的产品和所支持包的生命周期,请如下所示使用 zypper lifecycle
命令:
root #
zypper lifecycle
Product end of support Codestream: SUSE Linux Enterprise Server 15 2028-07-31 SUSE Linux Enterprise Server 15 n/a* Module end of support Basesystem Module n/a* Server Applications Module n/a* Package end of support if different from product: SUSEConnect Now, installed 0.3.11-1.4, update available 0.3.11-3.3.1 ca-certificates-mozilla Now, installed 2.22-2.12, update available 2.24-4.3.1 curl Now, installed 7.60.0-1.1, update available 7.60.0-3.3.1 e2fsprogs Now, installed 1.43.8-2.44, update available 1.43.8-4.3.1 glibc Now, installed 2.26-11.8, update available 2.26-13.3.1
6.1.8 配置 Zypper #
Zypper 现在随附配置文件,允许您永久更改 Zypper 的行为(系统范围或用户特定)。要进行系统范围更改,请编辑 /etc/zypp/zypper.conf
。要进行用户特定的更改,请编辑 ~/.zypper.conf
。如果 ~/.zypper.conf
尚不存在,您可以使用 /etc/zypp/zypper.conf
作为模板:将其复制到 ~/.zypper.conf
并根据您的喜好进行调整。请参见文件中的注释,获取有关可用选项的帮助。
6.1.9 查错 #
如果您在访问配置的储存库中的包时遇到问题(例如,尽管您知道某个包在某个储存库中,但 Zypper 找不到该包),刷新储存库或许可以解决问题:
tux >
sudo
zypper refresh
如果不起作用,则尝试
tux >
sudo
zypper refresh -fdb
这会强制完全刷新和重构建数据库,包括强制下载原始元数据。
6.1.10 Btrfs 文件系统上的 Zypper 回滚功能 #
如果根分区上使用的是 Btrfs 文件系统,且系统中安装了 snapper
,当 Zypper 提交对文件系统所做的更改以创建相应的文件系统快照时,会自动调用 snapper
。这些快照可用于还原 Zypper 进行的任何更改。有关详细信息,请参见第 7 章 “通过 Snapper 进行系统恢复和快照管理”。
6.1.11 更多信息 #
有关从命令行管理软件的详细信息,请输入 zypper help
、zypper help
命令,或参见 zypper(8)
手册页。有关详尽的命令参考、最重要的命令的速查表
,以及如何在脚本和应用程序中使用 Zypper 的信息,请参见 http://en.opensuse.org/SDB:Zypper_usage。SUSE Linux Enterprise Desktop 最新版本的软件更改列表可在 http://en.opensuse.org/openSUSE:Zypper versions 中找到。
6.2 RPM — 包管理器 #
RPM(RPM 程序包管理器)用于管理软件包。其主要程命令为 rpm
和 rpmbuild
。用户、系统管理员和包构建人员可以查询强大的 RPM 数据库以获得有关已安装软件的详细信息。
rpm
有五种模式:安装、卸装(或更新)软件包、重构建 RPM 数据库、查询 RPM 库或独立 RPM 存档、对包执行完整性检查以及对包签名。rpmbuild
可用于从原始源构建可安装的包。
用特殊的二进制格式对可安装 RPM 存档进行打包。这些存档由要安装的程序文件和某些元信息组成,这些元信息供 rpm
在安装过程中配置软件包使用或者储存在 RPM 数据库中进行存档。RPM 存档通常具有扩展名 .rpm
。
对于一些包,软件开发所需的组件(库、报头、包含文件等)已纳入独立的包中。只有当您要自己编译软件时才需要这些开发包(例如最新的 GNOME 包)。可以通过扩展名 -devel
确定这些开发包,例如包 alsa-devel
和 gimp-devel
。
6.2.1 校验包真实性 #
RPM 包具有 GPG 签名。要校验 RPM 包的签名,请使用 rpm --checksig
PACKAGE-1.2.3.rpm 命令确定该包是来自 SUSE 还是另一个可信机构。特别建议对来自因特网的更新包使用此命令。
修复操作系统中的问题时,您可能需要将问题临时修复 (PTF) 安装到生产系统中。SUSE 提供的包已使用特殊的 PTF 密钥签名。但是,与 SUSE Linux Enterprise 11 不同,SUSE Linux Enterprise 12 系统上默认不会导入此密钥。要手动导入该密钥,请使用以下命令:
tux >
sudo
rpm --import \ /usr/share/doc/packages/suse-build-key/suse_ptf_key.asc
导入该密钥后,您可以在系统上安装 PTF 包。
6.2.2 管理包:安装、更新和卸装 #
安装 RPM 存档的步骤通常十分简单,执行运行:rpm -i
包.rpm。使用此命令可以安装包,但前提是满足其依赖项并且不与其他包冲突。如果出现错误消息,rpm
将请求那些需要安装的包以满足依赖项要求。在后台,RPM 数据库确保不出现冲突 - 一个特定文件只能属于一个包。通过选择不同的选项,您可以强制 rpm
忽略这些默认设置,但这只供专家用户使用。否则,将影响系统的完整性并可能使系统无法更新。
选项 -U
或 --upgrade
以及 -F
或 --freshen
可用于更新包(例如,rpm -F
PACKAGE.rpm)。此命令将删除旧版本的文件并立即安装新文件。两个版本之间的差别是:-U
安装系统中以前不存在的包,而 -F
只更新以前安装的包。更新时,rpm
使用以下策略小心更新配置文件:
如果配置文件未被系统管理员更改,则
rpm
将安装适当文件的新版本。系统管理员无需执行任何操作。如果配置文件在更新前曾被系统管理员更改,则
rpm
会以扩展名.rpmorig
或.rpmsave
(备份文件)保存更改的文件,并安装新包中的版本。仅当原先安装的文件和较新的版本不同时,才执行此操作。如果是这种情况,则将备份文件(.rpmorig
或.rpmsave
)与新安装的文件进行比较,并在新文件中再次进行更改。之后,请删除所有.rpmorig
和.rpmsave
文件,以免以后的更新出现问题。如果配置文件已存在并且
.spec
文件中指定了noreplace
标签,则出现.rpmnew
文件。
更新后,在使用 .rpmsave
和 .rpmnew
文件进行比较后应将它们删除,从而防止它们阻碍以后的更新。如果 RPM 数据库以前未能识别文件,则将为其指派扩展名 .rpmorig
。
否则,将使用 .rpmsave
。换句话说,.rpmorig
是从异系统格式更新为 RPM 的结果。而
.rpmsave 是从较早的 RPM 更新为较新的 RPM 的结果。.rpmnew
不提供任何有关系统管理员是否对配置文件进行过任何更改的信息。/var/adm/rpmconfigcheck
中提供这些文件的列表。不覆盖某些配置文件(如 /etc/httpd/httpd.conf
)以允许继续进行操作。
-U
开关的作用并不完全等同于使用 -e
选项进行卸载以及使用 -i
选项进行安装,它还有其他作用。只要可能,就可以使用 -U
。
要去除包,请输入 rpm -e
PACKAGE。仅当不存在未解决的依赖项问题时,此命令才会删除包。例如,只要有其他程序需要 Tcl/Tk,理论上就不能删除它。即使是在这种情况下,RPM 也会向数据库寻求帮助。如果出于任何原因无法进行此删除操作(即使不存在其他依赖项),则最好使用选项 --rebuilddb
重构建 RPM 数据库。
6.2.3 增量 RPM 包 #
增量 RPM 包包含旧版本和新版本的 RPM 包之间的差别。在旧 RPM 上应用增量 RPM 将得到全新的 RPM。不需要旧 RPM 的副本,因为增量 RPM 也可以与已安装的 RPM 一起工作。增量 RPM 包的大小甚至比增补程序 RPM 小,这有利于通过因特网传送更新包。缺点是,涉及增量 RPM 的更新操作与使用纯粹 RPM 或增补程序 RPM 进行更新的情况相比,占用的 CPU 周期要长得多。
makedeltarpm
和 applydelta
二进制文件是增量 RPM 套件(包 deltarpm
)的一部分,可帮助您创建和应用增量 RPM 包。使用以下命令可以创建名为 new.delta.rpm
的增量 RPM。以下命令假设 old.rpm
和 new.rpm
是存在的:
tux >
sudo
makedeltarpm old.rpm new.rpm new.delta.rpm
如果旧包已经安装,则使用 applydeltarpm
可以从文件系统重新构建新的 RPM:
tux >
sudo
applydeltarpm new.delta.rpm new.rpm
如果不访问文件系统而从旧 RPM 得到它,请使用 -r
选项:
tux >
sudo
applydeltarpm -r old.rpm new.delta.rpm new.rpm
关于技术详细信息,请参见 /usr/share/doc/packages/deltarpm/README
。
6.2.4 RPM 查询 #
带 -q
选项的 rpm
将启动查询,如此用户便可查看 RPM 存档(通过添加选项 -p
)并查询已安装包的 RPM 数据库。可以使用多个开关指定所需信息的类型。请参见表 6.1 “最重要的 RPM 查询选项”。
|
包信息 |
|
文件列表 |
|
查询包含文件 FILE 的包(必须使用 FILE 指定完整路径) |
|
带有状态信息的文件列表(间接指定 |
|
仅列出文档文件(间接指定 |
|
仅列出配置文件(间接指定 |
|
带有完整详细信息的文件列表(将用于 |
|
列出包中可被另一个包通过 |
|
包需要的功能 |
|
安装脚本(预安装、后安装、卸载) |
例如,命令 rpm -q -i wget
显示例 6.2 “rpm -q -i wget
” 中所示的信息。
rpm -q -i wget
#Name : wget Version : 1.14 Release : 17.1 Architecture: x86_64 Install Date: Mon 30 Jan 2017 14:01:29 CET Group : Productivity/Networking/Web/Utilities Size : 2046483 License : GPL-3.0+ Signature : RSA/SHA256, Thu 08 Dec 2016 07:48:44 CET, Key ID 70af9e8139db7c82 Source RPM : wget-1.14-17.1.src.rpm Build Date : Thu 08 Dec 2016 07:48:34 CET Build Host : sheep09 Relocations : (not relocatable) Packager : https://www.suse.com/ Vendor : SUSE LLC <https://www.suse.com/> URL : http://www.gnu.org/software/wget/ Summary : A Tool for Mirroring FTP and HTTP Servers Description : Wget enables you to retrieve WWW documents or FTP files from a server. This can be done in script files or via the command line. Distribution: SUSE Linux Enterprise 12
只有当您指定带有完整路径的完整文件名时,选项 -f
才起作用。根据需要提供任意多个文件名。例如:
tux >
rpm -q -f /bin/rpm /usr/bin/wget
rpm-4.11.2-15.1.x86_64
wget-1.14-17.1.x86_64
如果只知道部分文件名,则可以使用外壳脚本,如例 6.3 “搜索包的脚本”所示。当运行所显示的脚本时,将部分文件名以参数的形式传递给脚本。
#! /bin/sh for i in $(rpm -q -a -l | grep $1); do echo "\"$i\" is in package:" rpm -q -f $i echo "" done
rpm -q --changelog
PACKAGE 命令会按日期排序显示有关特定包的详细更改信息列表。
借助已安装的 RPM 数据库,可以进行校验检查。使用 -V
或 --verify
启动这些检查。使用此选项,rpm
显示安装后已被更改的包中的所有文件。rpm
使用 8 个字符符号给出有关以下更改的一些提示:
|
MD5 校验和 |
|
文件大小 |
|
符号链接 |
|
修改时间 |
|
主要和次要设备编号 |
|
拥有者 |
|
组 |
|
方式(权限和文件类型) |
对于配置文件,将输出字母 c
。例如,对于 /etc/wgetrc
(wget
包)的更改:
tux >
rpm -V wget
S.5....T c /etc/wgetrc
RPM 数据库的文件被放置在 /var/lib/rpm
中。如果分区 /usr
的大小为 1 GB,则此数据库可能会占用将近 30 MB,特别是在完全更新之后。如果数据库比预期大得多,则最好使用选项 --rebuilddb
重构建数据库。在执行此操作之前,制作旧数据库的备份。cron
脚本 cron.daily
每天制作数据库的副本(用 gzip 打包)并将这些副本储存在 /var/adm/backup/rpmdb
中。副本的数目是由 /etc/sysconfig/backup
中的变量 MAX_RPMDB_BACKUPS
(默认值为 5
)控制的。对于 1 GB 的 /usr
,单个备份的大小大约为 1 MB。
6.2.5 安装和编译源包 #
所有源包都带有 .src.rpm
扩展名(源 RPM)。
源包可以从安装媒体复制到硬盘并使用 YaST 解压缩。但是,在包管理器中它们不会被标记为已安装 ([i]
)。这是因为源包不是在 RPM 数据库中输入的。只有已安装的操作系统软件列在 RPM 数据库中。安装源包时,只将源代码添加到系统中。
以下目录必须可用于 /usr/src/packages
中的 rpm
和 rpmbuild
(除非在诸如 /etc/rpmrc
这样的文件中指定自定义设置):
SOURCES
代表原始源(
.tar.bz2
或.tar.gz
文件等)和特定于发布版本的调整(多为.diff
或.patch
文件)SPECS
代表
.spec
文件,类似于元 Makefile,该文件控制构建进程BUILD
在此目录中解压缩、增补和编译所有源
RPMS
储存完整的二进制包的位置
SRPMS
这里是源 RPM
使用 YaST 安装源包时,将在 /usr/src/packages
中安装所有需要的组件:源和调整在 SOURCES
中,相关的 .spec
文件在 SPECS
中。
不要对系统组件(glibc
、rpm
等)进行试验,因为这样做会影响系统的稳定性。
下面的示例使用 wget.src.rpm
包。安装源包后,应具有类似以下列表中的文件:
/usr/src/packages/SOURCES/wget-1.11.4.tar.bz2 /usr/src/packages/SOURCES/wgetrc.patch /usr/src/packages/SPECS/wget.spec
rpmbuild
-bX
/usr/src/packages/SPECS/wget.spec
会启动编译。X 是通配符,代表构建进程的不同阶段(有关详细信息,请参见 --help
的输出或 RPM 文档)。以下内容只是简要描述:
-bp
在
/usr/src/packages/BUILD
中准备源:解压和打增补程序。-bc
执行与
-bp
相同的操作,但还进行编译。-bi
执行与
-bp
相同的操作,但还安装生成的软件。注意:如果包不支持 BuildRoot 功能,则可能会重写配置文件。-bb
执行与
-bi
相同的操作,但还创建二进制包。如果编译成功,二进制包应该在/usr/src/packages/RPMS
中。-ba
执行与
-bb
相同的操作,但还创建源 RPM。如果编译成功,二进制包应该在/usr/src/packages/SRPMS
中。--short-circuit
跳过某些步骤。
现在可以使用 rpm
-i
或最好使用 rpm
-U
来安装创建的二进制 RPM。使用 rpm
进行安装使它显示在 RPM 数据库中。
请记住,从 SUSE Linux Enterprise Desktop 12 开始,就已弃用规范文件中的 BuildRoot
指令。如果您仍然需要此功能,请使用 --buildroot
选项作为替代方法。有关更详细的背景信息,请参见 https://www.suse.com/support/kb/doc?id=7017104 上的支持数据库。
6.2.6 使用 build 编译 RPM 包 #
许多包存在的风险是构建进程中会将许多不需要的文件添加到正在运行的系统中。为防止发生这种情况,请使用 build
,它将创建构建包的已定义环境。要建立这一 chroot 环境,build
脚本必须和完整的包树结构一起提供。可以通过 NFS 或从 DVD 使用硬盘上的此树。使用 build --rpms
DIRECTORY 设置位置。与 rpm
不同,build
命令在源目录中查找 .spec
文件。要用系统中 /media/dvd
下装入的 DVD 构建 wget
(如上例所示),请以 root
用户身份使用以下命令:
root #
cd /usr/src/packages/SOURCES/root #
mv ../SPECS/wget.spec .root #
build --rpms /media/dvd/suse/ wget.spec
随后,将在 /var/tmp/build-root
建立一个最小的环境。在此环境中构建包。完成后,生成的包位于 /var/tmp/build-root/usr/src/packages/RPMS
中。
build
脚本提供多个其他选项。例如,使脚本优先选择您自己的 RPM、忽略构建环境的初始化或者将 rpm
命令限制在上述阶段之一。使用 build
--help
并通过阅读 build
手册页来访问更多信息。
6.2.7 用于 RPM 存档和 RPM 数据库的工具 #
Midnight Commander (mc
) 可以显示 RPM 存档的内容并复制部分内容。它将存档表示为虚拟文件系统,提供 Midnight Commander 所有常用的菜单选项。使用 F3 键显示 HEADER
。使用光标键和 Enter 键查看存档结构。使用 F5 键复制部分存档。
拥有全部功能的包管理器将作为 YaST 模块提供。有关细节,请参见Book “Deployment Guide”, Chapter 16 “Installing or Removing Software”。
7 通过 Snapper 进行系统恢复和快照管理 #
能够生成文件系统快照以便在 Linux 上实现回滚,这是过去常常要求提供的功能。如今,Snapper 与 Btrfs
文件系统或瘦配置的 LVM 卷相结合,填补了这一空白。
Btrfs
是全新的 Linux 写入时复制文件系统。它支持为子卷(每个物理分区中的一或多个单独的可装入文件系统)生成文件系统快照(复制子卷在某个时间点的状态)。XFS、Ext4 或 Ext3 格式的精简 LVM 卷上也支持快照。您可以使用 Snapper 创建并管理这些快照。Snapper 有一个命令行和一个 YaST 界面。从 SUSE Linux Enterprise Server 12 开始,还可以从 Btrfs
快照引导。有关详细信息,请参见第 7.3 节 “通过从快照引导来执行系统回滚”。
您可以使用 Snapper 执行以下任务:
撤销
zypper
和 YaST 所做的系统更改。有关详细信息,请参见第 7.2 节 “使用 Snapper 撤销更改”。通过先前的快照恢复文件。有关详细信息,请参见第 7.2.2 节 “使用 Snapper 恢复文件”。
从快照引导以执行系统回滚。有关详细信息,请参见第 7.3 节 “通过从快照引导来执行系统回滚”。
以手动方式即时创建快照并管理现有快照。有关详细信息,请参见第 7.5 节 “手动创建和管理快照”。
7.1 默认设置 #
SUSE Linux Enterprise Desktop 中设置 Snapper 的目的是提供系统更改的“撤消和恢复工具”。默认情况下,SUSE Linux Enterprise Desktop
的根分区 (/) 使用 Btrfs
格式。如果根分区 (/
) 足够大(约为 16GB 以上),则创建快照功能会自动启用。默认不允许创建除 /
以外的分区的快照。
如果您在安装期间禁用了 Snapper,以后随时都可启用它。要执行此操作,请运行以下命令创建根文件系统的默认 Snapper 配置:
tux >
sudo
snapper -c root create-config /
之后,按第 7.1.3.1 节 “禁用/启用快照”中所述启用不同的快照类型。
请记住,要使用快照,需按照安装程序的建议设置一个包含子卷的 Btrfs 根文件系统,并且需有一个大小至少为 16 GB 的分区。
创建快照时,快照与原始点都会指向文件系统中的同一个块。因此一开始时快照并不占用额外的磁盘空间。但如果修改了原始文件系统中的数据,则会复制已更改的数据块,同时将旧的数据块作为快照保留。因此,快照就将占用与已修改数据相同的空间。所以久而久之,分配给快照的空间便会不断增长。其结果是,即便从包含快照的 Btrfs
文件系统删除文件可能也不会释放磁盘空间!
快照始终存放在创建快照的那个分区或子卷中,而无法将快照存储到其他分区或子卷。
因此,包含快照的分区需要比“常规”分区大才行。确切的空间大小主要取决于要保留的快照数量以及数据更改量。一般来说,您应考虑使用两倍于常规使用磁盘空间的空间大小。为了防止磁盘上的空间耗尽,系统会自动清理旧快照。有关详细信息,请参见第 7.1.3.4 节 “控制快照存档”。
7.1.1 快照类型 #
尽管快照本身在技术方面并无区别,但我们根据触发它们的事件将其分成三类:
- 时间线快照
每小时创建一个快照,且旧的快照会自动删除。默认情况下,会保留最近十天、最近十个月以及最近十年的首张快照。时间线快照默认为禁用状态。
- 安装快照
每次使用 YaST 或 Zypper 安装一个或多个包时,会创建一对快照:一个是在安装开始前(“前”),另一个是在安装完成后(“后”)。如果安装了内核等重要的系统组件,快照对会标记为重要 (
important=yes
)。旧的快照会自动删除。默认情况下,会保留最近十个重要快照和最近十个“普通”快照(包括管理快照)。安装快照默认为启用状态。- 管理快照
每次使用 YaST 管理系统时都会创建一对快照:一个是在 YaST 模块启动之前(“前”),另一个是在该模块关闭之后(“后”)。旧的快照会自动删除。默认情况下,会保留最近十个重要快照和最近十个“普通”快照(包括安装快照)。管理快照默认为启用状态。
7.1.2 快照中排除的目录 #
出于多种不同的理由,有些目录需要排除在快照之外。以下列表显示了排除的所有目录:
/boot/grub2/i386-pc
、/boot/grub2/x86_64-efi
、/boot/grub2/powerpc-ieee1275
、/boot/grub2/s390x-emu
不能回滚引导加载程序配置。上面列出的目录是架构专属目录。前两个目录位于 AMD64/Intel 64 计算机上,后两个目录分别位于 IBM POWER 和 IBM Z 上。
/home
如果独立的分区中没有
/home
,便会将该目录排除以免在回滚时发生数据丢失。/opt
、/var/opt
第三方产品通常安装到
/opt
下。排除此目录是为了防止在回滚时卸装这些应用程序。/srv
包含 Web 和 FTP 服务器的数据。排除此目录是为了防止在回滚时发生数据丢失。
/tmp
、/var/tmp
、/var/cache
、/var/crash
包含临时文件和超速缓存的所有目录都会排除在快照范围之外。
/usr/local
在手动安装软件时会用到此目录。系统会将该目录排除以免在回滚时卸载这些安装的软件。
/var/lib/libvirt/images
使用 libvirt 管理的虚拟机映像的默认位置。为确保回滚期间虚拟机映像不会替换为旧版本而被排除。默认情况下,此子卷是使用
写入时不复制
选项创建的。/var/lib/mailman
、/var/spool
包含邮件或邮件队列的目录会排除,以免在回滚后造成邮件丢失。
/var/lib/bind
包含 DNS 服务器的区域数据。排除该目录是为了确保回滚后名称服务器仍能运作。
/var/lib/mariadb
、/var/lib/mysql
、/var/lib/pgqsl
这些目录包含数据库数据。默认情况下,这些子卷是使用
写入时不复制
选项创建的。/var/log
日志文件所在的位置。排除该目录是为了在对受损的系统进行回滚后能够对日志文件进行分析。
7.1.3 自定义设置 #
SUSE Linux Enterprise Desktop 自带的默认设置设计合理,适合大多数使用情况。不过,您可以根据自己的需要对创建自动快照以及保留快照的各个方面进行配置。
7.1.3.1 禁用/启用快照 #
这三种快照类型(时间线、安装、管理)都可以单独启用或禁用。
- 禁用/启用时间线快照
启用:
snapper -c root set-config "TIMELINE_CREATE=yes"
禁用:
snapper -c root set-config "TIMELINE_CREATE=no"
时间线快照默认会启用,但根分区除外。
- 禁用/启用安装快照
启用:: 安装
snapper-zypp-plugin
包禁用:: 卸装
snapper-zypp-plugin
包安装快照默认为启用状态。
- 禁用/启用管理快照
启用:: 在
/etc/sysconfig/yast2
中将USE_SNAPPER
设置为yes
。禁用:: 在
/etc/sysconfig/yast2
中将USE_SNAPPER
设置为no
。管理快照默认为启用状态。
7.1.3.2 控制安装快照 #
使用 YaST 或 Zypper 安装包时所创建的快照会由 snapper-zypp-plugin
进行处理。何时创建快照由 XML 配置文件 /etc/snapper/zypp-plugin.conf
定义。默认情况下,该文件如下所示:
1 <?xml version="1.0" encoding="utf-8"?> 2 <snapper-zypp-plugin-conf> 3 <solvables> 4 <solvable match="w"1 important="true"2>kernel-*3</solvable> 5 <solvable match="w" important="true">dracut</solvable> 6 <solvable match="w" important="true">glibc</solvable> 7 <solvable match="w" important="true">systemd*</solvable> 8 <solvable match="w" important="true">udev</solvable> 9 <solvable match="w">*</solvable>4 10 </solvables> 11 </snapper-zypp-plugin-conf>
match 属性定义模式是 Unix 外壳风格的通配符 ( | |
如果匹配指定模式而且对应的包标记为 important(例如内核包),则快照也会标记为 important。 | |
用于匹配包名称的模式。根据 | |
此行无条件匹配所有包。 |
在这样的快照配置下,只要安装了包,就会创建快照对(第 9 行)。如果标记为 important 的内核、dracut、glibc、systemd 或 udev 包已安装,快照对也会标记为 important(第 4 行到第 8 行)。所有规则都会进行评估。
要禁用某规则,可以删除该规则或通过 XML 注释的方式将其停用。举例来说,如果不希望系统在每次安装包时创建快照对,可以将第 9 行注释掉:
1 <?xml version="1.0" encoding="utf-8"?> 2 <snapper-zypp-plugin-conf> 3 <solvables> 4 <solvable match="w" important="true">kernel-*</solvable> 5 <solvable match="w" important="true">dracut</solvable> 6 <solvable match="w" important="true">glibc</solvable> 7 <solvable match="w" important="true">systemd*</solvable> 8 <solvable match="w" important="true">udev</solvable> 9 <!-- <solvable match="w">*</solvable> --> 10 </solvables> 11 </snapper-zypp-plugin-conf>
7.1.3.3 创建和装入新子卷 #
系统支持在 /
层次下创建新的子卷,并永久性装入该卷。此类子卷将从快照中排除。切勿在现有快照中创建此类子卷,因为在回滚之后,您将无法再删除快照。
SUSE Linux Enterprise Desktop 上配置了 /@/
子卷,该子卷充当永久性子卷(例如 /opt
、/srv
、/home
等)的独立根目录。您创建和永久装入的任何新子卷都需要在这个初始根文件系统中创建。
为此,请运行以下命令。在此示例中,从 /dev/sda2
创建了一个新子卷 /usr/important
。
tux >
sudo
mount /dev/sda2 -o subvol=@ /mnttux >
sudo
btrfs subvolume create /mnt/usr/importanttux >
sudo
umount /mnt
/etc/fstab
中的相应项需类似于:
/dev/sda2 /usr/important btrfs subvol=@/usr/important 0 0
子卷可能包含经常更改的文件,例如虚拟化的磁盘映像、数据库文件或日志文件。如果是这样,可考虑对此卷禁用写入时复制功能,以免复制磁盘块。可在 /etc/fstab
中使用 nodatacow
装入选项来实现此目的:
/dev/sda2 /usr/important btrfs nodatacow,subvol=@/usr/important 0 0
或者,要为单个文件或目录禁用写入时复制功能,请使用命令 chattr +C 路径
。
7.1.3.4 控制快照存档 #
快照会占用磁盘空间。为了防止磁盘空间耗尽而导致系统中断,旧的快照会自动删除。默认情况下,将保留最多 10 个重要的安装快照与管理快照,以及最多 10 个普通的安装快照与管理快照。如果这些快照占用的空间超过根文件系统大小的 50%,将会删除其他快照。系统始终会至少保留 4 个重要快照和 2 个普通快照。
有关如何更改这些值的指导,请参考第 7.4.1 节 “管理现有配置”。
7.1.3.5 在精简的 LVM 卷上使用 Snapper #
除了在 Btrfs
文件系统上生成快照之外,Snapper 还支持在 XFS、Ext4 或 Ext3 格式的精简 LVM 卷(不支持在常规 LVM 卷上生成快照)上生成快照。有关 LVM 卷的详细信息和设置指导,请参考Book “Deployment Guide”, Chapter 6 “Expert Partitioner”, Section 6.2 “LVM Configuration”。
若要在瘦配置的 LVM 卷上使用 Snapper,您需要为其创建 Snapper 配置。在 LVM 上要使用 --fstype=lvm(文件系统)
指定文件系统。文件系统的有效值为 ext3
、etx4
或 xfs
。示例:
tux >
sudo
snapper -c lvm create-config --fstype="lvm(xfs)" /thin_lvm
您可以按照第 7.4.1 节 “管理现有配置”中的说明根据需要调整此配置。
7.2 使用 Snapper 撤销更改 #
SUSE Linux Enterprise Desktop 上的 Snapper 经过预配置,可以用来撤消 zypper
和 YaST 所做的更改。要实现此功能,请对 Snapper 进行配置,让其在每次运行 zypper
和 YaST 前后创建一个快照对。您也可以使用 Snapper 来恢复被意外删除或修改的系统文件。要实现此目的,需要对根分区启用时间线快照 — 有关细节,请参见第 7.1.3.1 节 “禁用/启用快照”。
默认情况下,上述的自动快照针对根分区及其子卷所配置。若希望针对 /home
等其他分区生成快照,您可以创建自定义配置。
通过快照来恢复数据时,必须知道,Snapper 可以处理两种完全不同的情形:
- 撤销更改
在如下文中所述撤销更改时,系统会对两个快照进行比较,并撤销两个快照之间的更改。借助这种方式可以明确地选择要恢复的文件。
- 回滚
在如第 7.3 节 “通过从快照引导来执行系统回滚”中所述进行回滚时,系统会重设置为创建快照时的状态。
撤销更改时,可以将快照与现有系统进行比较。如果比较后恢复所有发生变化的文件,那么结果会和回滚完全相同。但是,还是建议使用第 7.3 节 “通过从快照引导来执行系统回滚”中介绍的方法进行回滚,因为回滚操作的速度更快,而且您可以在进行回滚前查看系统。
在创建快照时并没有能确保数据一致性的机制。如果在创建快照的同时写入某个文件(例如数据库),将导致文件损坏或写入不完整。恢复此类文件会产生问题。而且,有些系统文件(例如 /etc/mtab
)甚至永远都无法恢复。因此强烈建议您要始终仔细查看已更改文件及其差异的列表。只恢复您要还原的操作真正包含的文件。
7.2.1 撤销 YaST 和 Zypper 更改 #
如果在安装时使用 Btrfs
设置根分区,则将自动安装 Snapper(经过预配置,可以回滚 YaST 或 Zypper 所做的更改)。每次启动 YaST 模块或 Zypper 事务时,会创建两个快照:即截获模块启动之前文件系统状态的“前快照”以及截获模块完成之后状态的“后快照”。
您可以使用 YaST Snapper 模块或 snapper
命令行工具,通过从“前快照”恢复文件来撤销 YaST 或 Zypper 所做的更改。您也可以使用该工具比较这两张快照,以查看更改了哪些文件。您还可以显示文件的两个版本之间的差异 (diff)。
从 YaST 中的
部分或通过输入 来启动Snapper
模块。务必将
设置为 。除非手动添加自己的 Snapper 配置,否则请始终做此设置。从列表中选择前后快照对。YaST 和 Zypper 快照对都属于
类型。在 中,YaST 快照以zypp(y2base)
标记;Zypper 快照以zypp(zypper)
标记。单击
,会打开一个文件列表显示两张快照之间的差异。查看文件列表。要显示文件的前后版本之间的“差异”,请从列表中选中该文件。
要恢复一个或多个文件,请通过勾选相应的复选框选择相关的文件或目录。单击
,然后单击 以确认该操作。要恢复单一文件,请单击其名称以激活该文件的差异视图。单击
,然后单击 予以确认。
snapper
命令撤销更改 #运行
snapper list -t pre-post
以获取 YaST 与 Zypper 快照的列表。在 列中,YaST 快照标为yast MODULE_NAME
;Zypper 快照标为zypp(zypper)
。tux >
sudo
snapper list -t pre-post Pre # | Post # | Pre Date | Post Date | Description ------+--------+-------------------------------+-------------------------------+-------------- 311 | 312 | Tue 06 May 2018 14:05:46 CEST | Tue 06 May 2018 14:05:52 CEST | zypp(y2base) 340 | 341 | Wed 07 May 2018 16:15:10 CEST | Wed 07 May 2018 16:15:16 CEST | zypp(zypper) 342 | 343 | Wed 07 May 2018 16:20:38 CEST | Wed 07 May 2018 16:20:42 CEST | zypp(y2base) 344 | 345 | Wed 07 May 2018 16:21:23 CEST | Wed 07 May 2018 16:21:24 CEST | zypp(zypper) 346 | 347 | Wed 07 May 2018 16:41:06 CEST | Wed 07 May 2018 16:41:10 CEST | zypp(y2base) 348 | 349 | Wed 07 May 2018 16:44:50 CEST | Wed 07 May 2018 16:44:53 CEST | zypp(y2base) 350 | 351 | Wed 07 May 2018 16:46:27 CEST | Wed 07 May 2018 16:46:38 CEST | zypp(y2base)使用
snapper status
PRE..POST 命令以获取快照对的已更改文件列表。文件内容发生了更改会以 标记、添加了文件会以 标记、删除了文件会以 标记。tux >
sudo
snapper status 350..351 +..... /usr/share/doc/packages/mikachan-fonts +..... /usr/share/doc/packages/mikachan-fonts/COPYING +..... /usr/share/doc/packages/mikachan-fonts/dl.html c..... /usr/share/fonts/truetype/fonts.dir c..... /usr/share/fonts/truetype/fonts.scale +..... /usr/share/fonts/truetype/みかちゃん-p.ttf +..... /usr/share/fonts/truetype/みかちゃん-pb.ttf +..... /usr/share/fonts/truetype/みかちゃん-ps.ttf +..... /usr/share/fonts/truetype/みかちゃん.ttf c..... /var/cache/fontconfig/7ef2298fde41cc6eeb7af42e48b7d293-x86_64.cache-4 c..... /var/lib/rpm/Basenames c..... /var/lib/rpm/Dirnames c..... /var/lib/rpm/Group c..... /var/lib/rpm/Installtid c..... /var/lib/rpm/Name c..... /var/lib/rpm/Packages c..... /var/lib/rpm/Providename c..... /var/lib/rpm/Requirename c..... /var/lib/rpm/Sha1header c..... /var/lib/rpm/Sigmd5要显示某份文件的差异,请运行
snapper diff
PRE..POST 文件名。如果没有指定文件名,则会显示所有文件的差异。tux >
sudo
snapper diff 350..351 /usr/share/fonts/truetype/fonts.scale --- /.snapshots/350/snapshot/usr/share/fonts/truetype/fonts.scale 2014-04-23 15:58:57.000000000 +0200 +++ /.snapshots/351/snapshot/usr/share/fonts/truetype/fonts.scale 2014-05-07 16:46:31.000000000 +0200 @@ -1,4 +1,4 @@ -1174 +1486 ds=y:ai=0.2:luximr.ttf -b&h-luxi mono-bold-i-normal--0-0-0-0-c-0-iso10646-1 ds=y:ai=0.2:luximr.ttf -b&h-luxi mono-bold-i-normal--0-0-0-0-c-0-iso8859-1 [...]要恢复一或多份文件,请运行
snapper -v undochange
PRE..POST 文件名。如果没有指定文件名,则会恢复所有已更改的文件。tux >
sudo
snapper -v undochange 350..351 create:0 modify:13 delete:7 undoing change... deleting /usr/share/doc/packages/mikachan-fonts deleting /usr/share/doc/packages/mikachan-fonts/COPYING deleting /usr/share/doc/packages/mikachan-fonts/dl.html deleting /usr/share/fonts/truetype/みかちゃん-p.ttf deleting /usr/share/fonts/truetype/みかちゃん-pb.ttf deleting /usr/share/fonts/truetype/みかちゃん-ps.ttf deleting /usr/share/fonts/truetype/みかちゃん.ttf modifying /usr/share/fonts/truetype/fonts.dir modifying /usr/share/fonts/truetype/fonts.scale modifying /var/cache/fontconfig/7ef2298fde41cc6eeb7af42e48b7d293-x86_64.cache-4 modifying /var/lib/rpm/Basenames modifying /var/lib/rpm/Dirnames modifying /var/lib/rpm/Group modifying /var/lib/rpm/Installtid modifying /var/lib/rpm/Name modifying /var/lib/rpm/Packages modifying /var/lib/rpm/Providename modifying /var/lib/rpm/Requirename modifying /var/lib/rpm/Sha1header modifying /var/lib/rpm/Sigmd5 undoing change done
建议不要使用 Snapper 通过撤销更改的方式来还原用户添加。因为快照中排除了一些目录,文件系统中将保留属于用户的文件。如果使用已删除用户的 ID 创建新用户,该用户将继承原用户的文件。因此,强烈建议您使用 YaST 的
工具来删除用户。7.2.2 使用 Snapper 恢复文件 #
除了安装和管理快照之外,Snapper 还会创建时间线快照。您可以使用这些备份快照还原意外删除的文件或文件的前一个版本。您也可以使用 Snapper 的差异功能来确定在某个时间点所做的修改。
还原文件功能对于默认情况下不会生成快照的那些子卷或分区上的数据特别有用。例如,要从主目录还原文件,可以为自动生成时间线快照的 /home
创建单独的 Snapper 配置。有关指导,请参见第 7.4 节 “创建并修改 Snapper 配置”。
从根文件系统(由 Snapper 的根配置定义)生成的快照可用于执行系统回滚。进行此类回滚时,建议先从快照引导,然后再执行回滚。有关详细信息,请参见第 7.3 节 “通过从快照引导来执行系统回滚”。
从根文件系统快照还原所有文件(如下文中所述)也可以达到回滚的目的,但不建议这样做。您可以还原个别文件,例如还原 /etc
目录中的某个配置文件,但不能从快照中还原一系列文件。
此限制仅针对根文件系统的快照!
从 YaST 中的
部分或通过输入 来启动Snapper
模块。选择要从中选择快照的
。选择要用于恢复文件的时间线快照,并选择
。时间线快照的类型为 ,描述为 。单击文件名从文本框中选择文件。系统会显示快照版本和当前系统之间的差异。勾选复选框来选中要恢复的文件。请对要恢复的所有文件执行此操作。
单击
,然后单击 以确认该操作。
snapper
命令恢复文件 #运行以下命令来显示特定配置的一系列时间线快照:
tux >
sudo
snapper -c CONFIG list -t single | grep timelineCONFIG 需要替换为现有的 Snapper 配置。使用
snapper list-configs
显示列表。运行以下命令来显示指定快照中发生更改的一系列文件:
tux >
sudo
snapper -c CONFIG status SNAPSHOT_ID..0将 SNAPSHOT_ID 替换为您要用于恢复文件的快照的 ID。
(可选)运行以下命令列出当前文件版本与快照中文件版本的差异:
tux >
sudo
snapper -c CONFIG diff SNAPSHOT_ID..0 FILE NAME如果不指定 <FILE NAME>,则会显示所有文件的差异。
要恢复一个或多个文件,请运行
tux >
sudo
snapper -c CONFIG -v undochange SNAPSHOT_ID..0 FILENAME1 FILENAME2如果没有指定文件名,则会恢复所有已更改的文件。
7.3 通过从快照引导来执行系统回滚 #
SUSE Linux Enterprise Desktop 上包含的 GRUB 2 版本可以从 Btrfs 快照进行引导。与 Snapper 的回滚功能相结合,就能恢复配置错误的系统。只有针对默认 Snapper 配置(根
)创建的快照才可引导。
从 SUSE Linux Enterprise Desktop 15 SP1 开始,只有在根分区的默认子卷配置未更改过的情况下,才支持系统回滚。
引导快照时,快照中包含的文件系统部分会装载为只读状态;从快照中排除的所有其他文件系统和部分会加载为读写状态,并且可以修改。
通过快照来恢复数据时,必须知道,Snapper 可以处理两种完全不同的情形:
- 撤销更改
在如第 7.2 节 “使用 Snapper 撤销更改”中所述撤销更改时,系统会对两个快照进行比较,并还原两个快照之间的更改。通过这种方式可以明确指定不还原所选的文件。
- 回滚
在如下文所述进行回滚时,系统会重设置为生成快照时的状态。
要从可引导快照进行回滚,必须满足以下要求。执行默认安装时,系统会进行相应的设置。
根文件系统必须是 Btrfs。不支持从 LVM 卷快照引导。
根文件系统必须在单个设备、单个分区和单个子卷上。
/srv
等快照中排除的目录(参见第 7.1.2 节 “快照中排除的目录”了解完整列表)可以位于单独的分区。系统应能够借助安装的引导加载程序进行引导。
要从可引导快照进行回滚,请执行以下操作:
引导系统。在引导菜单中选择
,然后选择要引导的快照。快照会按日期顺序从近到远一一列出。登录系统。仔细检查是否一切运行正常。请注意,您无法对快照包含的任何目录进行写操作。写入其他目录的数据无论您下一步选择什么操作都不会丢失。
根据您是否要执行回滚,选择下一步操作:
如果您不想对当前状态的系统执行回滚,请重引导进入当前的系统状态。然后,您便可选择另一个快照,或是启动救援系统。
要执行回滚,请运行
tux >
sudo
snapper rollback然后重引导。在引导屏幕上,选择默认的引导项以重引导至恢复后的系统。系统即会创建回滚前文件系统状态的快照。根的默认子卷将替换为全新的读写快照。有关细节,请参见第 7.3.1 节 “回滚后的快照”。
通过
-d
选项添加快照的说明非常实用。例如:New file system root since rollback on DATE TIME
如果安装期间未禁用快照,将在初始系统安装结束时创建初始可引导快照。您随时可以通过引导此快照返回到该状态。该快照可通过 after installation
说明识别。
开始对服务包或新的主要版本进行系统升级时,也会创建可引导快照(前提是未禁用快照)。
7.3.1 回滚后的快照 #
在执行回滚之前,将会创建正在运行的文件系统的快照。快照说明会引用在回滚中恢复的快照的 ID。
对于通过回滚创建的快照,其 Cleanup
属性的值会设为 number
。因此,回滚快照会在达到设置的快照数后自动删除。有关细节,请参见第 7.6 节 “自动清理快照”。如果快照包含重要数据,请在系统去除快照之前从快照中提取数据。
7.3.1.1 回滚快照示例 #
例如,在全新安装之后,系统上存在以下可用的快照:
root #
snapper
--iso list Type | # | | Cleanup | Description | Userdata -------+---+ ... +---------+-----------------------+-------------- single | 0 | | | current | single | 1 | | | first root filesystem | single | 2 | | number | after installation | important=yes
运行 sudo snapper rollback
之后,将会创建快照 3
,它包含执行回滚前系统的状态。快照 4
是新的默认 Btrfs 子卷,因此是重引导之后的系统。
root #
snapper
--iso list Type | # | | Cleanup | Description | Userdata -------+---+ ... +---------+-----------------------+-------------- single | 0 | | | current | single | 1 | | number | first root filesystem | single | 2 | | number | after installation | important=yes single | 3 | | number | rollback backup of #1 | important=yes single | 4 | | | |
7.3.2 访问和识别快照引导项 #
要从快照引导,请重引导计算机并选择↓ 和 ↑ 导航,然后按 Enter 激活选定的快照。从引导菜单激活快照不会立即重引导计算机,而是打开选定快照的引导加载程序。
。一个屏幕即会打开,列出所有可引导的快照。最近的快照列在最前面,最旧的快照列在最后面。使用引导加载程序中的每个快照项遵循一种可方便您识别快照的命名模式:
[*]1OS2 (KERNEL3,DATE4TTIME5,DESCRIPTION6)
如果快照标记为 | |
操作系统标签。 | |
采用 | |
采用 | |
此字段包含快照的说明。对于手动创建的快照,这是使用选项 |
可以将快照说明字段中的默认字符串替换为自定义字符串。例如,如果自动创建的说明不能提供充分的描述,或者用户提供的说明太长,这种做法将十分有用。要为快照 NUMBER 设置自定义字符串 STRING,请使用以下命令:
tux >
sudo
snapper modify --userdata "bootloader=STRING" NUMBER
说明的长度不应超过 25 个字符,超过此大小的任何内容都无法在引导屏幕上正常显示。
7.3.3 限制 #
不可能实现完整的系统回滚,即将整个系统恢复到生成快照时完全相同的状态。
7.3.3.1 快照中排除的目录 #
根文件系统快照并不包含所有目录。请参见第 7.1.2 节 “快照中排除的目录”了解详情和背后的原因。正因为此,这些目录中的数据并不会恢复,也就造成了以下限制。
- 回滚后,附加产品和第三方软件可能会无法使用
在快照中排除的子卷(如
/opt
)上安装了数据的应用程序和附加产品,如果在快照中包含的子卷上也安装了部分应用程序数据,则回滚后,这些应用程序和附加产品将无法工作。要解决此问题,需要重新安装该应用程序或附加产品。- 文件访问问题
如果某个应用程序在快照和当前系统之间更改了文件权限和/或所有权,回滚后,该应用程序可能无法访问这些文件。请在回滚后重设置受影响的文件的权限和/或所有权。
- 数据格式不兼容
如果服务或应用程序在快照和当前系统之间建立了新的数据格式,回滚后,该应用程序可能无法读取受影响的数据文件。
- 混合了代码和数据的子卷
诸如
/srv
之类的子卷可能同时包含代码和数据。回滚可能会导致代码失效。例如,降级 PHP 的版本可能会导致 Web 服务器的 PHP 脚本被破坏。- 用户数据
如果回滚操作从系统中删除了用户,这些用户在快照中未包含的目录上所拥有的数据并不会删除。如果使用相同的用户 ID 创建新用户,该用户便会继承原用户的文件。请使用
find
之类的工具找到并删除孤立的文件。
7.3.3.2 不回滚引导装载程序数据 #
无法回滚引导装载程序,因为引导装载程序的所有“阶段”必须相互匹配。这在 /boot
回滚时并不能保证。
7.4 创建并修改 Snapper 配置 #
每一个分区或 Btrfs
子卷都有一个专用的配置文件用于定义 Snapper 的行为方式。这些配置文件位于 /etc/snapper/configs/
下。
如果根文件系统足够大(大约有 12 GB),安装时将自动对根文件系统 /
启用快照。相应的默认配置命名为 root
。该配置可创建和管理 YaST 及 Zypper 快照。有关默认值列表,请参见第 7.4.1.1 节 “配置数据”。
如第 7.1 节 “默认设置”中所述,要启用快照,根文件系统中需要有额外的可用空间。所需空间取决于所安装的包数量以及快照中包括的卷更改量,另外还取决于快照频率和存档的快照数。
要在安装期间自动启用快照,需要满足最小根文件系统大小。目前,此大小约为 12 GB。将来,这个值可能会发生变化,具体视基础系统的体系结构和大小而定。它取决于安装媒体内 /control.xml
文件中以下标记的值:
<root_base_size> <btrfs_increase_percentage>
该值通过下面的公式计算得出:ROOT_BASE_SIZE * (1 + BTRFS_INCREASE_PERCENTAGE/100)
请记住,此值是最小大小。请考虑分给根文件系统更多空间。一般而言,两倍于未启用快照时将使用的大小即可。
您可以为使用 Btrfs
格式化的其他分区或 Btrfs
分区上的现有子卷创建自己的配置。在以下示例中,我们将设置 Snapper 配置,以便对驻留在单独的、以 Btrfs
格式化且安装点为 /srv/www
的分区的 Web 服务器数据进行备份。
创建配置后,您可以直接使用 snapper
,也可以使用 YaST 模块,从这些快照恢复文件。在 YaST 中,您需要选择您的 ,同时还需要使用全局开关 -c
指定 snapper 的配置(例如
snapper -c myconfig
list)。
要创建新的 Snapper 配置,请运行 snapper create-config
:
tux >
sudo
snapper -c www-data1 create-config /srv/www2
此命令将使用合理的默认值(取自 /etc/snapper/config-templates/default
)创建新的配置文件 /etc/snapper/configs/www-data
。有关如何调整这些值的指导,请参考第 7.4.1 节 “管理现有配置”。
新配置的默认值取自 /etc/snapper/config-templates/default
。要使用自己的一组默认值,请在相同的目录中创建此文件的副本然后按照需要进行调整。要使用此功能,请在 create-config 命令中指定 -t
选项:
tux >
sudo
snapper -c www-data create-config -t MY_DEFAULTS /srv/www
7.4.1 管理现有配置 #
snapper
有多个子命令可用于管理现有的配置。您可以列出、显示这些配置,也可以对它们进行删除和修改:
- 列出配置
使用
snapper list-configs
命令可以显示所有现有的配置:tux >
sudo
snapper list-configs Config | Subvolume -------+---------- root | / usr | /usr local | /local- 显示配置
使用
snapper -c CONFIG
get-config 子命令可以显示指定的配置。CONFIG 应替换为执行snapper list-configs
命令后所显示的某个配置名称。请参见第 7.4.1.1 节 “配置数据”以了解有关配置选项的更多信息。要显示默认配置,请运行
tux >
sudo
snapper -c root get-config- 修改配置
使用
snapper -c CONFIG set-config OPTION=VALUE
子命令可以修改指定配置中的选项。CONFIG 应替换为执行snapper list-configs
命令后所显示的某个配置名称。OPTION 和 VALUE 的可能值可参见第 7.4.1.1 节 “配置数据”。- 删除配置
使用
snapper -c CONFIG
delete-config 子命令可以删除配置。CONFIG 应替换为执行snapper list-configs
命令后所显示的某个配置名称。
7.4.1.1 配置数据 #
每个配置都包含一系列选项,这些选项可以通过命令行进行修改。下面的列表提供了每个选项的细节。要更改某个值,请运行 snapper -c CONFIG set-config "KEY=VALUE"
。
ALLOW_GROUPS
、ALLOW_USERS
授予普通用户使用快照的权限。有关详细信息,请参见第 7.4.1.2 节 “以普通用户身份使用 Snapper”。
默认值是
""
。BACKGROUND_COMPARISON
定义在创建前后快照后是否应在后台对它们进行比较。
默认值为
"yes"
。EMPTY_*
为前后快照相同的快照对定义清理算法。有关详细信息,请参见第 7.6.3 节 “清理没有差异的快照对”。
FSTYPE
分区的文件系统类型。不更改。
默认值为
"btrfs"
。- NUMBER_*
为安装快照与管理快照定义清理算法。有关详细信息,请参见第 7.6.1 节 “清理编号快照”。
QGROUP
/SPACE_LIMIT
将定额支持添加到清理算法。有关详细信息,请参见第 7.6.5 节 “添加磁盘定额支持”。
SUBVOLUME
分区或子卷生成快照的安装点。不更改。
默认值是
"/"
.SYNC_ACL
如果普通用户要使用 Snapper(请参见第 7.4.1.2 节 “以普通用户身份使用 Snapper”),他们必须能访问
.snapshot
目录,并且能读取其中的文件。如果 SYNC_ACL 设置为yes
,Snapper 会通过 ACL 自动允许 ALLOW_USERS 和 ALLOW_GROUPS 项指定的用户和组访问这些目录及其中的文件。默认值为
"no"
。TIMELINE_CREATE
如果设置为
yes
,便会每小时创建一个快照。有效值:yes
、no
.默认值为
"no"
。TIMELINE_CLEANUP
/TIMELINE_LIMIT_*
为时间线快照定义清理算法。有关详细信息,请参见第 7.6.2 节 “清理时间线快照”。
7.4.1.2 以普通用户身份使用 Snapper #
默认情况下,Snapper 只能由 root
用户使用。但在特定情况下,某些组或用户也需要创建快照或通过还原至快照来撤销更改:
想要为
/srv/www
生成快照的网站管理员想要为自己的主目录生成快照的用户
此类情况下,可以创建为用户和(或)组授予权限的 Snapper 配置。指定的用户必须能连接并访问相应的 .snapshots
目录。要实现这一点,最简单的方法是将 SYNC_ACL 选项设置为 yes
。
请注意,此过程中的所有步骤都需要由 root
用户运行。
如果不存在,则请为用户可以使用 Snapper 的分区或子卷创建 Snapper 配置。有关指导,请参见第 7.4 节 “创建并修改 Snapper 配置”。示例:
tux >
sudo
snapper --config web_data create /srv/www在
/etc/snapper/configs/CONFIG
下创建配置文件,其中“CONFIG”是您在上一步中使用-c/--config
指定的值(例如/etc/snapper/configs/web_data
)。按照需要进行调整;有关详细信息,请参见第 7.4.1 节 “管理现有配置”。为
ALLOW_USERS
和(或)ALLOW_GROUPS
设置值,以分别为用户和(或)组授予权限。多个条目需要使用 Space 分隔。例如,要为用户www_admin
授予权限,可运行:tux >
sudo
snapper -c web_data set-config "ALLOW_USERS=www_admin" SYNC_ACL="yes"此时,指定的用户和(或)组便可以使用指定的 Snapper 配置。您可以使用
list
命令对其进行测试,例如:www_admin:~ > snapper -c web_data list
7.5 手动创建和管理快照 #
Snapper 的功能并不仅限于根据配置自动创建和管理快照;您还可以使用命令行工具或 YaST 模块手动创建快照对(“前快照和后快照”)或单一快照。
所有 Snapper 操作皆针对现有配置执行(有关详细信息,请参见第 7.4 节 “创建并修改 Snapper 配置”)。您可以只为存在配置的分区或卷生成快照。默认情况下使用系统配置 (root
)。要为自己的配置创建或管理快照,则需要明确选择您的配置。使用 YaST 中的 下拉框,或在命令行上指定 -c
(即 snapper -c 我的配置
命令
)。
7.5.1 快照元数据 #
每一张快照均由快照本身以及一些元数据组成。创建快照时,您还需要指定元数据。修改快照就意味着更改其元数据——您无法修改其内容。使用 snapper list
可显示现有快照及其元数据:
snapper --config home list
列出配置
home
的快照。要列出默认配置 (root) 的快照,请使用snapper -c root list
或snapper list
。snapper list -a
列出所有现有配置的快照。
snapper list -t pre-post
列出默认 (
root
) 配置的所有前快照和后快照对。snapper list -t single
列出默认 (
root
) 配置的所有单一
类型的快照。
每一张快照可以使用以下元数据:
类型:快照类型,有关详细信息,请参见第 7.5.1.1 节 “快照类型”。不能更改此数据。
编号:快照的唯一编号。不能更改此数据。
前编号:指定相应前快照的编号。仅适用于后类型。不能更改此数据。
说明:快照的说明。
用户数据:扩展的说明。您可使用逗号分隔的“键=值”列表格式指定自定义数据:
reason=testing, project=foo
。此字段也可用于将快照标记为重要 (important=yes
) 以及列出创建快照的用户 (user=tux)。清理算法:快照的清理算法。有关详细信息,请参见第 7.6 节 “自动清理快照”。
7.5.1.1 快照类型 #
Snapper 能够分清三种不同类型的快照:前快照、后快照以及单一快照。从物理上讲,这三种快照没有什么不同,但 Snapper 会针对不同类型采用不同的处理方式。
前
修改前的文件系统快照。每一张
前
快照都有一个对应的后
快照。目的之一就是为了自动创建 YaST/Zypper 快照。后
修改后的文件系统快照。每一张
后
快照都有一个对应的前
快照。目的之一就是为了自动创建 YaST/Zypper 快照。单一
独立的快照。目的之一就是为了自动创建每小时快照。此为创建快照时的默认类型。
7.5.1.2 清理算法 #
Snapper 提供有三种清理旧快照的算法。这些算法在日常的 cron 作业中执行。您可以定义要在 Snapper 配置中保留的不同类型的快照数(有关细节,请参见第 7.4.1 节 “管理现有配置”)。
- 数量
当达到某一快照计数时将删除旧快照。
- 时间线
将删除超过一定时限的旧快照,但保留若干个每小时、每天、每月和每年快照。
- 无差异前后快照对
将删除无差异的前后快照对。
7.5.2 创建快照 #
通过运行 snapper create
或单击 YaST 的 模块中的 来创建快照。以下示例解释了如何从命令行创建快照。使用 YaST 界面会比较简单。
为了便于日后确定快照的用途,您应始终指定有意义的说明。甚至可以通过用户数据选项指定更多信息。
snapper create --description "2014 年第二周快照"
创建默认 (
root
) 配置的独立快照(单一类型)并附加说明。因为没有指定清理算法,将不会自动删除快照。snapper --config home create --description "~tux 中清理"
为名为
home
的自定义配置创建独立快照(单一类型)并附加说明。因为没有指定清理算法,将不会自动删除快照。snapper --config home create --description "每日数据备份" --cleanup-algorithm timeline
>为名为
home
的自定义配置创建独立快照(单一类型)并附加说明。一旦符合为配置中的时间线清理算法指定的条件,便会自动删除文件。snapper create --type pre--print-number--description "Apache 配置清理之前"--userdata "important=yes"
创建
前
类型的快照并打印快照编号。创建用于保存“之前”和“之后”状态的快照对所需的首个命令。该快照标记为重要。snapper create --type post--pre-number 30--description "Apache 配置清理之后"--userdata "important=yes"
创建
后
类型的快照且其对应的前
快照编号为30
。创建用于保存“之前”和“之后”状态的快照对所需的第二个命令。该快照标记为重要。snapper create --command COMMAND--description "命令前后"
运行命令前后自动创建快照对。此选项仅在于命令行上使用 snapper 时可用。
7.5.3 修改快照元数据 #
Snapper 允许您修改说明、清理算法及快照的用户数据。其他元数据均无法更改。以下示例解释了如何从命令行修改快照。使用 YaST 界面会比较简单。
要在命令行上修改快照,您需要知道其编号。使用 snapper list
可显示所有快照及其编号。
YaST 的
模块已列出所有快照。从列表中选择一个快照,然后单击 。snapper modify --cleanup-algorithm "timeline"
10修改默认 (
root
) 配置的第 10 张快照的元数据。清理算法设置为timeline
。snapper --config home modify --description "每日备份" -cleanup-algorithm "timeline"120
修改名为
home
的自定义配置的第 120 张快照的元数据。将设置新的说明并取消设置清理算法。
7.5.4 删除快照 #
要使用 YaST 的
模块删除快照,请从列表中选择快照,然后单击 。
要使用命令行工具删除快照,需要知道其编号。运行 snapper list
命令获取快照编号。要删除快照,请运行 snapper delete
编号。
不允许删除当前的默认子卷快照。
使用 Snapper 删除快照时,在后台运行的 Btrfs 进程将会回收释放的空间。因此,可用空间的可见性与可用性会延迟。如果您希望在删除快照后立即可以使用释放的空间,请结合选项 --sync
使用 delete 命令。
删除前
快照时,您应始终删除与其对应的后
快照(反之亦然)。
snapper delete 65
删除默认 (
root
) 配置的第 65 张快照。snapper -c home delete 89 90
删除名为
home
的自定义配置的第 89 张和第 90 张快照。snapper delete --sync 23
删除默认 (
root
) 配置的快照 23,并使释放的空间立即可用。
有时,虽然 Btrfs 快照存在,但却缺少包含 Snapper 元数据的 XML 文件。这种情况表示快照对 Snapper 不可见,需要手动将其删除:
btrfs subvolume delete /.snapshots/SNAPSHOTNUMBER/snapshot rm -rf /.snapshots/SNAPSHOTNUMBER
如果您要删除快照以释放硬盘上的空间,请务必先删除旧快照。快照生成的时间越长,其占用的空间就越大。
也可以通过日常的 cron 作业自动删除快照。有关详细信息,请参见第 7.5.1.2 节 “清理算法”。
7.6 自动清理快照 #
快照会占用磁盘空间,随着时间的推移,快照占用的磁盘空间可能会变得非常多。为了防止磁盘上的空间耗尽,Snapper 提供了用于自动删除旧快照的算法。这些算法根据时间线快照和编号快照(管理快照与安装快照对)而有所不同。您可以指定要为每种类型保留的快照数。
除此之外,您可以选择指定一个磁盘空间定额,用于定义快照可占用的最大磁盘空间大小。系统还可以自动删除前快照与后快照没有任何不同的快照对。
清理算法始终绑定到单个 Snapper 配置,因此您需要为每个配置指定算法。要防止自动删除特定的快照,请参见 如何永久保留快照? 。
默认设置 (root
) 配置为清理编号快照以及空的前快照与后快照对。已启用定额支持 - 快照占用的空间不可超过根分区可用磁盘空间的 50%。时间线快照默认处于禁用状态,因此,时间线清理算法也处于禁用状态。
7.6.1 清理编号快照 #
编号快照(管理快照与安装快照对)的清理由 Snapper 配置的以下参数控制。
NUMBER_CLEANUP
启用或禁用安装快照与管理快照对的清理。如果启用该参数,则当快照总数超过
NUMBER_LIMIT
和/或NUMBER_LIMIT_IMPORTANT
指定的数字以及NUMBER_MIN_AGE
指定的时限时,将删除快照对。有效值:yes
(启用)、no
(禁用)。默认值为
"yes"
。用于更改或设置值的示例命令:
tux >
sudo
snapper -c CONFIG set-config "NUMBER_CLEANUP=no"NUMBER_LIMIT
/NUMBER_LIMIT_IMPORTANT
定义要保留多少个普通和/或重要安装快照与管理快照对。所保留的会是最新的那些快照。如果
NUMBER_CLEANUP
设置为"no"
,则会忽略此参数。NUMBER_LIMIT
的默认值为"2-10"
,NUMBER_LIMIT_IMPORTANT
的默认值为"4-10"
。用于更改或设置值的示例命令:
tux >
sudo
snapper -c CONFIG set-config "NUMBER_LIMIT=10"重要:范围值与常量值的比较如果启用定额支持(请参见第 7.6.5 节 “添加磁盘定额支持”),则需要将限制指定为最小值-最大值范围,例如
2-10
。如果禁用定额支持,则需要提供常量值,例如10
,否则清理将会失败并返回错误。NUMBER_MIN_AGE
定义快照在自动删除前必须保留的最小时限(以秒为单位)。保留时间小于此处指定值的快照不会删除,不管这样的快照有多少。
默认值为
"1800"
。用于更改或设置值的示例命令:
tux >
sudo
snapper -c CONFIG set-config "NUMBER_MIN_AGE=864000"
NUMBER_LIMIT
、NUMBER_LIMIT_IMPORTANT
和 NUMBER_MIN_AGE
始终都会评估。只有同时符合全部条件才会删除快照。
如果您希望不考虑时限而始终保留 NUMBER_LIMIT*
所定义数量的快照,可将 NUMBER_MIN_AGE
设置为 0
。
下面的示例显示了保留最近 10 个重要和 10 个普通快照(不论保留期限)的配置:
NUMBER_CLEANUP=yes NUMBER_LIMIT_IMPORTANT=10 NUMBER_LIMIT=10 NUMBER_MIN_AGE=0
另外,如果不想保留超过一定时限的快照,可将 NUMBER_LIMIT*
设置为 0
,并用 NUMBER_MIN_AGE
指定时限。
下面的示例显示了只保留十天以内的快照的配置:
NUMBER_CLEANUP=yes NUMBER_LIMIT_IMPORTANT=0 NUMBER_LIMIT=0 NUMBER_MIN_AGE=864000
7.6.2 清理时间线快照 #
时间线快照的清理由 Snapper 配置的以下参数控制。
TIMELINE_CLEANUP
启用或禁用时间线快照的清理。如果启用该参数,则当快照总数超过
TIMELINE_LIMIT_*
指定的数字以及TIMELINE_MIN_AGE
指定的时限时,将删除快照。有效值:yes
、no
.默认值为
"yes"
。用于更改或设置值的示例命令:
tux >
sudo
snapper -c CONFIG set-config "TIMELINE_CLEANUP=yes"TIMELINE_LIMIT_DAILY
、TIMELINE_LIMIT_HOURLY
、TIMELINE_LIMIT_MONTHLY
、TIMELINE_LIMIT_WEEKLY
、TIMELINE_LIMIT_YEARLY
按小时、天、月、周和年保留的快照数量。
每项的默认值为
"10"
,但TIMELINE_LIMIT_WEEKLY
除外,该参数默认设置为"0"
。TIMELINE_MIN_AGE
定义快照在自动删除前必须保留的最小时限(以秒为单位)。
默认值为
"1800"
。
TIMELINE_CLEANUP="yes" TIMELINE_CREATE="yes" TIMELINE_LIMIT_DAILY="7" TIMELINE_LIMIT_HOURLY="24" TIMELINE_LIMIT_MONTHLY="12" TIMELINE_LIMIT_WEEKLY="4" TIMELINE_LIMIT_YEARLY="2" TIMELINE_MIN_AGE="1800"
此示例配置能够实现按小时生成将自动清理的快照。TIMELINE_MIN_AGE
和 TIMELINE_LIMIT_*
始终会一起评估。在本示例中,快照删除前的最小保留时限设置为 30 分钟(1800 秒)。因为我们会每小时创建一次快照,所以确保了只会保留最近的快照。如果 TIMELINE_LIMIT_DAILY
设置为非零值,则表示还会保留当天的首张快照。
每小时:最近创建的 24 个快照。
每天:保留最近 7 天内每天创建的首个快照。
每月:保留最近 12 个月内每月的最后一天创建的首个快照。
每周:保留最近 4 周内每周最后一天创建的首个快照。
每年:保留最近 2 年内每年最后一天创建的首个快照。
7.6.3 清理没有差异的快照对 #
如第 7.1.1 节 “快照类型”中所述,每当您运行 YaST 模块或执行 Zypper 时,将在启动时创建一个前快照,在退出时创建一个后快照。如果您未进行过任何更改,则前快照与后快照没有差异。在 Snapper 配置中设置以下参数可自动删除此类“空”快照对:
EMPTY_PRE_POST_CLEANUP
如果设置为
yes
,系统会删除前后快照相同的快照对。默认值为
"yes"
。EMPTY_PRE_POST_MIN_AGE
定义前后快照相同的快照对在自动删除之前必须保留的最短时限(以秒为单位)。
默认值为
"1800"
。
7.6.4 清理手动创建的快照 #
Snapper 未针对手动创建的快照提供自定义清理算法。但是,您可以向手动创建的快照指派 number 或 timeline 清理算法。如此,该快照将加入您所指定的算法的“清理队列”。可以在创建快照时或通过修改现有快照来指定清理算法:
snapper create --description "Test" --cleanup-algorithm number
为默认 (root) 配置创建独立快照(单一类型)并指派
number
清理算法。snapper modify --cleanup-algorithm "timeline" 25
使用数字 25 修改快照,并指派
timeline
清理算法。
7.6.5 添加磁盘定额支持 #
除了上述 number 和/或 timeline 清理算法外,Snapper 还支持定额。您可以定义允许快照占用的可用空间百分比。此百分比值始终适用于相应 Snapper 配置中定义的 Btrfs 子卷。
如果在安装期间启用了 Snapper,则会自动启用定额支持。如果您是在安装后的某个时间手动启用 Snapper 的,则可以通过运行 snapper setup-quota
来启用定额支持。这需要您具有有效的配置(有关详细信息,请参见第 7.4 节 “创建并修改 Snapper 配置”)。
定额支持由 Snapper 配置的以下参数控制。
QGROUP
Snapper 使用的 Btrfs 定额组。如果未设置,请运行
snapper setup-quota
。如果已设置,则仅在您熟悉man 8 btrfs-qgroup
的情况下才可对其进行更改。此值是使用snapper setup-quota
设置的,不应更改。SPACE_LIMIT
允许快照使用的空间限制,以 1 (100%) 的分数表示。有效值范围为 0 到 1(0.1 = 10%,0.2 = 20%...)。
需遵守以下限制和指导原则:
只能在已激活现有 number 和/或 timeline 清理算法的前提下才能激活定额。如果未激活任何清理算法,则无法应用定额限制。
启用定额支持后,Snapper 将根据需要执行两轮清理。第一轮清理将应用针对编号快照和时间线快照指定的规则。仅当完成这一轮清理后超出定额时,在第二轮清理中才会应用定额特定的规则。
即使启用了定额支持,Snapper 也始终会保留
NUMBER_LIMIT*
和TIMELINE_LIMIT*
值指定的快照数,而不管是否超出了定额。因此,建议为NUMBER_LIMIT*
和TIMELINE_LIMIT*
指定范围值 (MIN-MAX
),以确保可以应用定额。例如,如果设置了
NUMBER_LIMIT=5-20
,Snapper 将执行第一轮清理,并将普通的编号快照数量减至 20 个。如果这 20 个快照超出定额,Snapper 将在第二轮清理中删除最旧的快照,直到符合定额限制。系统始终会至少保留 5 个快照,不管这些快照占用了多少空间。
7.7 常见问题 #
- 问:
为什么 Snapper 从不显示
/var/log
、/tmp
以及其他目录中的更改? 因为我们将部分目录排除在了快照之外。详细的列表和具体原因请参见第 7.1.2 节 “快照中排除的目录”。为了将路径从快照中排除,我们为该路径创建了子卷。
- 问: 快照要占用多少磁盘空间?如何释放磁盘空间?
目前,
Btrfs
工具还不支持显示分配给快照的磁盘空间大小。不过,如果启用了定额,便可确定在删除所有快照后将会释放多少空间:获取定额组 ID(在下面的示例中为
1/0
):tux >
sudo
snapper -c root get-config | grep QGROUP QGROUP | 1/0重新扫描子卷定额:
tux >
sudo
btrfs quota rescan -w /显示定额组(在下面的示例中为
1/0
)的数据:tux >
sudo
btrfs qgroup show / | grep "1/0" 1/0 4.80GiB 108.82MiB第三列显示删除所有快照后将释放的空间 (
108.82MiB
)。
为了释放包含快照的
Btrfs
分区的空间,您需要删除不需要的快照,而不是文件。旧快照比新快照占用的磁盘空间更多。有关详细信息,请参见第 7.1.3.4 节 “控制快照存档”。升级服务包时,由于会更改大量数据(包更新),将导致快照占用大量系统子卷的磁盘空间。因此对于不再需要的快照,建议手动删除。有关详细信息,请参见第 7.5.4 节 “删除快照”。
- 问: 我可以从引导加载程序引导快照吗?
可以。有关细节,请参考第 7.3 节 “通过从快照引导来执行系统回滚”。
- 问: 如何永久保留快照?
目前,Snapper 尚无防止手动删除快照的功能。不过,您可以防止清理算法自动删除快照。除非您使用
--cleanup-algorithm
指定了清理算法,否则不会为手动创建的快照(请参见第 7.5.2 节 “创建快照”)指派清理算法。自动创建的快照始终会被指派number
或timeline
算法。要从一个或多个快照去除此类指派,请执行以下操作:列出所有可用快照:
tux >
sudo
snapper list -a记住您要防止删除的快照数。
运行以下命令并将数字占位符替换为您记住的数字:
tux >
sudo
snapper modify --cleanup-algorithm "" #1 #2 #n再次运行
snapper list -a
检查结果。在Cleanup
列中,您修改的快照所对应的项现在应该为空。
- 问: 何处能获得有关 Snapper 的详细信息?
请访问 Snapper 的主页,网址为:http://snapper.io/。
8 使用 VNC 远程访问 #
利用虚拟网络计算(Virtual Network Computing,VNC)可以通过图形桌面控制远程计算机(与远程外壳访问相对)。VNC 是独立于平台的并允许您从任何操作系统访问远程计算机。
SUSE Linux Enterprise Desktop 支持两种不同种类的 VNC 会话:只要客户端的 VNC 连接不中断即会保持“在线”的一次性会话,和始终“在线”直到被明确终止的永久会话。
一台计算机可在不同端口上同时提供两种会话,但当会话打开后不能从一种类型转换为另一种类型。
8.1 vncviewer
客户端 #
要连接到服务器提供的 VNC 服务,需要使用客户端。SUSE Linux Enterprise Desktop 中的默认客户端是 tigervnc
包提供的 vncviewer
。
8.1.1 使用 vncviewer CLI 进行连接 #
要启动 VNC 查看器并发起与服务器的会话,请使用以下命令:
tux >
vncviewer jupiter.example.com:1
若不使用 VNC 显示器编号,您也可以指定带两个冒号的端口号:
tux >
vncviewer jupiter.example.com::5901
您在 VNC 客户端中指定的实际显示号或端口号必须与在目标计算机上通过 vncserver
命令提取的显示号或端口号相同。有关更多信息,请参见第 8.4 节 “持续 VNC 会话”。
8.1.2 使用 vncviewer GUI 进行连接 #
在不指定 --listen
或要连接的主机的情况下运行 vncviewer
会显示一个窗口,要求您输入连接细节。按第 8.1.1 节 “使用 vncviewer CLI 进行连接”中所述在 字段中输入主机,然后单击 。
8.1.3 未加密连接通知 #
VNC 协议支持不同类型的加密连接,请不要将这些连接与口令身份验证相混淆。如果某个连接未使用 TLS,VNC 查看器的窗口标题中可能会出现“(连接未加密!)”文本。
8.2 Remmina:远程桌面客户端 #
Remmina 是功能丰富的新式远程桌面客户端。它支持多种访问方法,例如 VNC、SSH、RDP 或 Spice。
8.2.1 安装 #
要使用 Remmina,请检查系统上是否安装了 remmina 包,如未安装,请加以安装。记得还要安装适用于 Remmina 的 VNC 插件:
root #
zypper in remmina remmina-plugin-vnc
8.2.2 主窗口 #
通过输入 remmina
命令运行 Remmina。
该应用程序主窗口显示储存的远程会话列表。在这里,您可以添加和保存新远程会话、快速启动新会话而不保存、启动以前保存的会话,或设置 Remmina 的全局首选项。
8.2.3 添加远程会话 #
要添加和保存新远程会话,请单击主窗口左上方的 。 窗口即会打开。
在用于指定新添加的远程会话配置文件的字段中填写信息。最重要的技术包括:
- 名称
配置文件的名称,将列于主窗口中。
- 协议
连接到远程会话时要使用的协议,例如 VNC。
- 服务器
远程服务器的 IP 或 DNS 地址和显示号。
- 用户名、口令
要用于进行远程身份验证的身份凭证。保留为空表示不进行身份验证。
- 色深、质量
根据连接速度和质量选择最佳选项。
选择
选项卡可输入更具体的设置。如果客户端与远程服务器之间的通讯不加密,请激活
,否则连接会失败。选择
选项卡可显示高级 SSH 隧道通讯进程和身份验证选项。单击
进行确认。新设置的配置文件将列在主窗口中。8.2.4 启动远程会话 #
您可以启动以前保存的会话,也可以快速启动一个远程会话而不保存连接细节。
8.2.4.1 快速启动远程会话 #
要快速启动远程会话而不添加并保存连接细节,请使用主窗口顶部的下拉框和文本框。
从下拉框中选择通讯协议(例如 VNC),然后输入 VNC 服务器 DNS 或 IP 地址,后跟一个冒号和显示号,然后按 Enter 确认。
8.2.4.2 打开保存的远程会话 #
要打开特定的远程会话,请从会话列表中双击该会话。
8.2.4.3 远程会话窗口 #
远程会话会在新窗口的标签中打开。每个标签托管一个会话。窗口左侧的工具栏可用来管理窗口/会话,例如切换全屏模式、调整窗口大小以适应会话的显示大小、将特定按键发送到会话、对会话进行屏幕截图,或设置图像质量。
8.2.5 编辑、复制和删除保存的会话 #
要编辑保存的某个远程会话,请在 Remmina 的主窗口中右键单击其名称,然后选择 。有关相关字段的说明,请参见第 8.2.3 节 “添加远程会话”。
要复制保存的某个远程会话,请在 Remmina 的主窗口中右键单击其名称,然后选择 。在 窗口中,更改配置文件的名称,(可选)调整相关选项,然后单击 确认。
要删除保存的某个远程会话,请在 Remmina 的主窗口中右键单击其名称,然后选择 。在下一个对话框中,单击 确认。
8.2.6 从命令行运行远程会话 #
如果您需要从命令行或使用批处理文件打开远程会话,而不先打开应用程序主窗口,请使用以下语法:
tux >
remmina -c profile_name.remmina
Remmina 的配置文件储存在您主目录下的 .local/share/remmina/
目录中。要确定哪个配置文件属于您要打开的会话,请运行 Remmina,在主窗口中单击会话名称,然后在窗口底部的状态行中查看配置文件的路径。
如果 Remmina 未在运行,您可以将配置文件重命名为更合理的文件名,例如 sle15.remmina
。您甚至可以将配置文件复制到自定义目录,并从该目录中使用 remmina -c
命令来运行它。
8.3 一次性 VNC 会话 #
一次性会话由远程客户端启动。它在服务器上启动图形登录屏幕。这样您可以选择启动会话的用户,并且如果登录管理器支持,还可以选择桌面环境。终止与此类 VNC 会话的客户端连接时,此会话中启动的所有应用程序也将终止。一次性 VNC 会话不能共享,但可以在一台主机上同时存在多个会话。
启动
› › 。选中
。如果您打算在 Web 浏览器窗口中访问 VNC 会话,请激活
。如果需要,还可以选中
(例如,当网络接口配置为在外部区域中时)。如果有多个网络接口,请通过 将打开防火墙端口限制为特定的接口。单击
确认您的设置。如果不是所有需要的包都可使用,则需要批准安装缺少的包。
提示:重启动显示管理器YaST 对显示管理器设置进行了更改。您需要注销当前图形会话并重启动显示管理器,以使更改生效。
8.3.1 可用配置 #
SUSE Linux Enterprise Desktop 上的默认配置以 1024x768 像素(颜色深度 16 位)显示会话。会话在端口 5901
(对于“普通”VNC 查看器,等同于 VNC 显示器 1
)和端口 5801
上可用(对于 Web 浏览器)。
其他配置可在不同端口上使用。如果需要修改配置,请咨询您的系统管理员了解细节。
VNC 显示器编号和 X 显示器编号是独立于一次性会话的。VNC 显示器编号手动指派给服务器支持的每个配置(如上例中的 :1)。只要 VNC 会话启动时带任一配置,就会自动获取可用 X 显示器编号。
默认情况下,VNC 客户端与服务器将尝试通过安装后生成的自我签名 SSL 证书安全通讯。您可以使用默认的证书,也可以将它替换为您自己的证书。使用自我签名证书时,需要在首次连接之前,在 VNC 查看器和 Web 浏览器中确认证书的签名。
8.3.2 启动一次性 VNC 会话 #
要连接一次性 VNC 会话,必须安装 VNC 查看器,另请参见第 8.1 节 “vncviewer
客户端”。或者,可在支持 JavaScript 的 Web 浏览器中输入以下 URL 来查看 VNC 会话:http://jupiter.example.com:5801
8.3.3 配置一次性 VNC 会话 #
如果不需要或想修改默认配置,则可以跳过此部分。
一次性 VNC 会话通过 systemd
套接字 xvnc.socket
启动。该套接字默认提供六个配置块:三个用于 VNC 查看器(vnc1
到 vnc3
),另外三个用于 JavaScript 客户端(vnchttpd1
到 vnchttpd3
)。默认情况下,只有 vnc1
和 vnchttpd1
是活动的。
要在引导时激活 VNC 服务器套接字,请运行以下命令:
sudo systemctl enable xvnc.socket
要立即启动套接字,请运行:
sudo systemctl start xvnc.socket
Xvnc
服务器可通过 server_args
选项配置。有关选项列表,请参见 Xvnc --help
。
当添加自定义配置时,请确保它们未使用已由其他配置、其他服务或同一主机上的现有永久 VNC 会话使用的端口。
通过输入以下命令激活配置更改:
tux >
sudo
systemctl reload xvnc.socket
按照过程 8.1 “启用一次性 VNC 会话” 中的描述激活远程管理时,端口 5801
和 5901
将在防火墙中打开。如果用于 VNC 会话的网络接口受防火墙保护,则为 VNC 会话激活更多端口时,需要手动打开各个端口。有关指导,请参见Book “Security and Hardening Guide”, Chapter 22 “Masquerading and Firewalls”。
8.4 持续 VNC 会话 #
可以从多个客户端同时访问持续会话。为了便于演示,我们选择一个较为理想的配置,一个客户端具有完全访问权限,所有其他客户端只具有查看访问权限。另一个用例是教员可能需要访问学员桌面的培训。
要连接持续 VNC 会话,必须安装 VNC 查看器。有关更多细节,请参见第 8.1 节 “vncviewer
客户端”。或者,可在支持 JavaScript 的 Web 浏览器中输入以下 URL 来查看 VNC 会话:http://jupiter.example.com:5801
持续 VNC 会话分为以下两类:
8.4.1 使用 vncserver
启动的 VNC 会话 #
此类型的持续 VNC 会话在服务器上启动。该会话和其上启动的所有应用程序运行时不考虑客户端连接,直到会话被终止。永久会话访问受到两种可用口令类型的保护:
授予完全访问权限的普通口令或
可选仅查看口令,授予非交互(仅查看)访问权限。
一个会话可一次具有两种类型的多个客户端连接。
vncserver
启动持续 VNC 会话 #打开外壳,确保以拥有 VNC 会话的用户身份登录。
如果用于 VNC 会话的网络接口受防火墙保护,则需要手动打开防火墙中您的会话所使用的端口。如果启动多个会话,还可以选择打开一个端口范围。有关如何配置防火墙的细节,请参见Book “Security and Hardening Guide”, Chapter 22 “Masquerading and Firewalls”。
vncserver
对显示器:1
使用端口5901
,对显示器:2
使用端口5902
,依次类推。对于永久会话,VNC 显示器和 X 显示器通常具有相同编号。要其他具有 1024x768 像素和颜色深度为 16 的会话,请输入以下命令:
vncserver -alwaysshared -geometry 1024x768 -depth 16
vncserver
命令会在您未指定时选取一个未使用的显示编号,并打印输出它的选择。有关更多选项,请参见man 1 vncserver
。
当您首次运行 vncserver
时,它会要求您输入一个口令,以获取会话的完全访问权限。如果需要,还可以提供口令用于会话的仅查看访问。
这里提供的口令还用作同一用户将来启动会话的口令。这些口令可以用 vncpasswd
命令更改。
确保使用长度够长的高强度口令(八个或更多字符)。不要共享这些口令。
要终止会话,请从 VNC 查看器中关闭运行于 VNC 会话内的桌面环境,像您关闭普通本地 X 会话那样关闭它。
如果希望手动终止会话,请在 VNC 服务器上打开外壳并确保您已作为拥有要终止的 VNC 会话的用户登录。运行以下命令来终止在显示器 :1
上运行的会话:vncserver -kill :1
8.4.1.1 配置持续 VNC 会话 #
通过编辑 $HOME/.vnc/xstartup
可以配置持续 VNC 会话。默认情况下,此外壳脚本会启动它启动时所处的同一个 GUI/窗口管理器。在 SUSE Linux Enterprise Desktop 中,此 GUI/窗口管理器为 GNOME 或 IceWM。如果要使用您选择的窗口管理器启动会话,请设置变量 WINDOWMANAGER
:
WINDOWMANAGER=gnome vncserver -geometry 1024x768 WINDOWMANAGER=icewm vncserver -geometry 1024x768
持续 VNC 会话在单个按用户配置中进行配置。由同一个用户启动的多个会话都使用相同的启动文件和口令文件。
8.4.2 使用 vncmanager
启动的 VNC 会话 #
启动
› › 。激活
。如果您打算在 Web 浏览器窗口中访问 VNC 会话,请激活
。如果需要,还可以选中
(例如,当网络接口配置为在外部区域中时)。如果有多个网络接口,请通过 将打开防火墙端口限制为特定的接口。单击
确认您的设置。如果不是所有需要的包都可使用,则需要批准安装缺少的包。
提示:重启动显示管理器YaST 对显示管理器设置进行了更改。您需要注销当前图形会话并重启动显示管理器,以使更改生效。
8.4.2.1 配置持续 VNC 会话 #
按过程 8.3 “启用持续 VNC 会话”中所述启用 VNC 会话管理后,便可以使用您喜欢的 VNC 查看器(例如 vncviewer
或 Remmina)正常连接到远程会话。此时将显示登录屏幕。登录后,您桌面环境的系统托盘中将出现“VNC”图标。单击该图标可打开 窗口。如果该图标未出现,或者您的桌面环境不支持图标放在系统托盘中,请手动运行 vncmanager-controller
。
有几个设置会影响 VNC 会话的行为:
这相当于一次性会话。其他用户将看不到此会话,它在您断开连接后即会终止。有关更多信息,请参考第 8.3 节 “一次性 VNC 会话”。
其他用户可以看见此类会话,它在您断开连接后仍保持运行。
您可以在此处指定持续会话的名称,以便在重新连接时可以轻松识别它。
任何人不必使用用户身份凭证登录即可访问会话。
需要使用有效的用户名和口令登录后才能访问会话。该选项会在
文本框中列出有效的用户名。防止多个用户同时加入该会话。
允许多个用户同时加入持续会话。适合用于远程演示或培训。
单击
进行确认。8.4.2.2 加入持续 VNC 会话 #
按第 8.4.2.1 节 “配置持续 VNC 会话”中所述设置持续 VNC 会话后,可通过 VNC 查看器加入它。当 VNC 客户端连接到服务器后,系统将提示您选择是要创建新会话还是加入现有会话:
当您单击现有会话的名称后,系统可能要求您输入登录身份凭证,具体取决于持续会话设置。
8.5 加密 VNC 通讯 #
如果 VNC 服务器设置正确,则 VNC 服务器与客户端之间的所有通讯都会被加密。身份验证在会话开始时进行;实际的数据传输在身份验证后开始。
无论是一次性还是持续 VNC 会话,安全性选项都通过 server_args
行中 /usr/bin/Xvnc
命令的 -securitytypes
参数配置。-securitytypes
参数会选择身份验证方法和加密。它的选项如下:
- None、TLSNone、X509None
无身份验证。
- VncAuth、TLSVnc、X509Vnc
身份验证使用自定义口令。
- Plain、TLSPlain、X509Plain
身份验证使用 PAM 来验证用户的口令。
- None、VncAuth、Plain
不加密。
- TLSNone、TLSVnc、TLSPlain
匿名 TLS 加密。对所有内容加密,但不校验远程主机。因此,您可以防护被动攻击者,但不能防御中间人攻击者。
- X509None、X509Vnc、X509Plain
使用证书进行 TLS 加密。如果使用自我签名证书,则在第一次连接时,系统将要求您校验证书。在以后的连接中,仅当证书有变动时,系统才会向您发出警告。因此,在第一次连接时,您可以防御中间人攻击之外的所有其他攻击(类似于使用典型的 SSH)。如果使用由证书颁发机构签名且与计算机名称匹配的证书,您的安全将得到全面保障(类似于使用典型的 HTTPS)。
提示:证书和密钥的路径如果使用基于 X509 的加密,需要通过
-X509Cert
和-X509Key
选项指定 X509 证书和密钥的路径。
如果您选择多种安全性类型(用逗号分隔),将会使用客户端和服务器都支持且允许的第一种安全性。如此,您便可在服务器上配置随机加密。如果您需要支持不支持加密的 VNC 客户端,此功能将十分有用。
在客户端上,您也可以指定允许的安全性类型,以防在您连接到已知启用了加密的服务器时遭到降级攻击(虽然在该情况下,我们的 vncviewer 会发出“连接未加密!”讯息来警告您)。
9 使用 RSync 复制文件 #
当今时代,用户通常都会有数台计算机:家用计算机和办公计算机、笔记本电脑、智能手机或平板电脑。因而,在多个设备之间保持文件和文档同步的任务就变得越发重要。
您在开始使用同步工具之前,应该先熟悉其特性和功能。请务必备份您的重要文件。
9.1 概念概述 #
对于要通过慢速网络连接同步大量数据的情况,Rsync 提供了可靠的方法来只传输文件中的更改。此方法不仅适用于文本文件,还适用于二进制文件。为了检测文件之间的差异,Rsync 将文件分为多个块,并计算它们的校验和。
检测更改对计算能力有一定的要求。因此,请确保两端的计算机均具有足够的资源,包括 RAM。
当需要定期传输大量只包含微小更改的数据时,Rsync 特别有用。进行备份时就常常用到该工具。Rsync 也非常适合用来镜像试验服务器,此类服务器将 Web 服务器的完整目录树储存到 DMZ 内的某台 Web 服务器中。
Rsync 并不是同步工具,虽然它的名字看上去有些像。Rsync 工具一次只能在一个方向复制数据。它不会也不能反向复制数据。如果您需要既能同步源又能同步目标的双向工具,请使用 Csync。
9.2 基本语法 #
Rsync 是一个命令行工具,基本语法如下:
rsync [OPTION] SOURCE [SOURCE]... DEST
您可以在任何本地或远程计算机上使用 Rsync,前提是您拥有相应的访问权限和写入权限。可以有多个 SOURCE 项。SOURCE 和 DEST 占位符可以是路径和/或 URL。
下面介绍一些最常用的 Rsync 选项:
-v
输出较详细的文本
-a
存档模式;以递归方式复制文件并保留时间戳、用户/组所有权、文件权限和符号链接
-z
压缩传输的数据
使用 Rsync 时,要特别注意尾部斜杠。目录后面的尾部斜杠表示目录的内容。没有尾部斜杠表示目录本身。
9.3 在本地复制文件和目录 #
下面的说明假设当前用户拥有 /var/backup
目录的写入许可权限。要将单个文件从计算机上的一个目录复制到另一个路径,请使用以下命令:
tux >
rsync
-avz backup.tar.xz /var/backup/
文件 backup.tar.xz
会复制到 /var/backup/
,绝对路径是 /var/backup/backup.tar.xz
。
请勿忘记在 /var/backup/
目录后面加上尾部斜杠!如果不插入斜杠,文件 backup.tar.xz
会复制到 /var/backup
(文件)中,而不是 /var/backup/
目录中!
复制目录与复制单个文件相似。下面的示例将目录 tux/
及其内容复制到 /var/backup/
目录中:
tux >
rsync
-avz tux /var/backup/
在绝对路径 /var/backup/tux/
中可找到副本。
9.4 远程复制文件和目录 #
两台计算机上都需要有 Rsync 工具。要从远程目录复制文件或将文件复制到远程目录,需要提供 IP 地址或域名。如果本地计算机和远程计算机上当前的用户名相同,则可以不指定用户名。
要使用相同的用户(在本地和远程主机上)将文件 file.tar.xz
从本地主机复制到远程主机 192.168.1.1
,请使用以下命令:
tux >
rsync
-avz file.tar.xz tux@192.168.1.1:
根据您的个人偏好,也可以使用下面的命令,它们的作用相同:
tux >
rsync
-avz file.tar.xz 192.168.1.1:~tux >
rsync
-avz file.tar.xz 192.168.1.1:/home/tux
在使用标准配置的所有情况下,系统会提示您输入远程用户的通行口令。此命令会将 file.tar.xz
复制到用户 tux
的主目录(通常为 /home/tux
)。
远程复制目录与在本地复制目录相似。下面的示例将目录 tux/
及其内容复制到 192.168.1.1
主机上的远程目录 /var/backup/
:
tux >
rsync
-avz tux 192.168.1.1:/var/backup/
假设您在主机 192.168.1.1
上拥有写入许可权限,便可在绝对路径 /var/backup/tux
中找到副本。
9.5 配置和使用 Rsync 服务器 #
Rsync 可作为在用于传入连接的默认端口 873 上列出的守护程序 (rsyncd
) 运行。此守护程序可以接收“复制目标”。
下面的说明介绍如何在 jupiter
上创建具有备份目标的 Rsync 服务器。此目标可用于储存您的备份。要创建 Rsync 服务器,请执行以下操作:
在 jupiter 上,创建用于储存您所有备份文件的目录。在此示例中,我们使用
/var/backup
:root #
mkdir
/var/backup指定所有权。在此示例中,该目录为
用户
组中的用户tux
所拥有:root #
chown
tux.users /var/backup配置 rsyncd 守护程序。
我们将配置文件分割成一个主文件,和一些用于存放您的备份目标的“模块”。如此,以后便可更轻松地添加其他目标。全局值可以储存在
/etc/rsyncd.d/*.inc
文件中,而模块放置在etc/rsyncd.d/*.conf
文件中:创建目录
/etc/rsyncd.d/
:root #
mkdir
/etc/rsyncd.d/在主配置文件
/etc/rsyncd.conf
中,添加以下几行:# rsyncd.conf main configuration file log file = /var/log/rsync.log pid file = /var/lock/rsync.lock &merge /etc/rsyncd.d 1 &include /etc/rsyncd.d 2
在文件
/etc/rsyncd.d/backup.conf
中通过以下几行创建您的模块(您的备份目标):# backup.conf: backup module [backup] 1 uid = tux 2 gid = users 2 path = /var/backup 3 auth users = tux 4 secrets file = /etc/rsyncd.secrets 5 comment = Our backup target
创建包含以下内容的
/etc/rsyncd.secrets
文件,并替换 PASSPHRASE:# user:passwd tux:PASSPHRASE
确保该文件只有
root
用户可读:root #
chmod
0600 /etc/rsyncd.secrets
通过以下命令启动并启用 rsyncd 守护程序:
root #
systemctl
enable rsyncdroot #
systemctl
start rsyncd测试是否可访问 Rsync 服务器:
tux >
rsync
jupiter::您应该会看到类似如下的响应:
backup Our backup target
若非如此,请检查您的配置文件、防火墙和网络设置。
上述步骤创建了 Rsync 服务器,现在可以使用它来储存备份。下例还创建了一个列出所有连接的日志文件。此文件储存在 /var/log/rsyncd.log
中。如果您要对传输进行调试,那么它非常有用。
要列出备份目标的内容,请使用以下命令:
tux >
rsync -avz jupiter::backup
此命令会列出服务器上 /var/backup
目录中存在的所有文件。此请求还记录在日志文件 /var/log/rsyncd.log
中。要开始实际传输,请提供源目录。使用 .
表示当前目录。例如,下面的命令会将当前目录复制到 Rsync 备份服务器:
tux >
rsync -avz . jupiter::backup
默认情况下,Rsync 不会在运行时删除文件和目录。要允许删除,必须另外指定选项 --delete
。为保证不删除任何较新的文件,可转而使用选项 --update
。必须手动解决所有冲突。
9.6 更多信息 #
- Csync
双向文件同步程序,请参见 https://www.csync.org/。
- RSnapshot
创建增量备份,请参见 http://rsnapshot.org。
- Unison
与 CSync 类似的文件同步程序,但具有图形界面,请参见 http://www.seas.upenn.edu/~bcpierce/unison/。
- Rear
一个灾难恢复框架,请参见 https://www.suse.com/documentation/sle-ha/ 上 SUSE Linux Enterprise High Availability Extension 的《管理指南》。
第 II 部分 引导 Linux 系统 #
- 10 引导过程简介
引导 Linux 系统涉及不同组件和任务。固件和硬件初始化过程(取决于计算机的体系结构)完成后,系统将通过引导加载程序 GRUB 2 启动内核。在此之后,引导进程完全由操作系统控制,并由
systemd
处理。systemd
会提供一组“目标”,用于引导与日常使用、维护或紧急情况相关的配置。- 11 UEFI(统一可扩展固件接口)
UEFI(统一可扩展固件接口)是用于系统硬件自带的固件、系统所有的硬件组件以及操作系统之间的接口。
- 12 引导加载程序 GRUB 2
本章介绍如何配置 SUSE® Linux Enterprise Desktop 中使用的引导加载程序 GRUB 2。GRUB 是传统 GRUB 引导加载程序(现在称作“GRUB Legacy”)的后继产品。从 SUSE® Linux Enterprise Desktop 12 版开始,就已使用 GRUB 2 作为默认的引导加载程序。产品中提供了一个 YaST 模块来配置最重要的设置。第 10 章 “引导过程简介” 中将引导过程作为一个整体进行了介绍。有关 UEFI 计算机的安全引导支持的细节,请参见第 11 章 “UEFI(统一可扩展固件接口)”。
- 13
systemd
守护程序 systemd
程序是进程 ID 为 1 的进程。它负责以所需的方式初始化系统。systemd
由内核直接启动,信号 9(该信号通常会终止进程)对它不起作用。所有其他程序都由 systemd 直接启动,或由它的其中一个子进程启动。
10 引导过程简介 #
引导 Linux 系统涉及不同组件和任务。固件和硬件初始化过程(取决于计算机的体系结构)完成后,系统将通过引导加载程序 GRUB 2 启动内核。在此之后,引导进程完全由操作系统控制,并由 systemd
处理。systemd
会提供一组“目标”,用于引导与日常使用、维护或紧急情况相关的配置。
10.1 术语 #
本章使用的术语可能存在歧义。为了理解本章中术语的用法,请阅读以下定义:
init
有两个不同的进程通常命名为 “init”:
用于装入根文件系统的
initramfs
进程从实际根文件系统执行且用于启动其他所有进程的操作系统进程
在这两种情况下,
systemd
程序都会处理此任务。首先会从initramfs
执行此进程,以装入根文件系统。装入成功后,将从根文件系统以初始进程的形式重新执行此进程。为了避免混淆这两个systemd
进程,我们将第一个进程称为 init on initramfs,将第二个进程称为 systemd。-
initrd
/initramfs
initrd
(初始 RAM 磁盘)是一个映像文件,内含内核所装载的并且作为临时根文件系统从/dev/ram
装入的根文件系统映像。装入此文件系统需要使用文件系统驱动程序。从内核 2.6.13 开始,initrd 已由
initramfs
(初始 RAM 文件系统)取代,后者无需文件系统驱动程序即可装入。SUSE Linux Enterprise Desktop 只使用initramfs
。但是,由于initramfs
作为/boot/initrd
储存,因此通常将其称为“initrd”。本章只使用名称initramfs
。
10.2 Linux 引导进程 #
Linux 引导进程包括多个阶段,每个阶段由一个不同组件来代表:
10.2.1 初始化和引导加载程序阶段 #
在初始化阶段,将设置计算机的硬件并准备好设备。此过程根据硬件体系结构的不同有很大的差别。
SUSE Linux Enterprise Desktop 在所有体系结构中都使用引导加载程序 GRUB 2。根据体系结构和固件,启动 GRUB 2 引导加载程序的过程可能包括多个步骤。引导加载程序的用途是装载内核以及基于 RAM 的初始文件系统 (initramfs)。有关 GRUB 2 的详细信息,请参见第 12 章 “引导加载程序 GRUB 2”。
10.2.1.1 AArch64 和 AMD64/Intel 64 上的初始化和引导加载程序阶段 #
在打开计算机之后,BIOS 或 UEFI 将初始化屏幕和键盘并测试主内存。直到这一阶段,计算机不访问任何大容量储存媒体。随后,将从 CMOS 值装载有关当前日期、时间和最重要的外设的信息。识别引导媒体及其几何尺寸之后,系统控制权将从 BIOS/UEFI 转到引导加载程序。
在装配传统 BIOS 的计算机上,只能装载引导磁盘的第一个 512 字节物理数据扇区(主引导记录,MBR)中的代码。只有极少量的 GRUB 2 代码能够装入 MBR。引导加载程序的唯一作用就是从 MBR 与第一个分区(MBR 分区表)之间的间隙处,或是从 BIOS 引导分区(GPT 分区表)装载包含文件系统驱动程序的 GRUB 2 核心映像。此映像包含文件系统驱动程序,因此能够访问根文件系统中的 /boot
。/boot
包含 GRUB 2 核心的附加模块以及内核和 initramfs 映像。获取此分区的访问权限后,GRUB 2 会将内核和 initramfs 映像装载到内存中,并将控制权交接到内核。
从包含已加密分区 /boot
的加密文件系统引导 BIOS 系统时,需要输入解密口令两次。GRUB 2 使用第一次输入的口令来解密 /boot
,systemd
使用第二次输入的口令来装载加密的卷。
在装配 UEFI 的计算机上,引导过程比装配传统 BIOS 的计算机要简单得多。固件能够读取包含 GPT 分区表的磁盘的 FAT 格式化系统分区。此 EFI 系统分区(在运行的系统中装载为 /boot/efi
)可提供足够的空间用于托管由固件直接装载和执行的完备 GRUB 2。
如果 BIOS/UEFI 支持网络引导,则也可以配置提供引导加载程序的引导服务器。然后,可以通过 PXE 引导系统。BIOS/UEFI 充当引导加载程序。它会从引导服务器获取引导映像,然后启动系统。这完全不依赖本地硬盘。
10.2.1.2 IBM IBM Z 上的初始化和引导加载程序阶段 #
在 IBM IBM Z 上,必须通过名为 zipl
(z 初始程序装载)的引导加载程序初始化引导进程。尽管 zipl
支持读取不同的文件系统,但它不支持 SLE 默认文件系统 (Btrfs) 或者从快照引导。因此,SUSE Linux Enterprise Desktop 使用两阶段的引导过程来确保引导时完全支持 Btrfs:
zipl
从 ext2 格式化分区/boot/zipl
引导。此分区包含一个极简的内核,以及一个装载到内存中的 initramfs。initramfs 包含 Btrfs 驱动程序(及其他组件)和引导加载程序 GRUB 2。内核是使用参数initgrub
(告知要启动 GRUB 2)启动的。内核会装入根文件系统,使
/boot
可访问。现在,将从 initramfs 启动 GRUB 2。GRUB 2 从/boot/grub2/grub.cfg
读取其配置,并从/boot
装载最终的内核和 initramfs。现在,将通过 Kexec 装载新内核。
10.2.2 内核阶段 #
引导加载程序转交系统控制权后,所有体系结构中的引导过程都是相同的。引导加载程序会将内核和基于 RAM 的初始文件系统 (initramfs
) 都装载到内存中,而内核将接管控制权。
内核设立内存管理并检测 CPU 类型及其功能后,将初始化硬件,并从内存中装入使用 initramfs
装载的临时根文件系统。
10.2.2.1 initramfs
文件 #
initramfs
(初始 RAM 文件系统)是一个小型 cpio 存档,可由内核装载到 RAM 磁盘中。该文件位于 /boot/initrd
中。可以使用名为 dracut
的工具创建该文件,有关细节,请参见 man 8 dracut
。
initramfs
提供了一个极简的 Linux 环境,可用于在装入实际根文件系统之前执行程序。这个最小的 Linux 环境由 BIOS 或 UEFI 例程载入内存,而且除了需要足够的内存外没有特定的硬件要求。initramfs
存档必须始终提供一个名为 init
的可执行文件,该文件执行根文件系统上的 systemd
守护程序,使引导进程得以继续。
在能够装入 root 文件系统并启动操作系统之前,内核需要相应的驱动程序来访问 root 文件系统所在的设备。 这些驱动程序可能包括用于特定类型硬盘的特殊驱动程序,甚至还可能包括访问网络文件系统所需的网络驱动程序。根文件系统所需的模块由 init
on initramfs
装载。装载模块后,udev
将为 initramfs
提供所需的设备。在引导过程的后面,更改 root 文件系统之后需要重新生成设备。可以使用 systemd
单元 systemd-udev-trigger.service
来实现此目的。
10.2.2.1.1 重新生成 initramfs #
由于 initramfs
包含多个驱动程序,因此,每当其中某个驱动程序有新版本发布时,都需要更新 initramfs。在安装包含驱动程序更新的包时可以自动完成这种更新。YaST 或 zypper 通过显示用于生成 initramfs
的命令的输出来告知此状况。但在某些情况下,需要手动重新生成 initramfs
:
- 由于更换硬件而需添加驱动程序
如果需要更换硬件(例如硬盘),并且引导时此硬件需要内核中的不同驱动程序,则您必须更新
initramfs
文件。打开或创建
/etc/dracut.conf.d/10-驱动程序.conf
并添加以下行(请注意前导空格):force_drivers+=" DRIVER1"
用驱动程序的模块名称替换 DRIVER1。如果您需要添加多个驱动程序,请将其全部列出并以空格分隔:
force_drivers+=" DRIVER1 DRIVER2"
- 将系统目录移到 RAID 或 LVM
每当您要将正在运行的系统中的交换文件或系统目录(例如
/usr
)移到 RAID 或逻辑卷时,都需要创建一个包含软件 RAID 或 LVM 驱动程序支持的initramfs
。为此,请在
/etc/fstab
中创建相关的项,并装入新项(例如,使用mount -a
和/或swapon -a
)。- 将磁盘添加到包含根文件系统的 LVM 组或 Btrfs RAID
每当您要在包含根文件系统的逻辑卷组或者 Btrfs RAID 中添加(或去除)磁盘时,都需要创建一个支持扩容的卷的
initramfs
。请按照过程 10.1 “生成 initramfs”中的指导操作。- 更改内核变量
如果您在
sysctl
界面中通过编辑相关文件(/etc/sysctl.conf
或/etc/sysctl.d/*.conf
)更改了内核变量的值,系统下次重引导时,这项更改将会丢失。即使您在运行时使用sysctl --system
装载这些值,更改也不会保存到 initramfs 文件中。您需要根据过程 10.1 “生成 initramfs”中所述更新该文件。
请注意,以下过程中的所有命令都需要以 root
用户身份执行。
运行以下命令生成新的
initramfs
文件dracut MY_INITRAMFS
请将 MY_INITRAMFS 替换为所选的文件名。新的
initramfs
将创建为/boot/MY_INITRAMFS
。或者运行
dracut -f
。这会重写当前使用的现有文件。(如果在上一步中运行了
dracut -f
,请跳过此步骤。)为上一步中创建的initramfs
文件创建链接:(cd /boot && ln -sf MY_INITRAMFS initrd)
在 IBM IBM Z 体系结构中,另外还需运行
grub2-install
。
10.2.3 init on initramfs 阶段 #
由内核从 initramfs
装入的临时根文件系统包含可执行文件 systemd
(下面称作 init
on initramfs
,另请参见第 10.1 节 “术语”)。此程序执行装入正确根文件系统所需的全部操作。它为所需的文件系统提供内核功能,并为使用 udev
的大量储存控制器提供设备驱动程序。
initramfs
上的 init
的主要用途是准备真实 root 文件系统的装入和访问。根据您的系统配置的不同,initramfs
上的 init
负责以下任务。
- 装载内核模块
根据硬件配置的不同,可能需要一些特殊的驱动程序来访问计算机的硬件组件(最重要的组件是硬盘)。要访问最终的 root 文件系统,内核需要装载适当的文件系统驱动程序。
- 提供块特殊文件
内核根据装载的模块生成设备事件。
udev
会处理这些事件并在 RAM 文件系统的/dev
中生成所需的特殊块文件。没有这些特殊文件,文件系统和其他设备将不可访问。- 管理 RAID 和 LVM 设置
如果将系统配置为在 RAID 或 LVM 下保存根文件文件系统,则
initramfs
上的init
将设置 LVM 或 RAID 以支持以后对根文件系统的访问。- 管理网络配置
如果将系统配置为使用通过网络装入的 root 文件系统(通过 NFS 装入),则
init
必须确保装载了正确的网络驱动程序,并确保将其设置为支持访问 root 文件系统。如果文件系统驻留在一个联网的块设备(如 iSCSI 或 SAN)上,则与储存服务器的连接也由
initramfs
上的init
设置。SUSE Linux Enterprise Desktop 支持在主要目标不可用的情况下从次要 iSCSI 目标引导。
如果根文件系统无法从引导环境中装入,则必须先对其进行检查和修复,才能继续引导。如果文件系统为 Ext3 和 Ext4,文件系统检查程序将会自动启动。如果是 XFS 和 Btrfs 文件系统,则不会自动开始修复过程,而是向用户显示有关可用于修复文件系统的选项的信息。成功修复文件系统后,退出引导环境将会使系统重试装入根文件系统。如果装入成功,将正常继续引导。
10.2.3.1 安装过程中的 init on initramfs 阶段 #
如果在安装过程的初始引导阶段调用 init
on initramfs
,它要执行的任务将与上述任务不同。请注意,安装系统也不会从 initramfs
启动 systemd
— 这些任务由 linuxrc
执行。
- 查找安装媒体
当您启动安装进程时,计算机会装载一个安装内核以及一个包含 YaST 安装程序的特殊
init
。YaST 安装程序正在 RAM 文件系统中运行,它需要知道安装媒体的位置,才能访问安装媒体以安装操作系统。- 启动硬件识别并装载适当的内核模块
如第 10.2.2.1 节 “
initramfs
文件”中所述,引导过程从最少的一组驱动程序(可在大多数硬件配置中使用)开始。在 AArch64、POWER 和 AMD64/Intel 64 计算机上,linuxrc
会启动初始硬件扫描进程,以确定适合您的硬件配置的驱动程序集。在 IBM IBM Z 上,需要提供驱动程序及其参数的列表(例如,通过 linuxrc 或 parmfile 提供)。这些驱动程序用于生成引导系统所需的自定义
initramfs
。如果引导时不需要这些模块,但冷插拔时需要,您可以使用systemd
装载这些模块。有关详细信息,请参见第 13.6.4 节 “装载内核模块”。- 装载安装系统
系统在正确识别硬件后会装载相应的驱动程序。
udev
程序会创建特殊的设备文件,linuxrc
使用 YaST 安装程序启动安装系统。- 启动 YaST
最后,
linuxrc
启动 YaST,后者则启动包安装和系统配置。
10.2.4 systemd 阶段 #
找到“实际的”根文件系统后,对其进行错误检查并装入。如果装入成功,系统会清理 initramfs
并执行根文件系统上的 systemd
守护程序。systemd
是 Linux 的系统和服务管理器。它是作为 PID 1 启动的父进程,充当用于启动和维护用户空间服务的 init 系统。有关详细信息,请参见第 13 章 “systemd
守护程序”。
11 UEFI(统一可扩展固件接口) #
UEFI(统一可扩展固件接口)是用于系统硬件自带的固件、系统所有的硬件组件以及操作系统之间的接口。
UEFI 在 PC 系统上的应用范围越来越广,因此正在逐渐替代传统的 PC-BIOS。例如,UEFI 能够很好地支持 64 位系统,提供安全的引导(“安全引导”,要求固件为 2.3.1c 或以上版本)。安全引导是其最为重要的特性之一。最后,借助 UEFI,标准固件将能够用于所有 x86 平台。
除此之外,UEFI 还具有以下优点:
从带有 GUID 分区表 (GPT) 的大磁盘(超过 2 TiB)引导。
独立于 CPU 的架构和驱动程序。
带有网络功能的灵活的预操作系统环境。
通过 PC-BIOS 式仿真支持引导老式操作系统的 CSM(兼容支持模块)。
有关详细信息,请参见 http://en.wikipedia.org/wiki/Unified_Extensible_Firmware_Interface。以下小节仅针对部分功能如何在 SUSE Linux Enterprise Desktop 中实现而列举一些提示,并不代表 UEFI 的整体概述。
11.1 安全引导 #
在 UEFI 领域中,要想保障引导程序的安全,需要建立一个信任链。“平台”是此信任链的根;在 SUSE Linux Enterprise Desktop 环境中,可将主板和板载固件视为“平台”。换句话说,它就是硬件供应商,信任链从硬件供应商流向组件制造商、OS 供应商等。
系统通过公共密钥加密法表示信任。硬件供应商将所谓的“平台密钥 (PK)”放入固件中,代表可信根。操作系统供应商与其他方将其密钥与“平台密钥”签署在一起,以此记录他们之间的信任关系。
最后,除非这些“可信的”密钥之一(即 OS 引导加载程序、位于一些 PCI Express 卡的闪存上或磁盘上的一些驱动程序,或者更新的固件本身)签署了代码,否则要求固件不得执行该代码,从而建立安全保障。
要使用安全引导,您需要用固件信任的密钥对您的 OS 加载程序签名,并且需要 OS 加载程序校验其加载的内核是否可信。
可以将密钥交换密钥 (KEK) 添加到 UEFI 密钥数据库中。这样,其他证书只要签署了 PK 的私用部分,即可由您使用。
11.1.1 在 SUSE Linux Enterprise Desktop 上实施 #
默认情况下安装微软的密钥交换密钥 (KEK)。
UEFI/x86_64 安装中默认会启用安全引导功能。您可在
对话框的 选项卡中找到 选项。该选项支持在固件中的安全引导已激活时引导,同时也支持在安全引导已停用时引导。“安全引导”特性要求 GUID 分区表 (GPT) 使用主引导记录 (MBR) 替代旧的分区。如果安装期间 YaST 检测到 EFI 模式,则会设法创建 GPT 分区。UEFI 预期会在 FAT 格式的 EFI 系统分区(ESP) 上查找到 EFI 程序。
要支持 UEFI 安全引导,需要有引导加载程序,且固件认可其数字签名是可信密钥。该密钥需要先天为固件所信任(无需任何手动干预)。
有两种办法可以实现。一种是与硬件供应商合作,让其签署 SUSE 密钥,然后 SUSE 会使用该 SUSE 密钥签署引导加载程序;另一种是通过微软的 Windows 徽标认证计划使引导加载程序获得认证,并使微软认可 SUSE 签名密钥(也就是让加载程序使用他们的 KEK 签名)。至此,SUSE 使引导加载程序获得了 UEFI 签名服务(在此情况下为 Microsoft)的签名。
SUSE 在实施层使用默认将会安装的 shim
加载程序。这是一种可以避免法律纠纷的智能解决方案,能够大幅简化认证和签名步骤。shim
加载程序的任务是装载 GRUB 2 等引导加载程序并对其进行校验,之后,此引导加载程序将装载仅由一个 SUSE 密钥签名的内核。SUSE 从全新安装的 SLE11 SP3 开始提供此功能,并要求启用 UEFI 安全引导。
可信用户分为以下两类:
首先是持有密钥的用户。平台密钥 (PK) 几乎允许所有操作。密钥交换密钥 (KEK) 的许可范围与 PK 一致,但不能更改 PK。
其次是能够以物理方式访问机器的任何用户。具有物理访问权限的用户可以重引导机器并对 UEFI 进行配置。
UEFI 提供下列两类变量以满足这些用户的需求:
第一类变量即所谓的“已验证的变量”,它们可从引导过程(所谓的“引导服务环境”)和正在运行的操作系统中更新。仅当对变量新值签名的密钥是用于对变量旧值签名的相同密钥时,才能进行更新。而且,您只能向这类变量追加或将其更改为序列号更高的数值。
第二类变量即所谓的“仅供引导服务使用的变量”。引导进程中运行的任何代码都可以获取这些变量。在结束引导进程并准备启动 OS 的时间间隔内,引导加载程序必须调用
ExitBootServices
呼叫。此后将无法获取这些变量,OS 也无法接触到这些变量。
各类 UEFI 密钥列表属于第一类,因为该类变量除了允许联机更新外,还允许添加密钥、驱动程序、固件指纹以及将其列入黑名单。第二类变量即“仅供引导服务使用的变量”。该类变量有助于以安全且支持开源的方式实施安全引导,因此符合 GPLv3 要求。
SUSE 首先启动 shim
,它是一个小而简单的 EFI 引导加载程序,由 SUSE 和 Microsoft 签名。
这样一来,shim
即可加载并执行。
shim
随后继续验证其想要加载的引导加载程序是否可信。默认情况下,shim
会使用其主体中所嵌入的独立的 SUSE 证书。此外,shim
还允许“登记”其他密钥,用于覆盖默认的 SUSE 密钥。下文将这些密钥称为“机器拥有者密钥”或缩写为 MOK。
接下来,引导加载程序会验证内核,然后加以引导。该内核将在模块上执行同样的操作。
11.1.2 MOK(机器拥有者密钥) #
如果用户(“机器拥有者”)想要更换引导进程的任何组件,则会用到“机器拥有者密钥 (MOK)”。他们可以借助 mokutils
工具对组件签名及管理 MOK。
当加载 shim
时,登记进程便会开始重引导计算机并中断引导进程(例如按下某个键)。shim
随后转入登记模式,允许用户使用引导分区上的文件的密钥替换默认的 SUSE 密钥。如果用户选择这样做,则 shim
将计算该文件的哈希,并将计算结果置入“仅供引导服务”的变量中。这样,shim
可以检测到文件除引导服务之外出现的任何更改,从而避免篡改用户核准的 MOK 列表。
上述各步都在引导时发生,此时仅执行已经校验的代码。因此,只有控制台上所示的一位用户可以使用机器拥有者的一组密钥。它不可能是远程访问 OS 的恶意程序或骇客,因为骇客或恶意程序只能更改文件,但无法更改存储在“仅供引导服务使用”的变量中的哈希。
引导加载程序经 shim
装载并校验后,如果需要校验内核以免校验代码重复,则会回调 shim
。为此,Shim
将使用同一份 MOK 列表并通知引导加载程序能否加载内核。
这样,您就可以安装自己的内核或引导加载程序。您只需要安装一组新的密钥,并在首次重引导期间以物理方式呈现,从而予以授权。由于 MOK 是一个列表而不是单独一个 MOK,因此您可以让 shim
信任来自多个供应商的密钥,从而允许从引导加载程序进行双重或多重引导。
11.1.3 引导自定义内核 #
以下内容基于 http://en.opensuse.org/openSUSE:UEFI#Booting_a_custom_kernel。
安全引导不会阻止您使用自行编译的内核。您必须使用自己的证书在该内核上签名,并让固件或 MOK 得以识别该证书。
创建一个自定义的 X.509 密钥以及用于签名的证书:
openssl req -new -x509 -newkey rsa:2048 -keyout key.asc \ -out cert.pem -nodes -days 666 -subj "/CN=$USER/"
有关创建证书的详细信息,请参见 http://en.opensuse.org/openSUSE:UEFI_Image_File_Sign_Tools#Create_Your_Own_Certificate。
将密钥和证书打包成 PKCS#12 结构:
tux >
openssl pkcs12 -export -inkey key.asc -in cert.pem \ -name kernel_cert -out cert.p12生成用于
pesign
的 NSS 数据库:tux >
certutil -d . -N将 PKCS#12 中包含的密钥和证书导入 NSS 数据库:
tux >
pk12util -d . -i cert.p12使用
pesign
将新签名“赋予”内核:tux >
pesign -n . -c kernel_cert -i arch/x86/boot/bzImage \ -o vmlinuz.signed -s列出内核映像上的签名:
tux >
pesign -n . -S -i vmlinuz.signed此时,您可以照常在
/boot
中安装内核。由于内核现有一个自定义的签名,因此需要将用于签名的证书导入 UEFI 固件或 MOK 中。将证书转为 DER 格式,以供导入固件或 MOK:
tux >
openssl x509 -in cert.pem -outform der -out cert.der将证书复制到 ESP 以简化访问:
tux >
sudo
cp cert.der /boot/efi/使用
mokutil
自动启动 MOK 列表。将证书导入到 MOK 中:
tux >
mokutil --root-pw --import cert.der--root-pw
选项可让root
用户直接使用。检查准备注册的证书列表:
tux >
mokutil --list-new重引导系统;
shim
应该会起动 MokManager。您需要输入root
口令以确认将证书导入到 MOK 列表中。检查新导入的密钥以前是否注册过:
tux >
mokutil --list-enrolled
此外,若要手动启动 MOK,也可以采用这一过程:
重引导
在 GRUB 2 菜单中,按
c
键。类型:
chainloader $efibootdir/MokManager.efi boot
选择
。导航至
cert.der
文件并按 Enter。按照指导登记密钥。正常情况下应按“
0
”,然后按“y
”予以确认。除此之外,固件菜单也可能提供了多种向“签名数据库”中添加新密钥的方式。
11.1.4 使用非内置驱动程序 #
在启用安全引导的情况下,不支持在安装过程中添加非内置驱动程序(即,不是 SUSE Linux Enterprise Desktop 自带的驱动程序)。用于 SolidDriver/PLDP 的签名密钥默认不受信任。
您可以通过两种不同的方式,在启用安全引导的情况下于安装期间安装第三方驱动程序。在这两种情况下,都要:
在安装前,通过固件或系统管理工具将所需密钥添加到固件数据库中。此选项取决于您当前使用的具体硬件。请咨询您的硬件供应商了解详细信息。
使用 https://drivers.suse.com/ 上或硬件供应商提供的可引导驱动程序 ISO,在首次引导时将所需密钥登记到 MOK 列表中。
要使用可引导驱动程序 ISO 将驱动程序密钥登记到 MOK 列表中,请执行以下步骤:
将上文所述 ISO 映像刻录到空 CD/DVD 媒体中。
使用新的 CD/DVD 媒体开始安装,并准备好标准的安装媒体或网络安装服务器的 URL。
如果您要进行网络安装,请在引导命令行上使用
install=
选项输入网络安装源的 URL。如果您是从光学媒体安装,安装程序会先从驱动程序包引导,然后要求插入产品的第一张安装光盘。
安装时将会使用包含经过更新的驱动程序的 initrd。
有关详细信息,请参见 https://drivers.suse.com/doc/Usage/Secure_Boot_Certificate.html。
11.1.5 功能和限制 #
以安全引导模式引导时,可以使用以下功能:
安装到 UEFI 默认的引导加载程序位置,这是为了保留或恢复 EFI 引导项而采用的机制。
通过 UEFI 重引导。
如果没有其他可回退到的旧版 BIOS,Xen 超级管理程序将使用 UEFI 引导。
支持 UEFI IPv6 PXE 引导。
UEFI 视频模式支持,内核可以从 UEFI 检索视频模式,以使用相同的参数配置 KMS 模式。
UEFI 支持从 USB 设备引导。
以安全引导模式引导时,存在以下限制:
为确保他人无法轻易绕过安全引导,系统在安全引导下运行时会禁用部分内核特性。
引导加载程序、内核以及内核模块必须经过签名。
Kexec 和 Kdump 处于禁用状态。
休眠(挂起到磁盘)处于禁用状态。
无法访问
/dev/kmem
和/dev/mem
,连 root 用户也不例外。无法访问 I/O 端口,连 root 用户也不例外。所有 X11 图形驱动程序必须使用内核驱动程序。
无法通过 sysfs 访问 PCI BAR。
无法使用 ACPI 中的
custom_method
。无法使用 asus-wmi 模块的 debugfs。
acpi_rsdp
参数对内核没有任何影响。
11.2 更多信息 #
http://www.uefi.org — UEFI 主页,其中列出了最新的 UEFI 规范。
由 Olaf Kirch 与 Vojtěch Pavlík 撰写的博文(上述章节内容主要取材于这些博文):
http://en.opensuse.org/openSUSE:UEFI — UEFI 与 openSUSE。
12 引导加载程序 GRUB 2 #
本章介绍如何配置 SUSE® Linux Enterprise Desktop 中使用的引导加载程序 GRUB 2。GRUB 是传统 GRUB 引导加载程序(现在称作“GRUB Legacy”)的后继产品。从 SUSE® Linux Enterprise Desktop 12 版开始,就已使用 GRUB 2 作为默认的引导加载程序。产品中提供了一个 YaST 模块来配置最重要的设置。第 10 章 “引导过程简介” 中将引导过程作为一个整体进行了介绍。有关 UEFI 计算机的安全引导支持的细节,请参见第 11 章 “UEFI(统一可扩展固件接口)”。
12.1 GRUB Legacy 与 GRUB 2 之间的主要差异 #
配置储存在不同的文件中。
支持更多的文件系统(例如 Btrfs)。
可以直接读取 LVM 或 RAID 设备上储存的文件。
用户界面可翻译,并可以改变主题。
包含一个用于装载模块的机制,以支持更多功能,例如文件系统等。
自动搜索和生成其他内核与操作系统(例如 Windows)的引导项。
包含一个类似于 Bash 的精简控制台。
12.2 配置文件结构 #
GRUB 2 的配置基于以下文件:
/boot/grub2/grub.cfg
此文件包含 GRUB 2 菜单项的配置。它替代了 GRUB Legacy 中的
menu.lst
。不要编辑grub.cfg
— 它是由命令grub2-mkconfig -o /boot/grub2/grub.cfg
自动生成的。/boot/grub2/custom.cfg
此可选文件在引导时由
grub.cfg
直接检索,可用于向引导菜单添加自定义项。从 SUSE Linux Enterprise Desktop 开始,使用grub-once
时也将分析这些项目。/etc/default/grub
此文件控制 GRUB 2 的用户设置,通常包含背景和主题等其他环境设置。
/etc/grub.d/
下的脚本在执行
grub2-mkconfig -o /boot/grub2/grub.cfg
命令期间,将读取此目录中的脚本。主配置文件/boot/grub/grub.cfg
中集成了这些脚本的说明。/etc/sysconfig/bootloader
此配置文件保存一些基本设置,例如引导加载程序类型,或者是否要启用 UEFI 安全引导支持。
/boot/grub2/x86_64-efi
、/boot/grub2/power-ieee1275
、/boot/grub2/s390x
这些配置文件包含特定于体系结构的选项。
可以通过多种方式控制 GRUB 2。可以在图形菜单(启动屏幕)中选择现有配置的引导项。配置从文件 /boot/grub2/grub.cfg
装载,而该文件是基于其他配置文件编译的(参见下文)。所有 GRUB 2 配置文件都被视为系统文件,编辑这些配置文件需要拥有 root
特权。
手动编辑 GRUB 2 配置文件后,需要运行 grub2-mkconfig -o /boot/grub2/grub.cfg
以激活更改。但使用 YaST 更改配置时就不需要如此,因为 YaST 会自动运行 此命令。
12.2.1 文件 /boot/grub2/grub.cfg
#
带有引导菜单的图形启动屏幕内容由 GRUB 2 配置文件 /boot/grub2/grub.cfg
控制,该文件包含有关可以通过菜单引导的所有分区或操作系统的信息。
系统每次引导时,GRUB 2 会直接从文件系统装载菜单文件。因此,在更改配置文件后不需要重新安装 GRUB 2。安装或去除内核后,系统会自动重构建 grub.cfg
。
grub.cfg
是运行 grub2-mkconfig -o /boot/grub2/grub.cfg
命令时,基于文件 /etc/default/grub
以及 /etc/grub.d/
目录中的脚本编译的。因此,切勿手动编辑该文件,而应该编辑相关的源文件,或者根据第 12.3 节 “使用 YaST 配置引导加载程序”中所述,使用 YaST 模块来修改配置。
12.2.2 文件 /etc/default/grub
#
此文件包含 GRUB 2 的其他常规选项,例如,显示菜单的时间,或者要引导的默认操作系统。要列出所有可用选项,请查看以下命令的输出:
tux >
grep "export GRUB_DEFAULT" -A50 /usr/sbin/grub2-mkconfig | grep GRUB_
除了已定义的变量外,用户还可以引入自己的变量,以后在 /etc/grub.d
目录中的脚本内使用。
编辑 /etc/default/grub
后,请使用 grub2-mkconfig -o /boot/grub2/grub.cfg
更新主要配置文件。
此文件中设置的所有选项是会影响所有引导项的常规选项。通过 GRUB_*_XEN_* 配置选项可以设置 Xen 内核或 Xen 超级管理程序的特定选项。有关细节,请参见下文。
GRUB_DEFAULT
设置默认会引导的引导菜单项。它的值可以是数字值、菜单项的完整名称或“saved”。
GRUB_DEFAULT=2
引导第三个(从零开始计数)引导菜单项。GRUB_DEFAULT="2>0"
引导第三个顶级菜单项的第一个子菜单项。GRUB_DEFAULT="Example boot menu entry"
引导标题为“Example boot menu entry”的菜单项。GRUB_DEFAULT=saved
引导grub2-once
或grub2-set-default
命令指定的项。grub2-reboot
只设置下一次重引导的默认引导项,而grub2-set-default
设置发生更改之前的默认引导项。grub2-editenv list
列出下一个引导项。GRUB_HIDDEN_TIMEOUT
等待用户按某个键的指定秒数。在此期间,除非用户按下某个键,否则不显示菜单。如果用户在指定的时间内未按任何键,控制权将转交给
GRUB_TIMEOUT
。GRUB_HIDDEN_TIMEOUT=0
首先会检查是否已按下 Shift,如果是,则显示引导菜单,否则会立即引导默认的菜单项。如果 GRUB 2 只识别了一个可引导操作系统,则默认行为就是如此。GRUB_HIDDEN_TIMEOUT_QUIET
如果指定
false
,则在激活了GRUB_HIDDEN_TIMEOUT
功能时,会在一个空白屏幕上显示倒数计时器。GRUB_TIMEOUT
在自动引导默认引导项之前,显示引导菜单的期限(以秒为单位)。如果按下某个键,则会取消超时,GRUB 2 将等待您手动做出选择。如果指定
GRUB_TIMEOUT=-1
,则在您手动选择引导项之前,会一直显示菜单。GRUB_CMDLINE_LINUX
此行中的项将添加到正常和恢复模式的引导项的末尾。使用它可以向引导项添加内核参数。
GRUB_CMDLINE_LINUX_DEFAULT
与
GRUB_CMDLINE_LINUX
一样,但只能在正常模式下追加项。GRUB_CMDLINE_LINUX_RECOVERY
与
GRUB_CMDLINE_LINUX
一样,但只能在恢复模式下追加项。GRUB_CMDLINE_LINUX_XEN_REPLACE
此项将完全替代所有 Xen 引导项的
GRUB_CMDLINE_LINUX
参数。GRUB_CMDLINE_LINUX_XEN_REPLACE_DEFAULT
与
GRUB_CMDLINE_LINUX_XEN_REPLACE
一样,但只会替代GRUB_CMDLINE_LINUX_DEFAULT
的参数。GRUB_CMDLINE_XEN
此项只为 Xen guest 内核指定内核参数 — 工作原理与
GRUB_CMDLINE_LINUX
相同。GRUB_CMDLINE_XEN_DEFAULT
与
GRUB_CMDLINE_XEN
一样 — 工作原理与GRUB_CMDLINE_LINUX_DEFAULT
相同。GRUB_TERMINAL
启用和指定输入/输出终端设备。可以是
console
(PC BIOS 和 EFI 控制台)、serial
(串行终端)、ofconsole
(开放式固件控制台)或默认值gfxterm
(图形模式输出)。用引号括住所需的选项可以启用多个设备,例如GRUB_TERMINAL="console serial"
。GRUB_GFXMODE
gfxterm
图形终端使用的分辨率。请注意,您只能使用您的图形卡 (VBE) 支持的模式。默认值为“auto”,即尝试选择首选的分辨率。在 GRUB 2 命令行中键入videoinfo
可以显示 GRUB 2 适用的屏幕分辨率。GRUB 2 引导菜单屏幕显示后,键入 C 即可访问命令行。您还可以指定颜色深度,方法是将其值追加到分辨率设置的后面,例如
GRUB_GFXMODE=1280x1024x24
。GRUB_BACKGROUND
设置
gfxterm
图形终端的背景图像。该图像必须是 GRUB 2 在引导时可读的文件,并且必须以.png
、.tga
、.jpg
或.jpeg
后缀结尾。必要时,系统会缩放该图像以适合屏幕。GRUB_DISABLE_OS_PROBER
如果将此选项设置为
true
,将禁用自动搜索其他操作系统的功能。系统只会检测/boot/
中的内核映像,以及/etc/grub.d/
中您自己的脚本内的选项。SUSE_BTRFS_SNAPSHOT_BOOTING
如果将此选项设置为
true
,GRUB 2 可直接引导至 Snapper 快照。有关详细信息,请参见第 7.3 节 “通过从快照引导来执行系统回滚”。
有关选项的完整列表,请参见 GNU GRUB 手册。
12.2.3 /etc/grub.d
中的脚本 #
在执行 grub2-mkconfig -o /boot/grub2/grub.cfg
命令期间,将读取此目录中的脚本。脚本中的指令将整合到 /boot/grub2/grub.cfg
中。grub.cfg
中菜单项的顺序由此目录中文件的运行顺序来决定。具有前导编号的文件先执行,从最小的编号开始。00_header
在 10_linux
之前运行,而后者又在 40_custom
之前运行。如果存在采用字母名称的文件,这些文件将在采用编号命名的文件后面执行。在执行 grub2-mkconfig
期间,只有可执行文件才能在 grub.cfg
中生成输出。默认情况下,/etc/grub.d
目录中的所有文件都是可执行文件。
grub.cfg
中
由于每次运行 grub2-mkconfig
时都会重新编译 /boot/grub2/grub.cfg
,因此所有自定义内容都会丢失。如果要将您的行直接插入到 /boot/grub2/grub.cfg
中,并且希望在运行 grub2-mkconfig
之后它们不会丢失,请将这些行插入到下面两行之间
### BEGIN /etc/grub.d/90_persistent ###
与
### END /etc/grub.d/90_persistent ###
90_persistent
脚本可确保此类内容会保留下来。
下面列出了最重要的脚本:
00_header
设置环境变量,例如系统文件位置、显示设置、主题和以前保存的项。它还可以导入
/etc/default/grub
中储存的首选项。通常,不需要对此文件进行更改。10_linux
识别根设备上的 Linux 内核,并创建相关的菜单项。这包括关联的恢复模式选项(如果已启用)。主菜单页中只显示最新内核,其他内核包含在子菜单中。
30_os-prober
此脚本使用
os-prober
来搜索 Linux 和其他操作系统,并将结果列于 GRUB 2 菜单中。其中的某些部分可以识别其他特定操作系统,例如 Windows 或 macOS。40_custom
使用此文件可以方便地在
grub.cfg
中包含自定义引导项。切勿更改开头的exec tail -n +3 $0
部分。
处理顺序根据前导编号确定,编号最小的脚本最先执行。如果多个脚本的前导编号相同,则根据整个名称的字母顺序来决定执行顺序。
/boot/grub2/custom.cfg
如果您创建了 /boot/grub2/custom.cfg
并在其中填充了内容,则引导时系统会自动将它包含到 /boot/grub40/grub.cfg
中紧接在 40_custom 后面的位置。
12.2.4 BIOS 驱动器与 Linux 设备之间的映射 #
在 GRUB Legacy 中,device.map
配置文件用于基于 BIOS 驱动器号派生 Linux 设备名称。不一定总能正确猜测出 BIOS 驱动器与 Linux 设备之间的映射。例如,如果 IDE 和 SCSI 驱动器的引导顺序在 BIOS 配置中被交换,则 GRUB Legacy 就会发生顺序错误。
GRUB 2 在生成 grub.cfg
时使用设备 ID 字符串 (UUID) 或文件系统标签,因此避免了此问题。GRUB 2 实用程序会即时创建一个临时设备映射,这通常足以满足需要,在单磁盘系统中尤其如此。
但是,如果您需要覆盖 GRUB 2 的自动设备映射机制,请创建自定义映射文件 /boot/grub2/device.map
。以下示例将更改映射,使 DISK 3
成为引导磁盘。请注意,GRUB 2 分区编号以 1
开始,而不是像 GRUB Legacy 中那样以 0
开始。
(hd1) /dev/disk-by-id/DISK3 ID (hd2) /dev/disk-by-id/DISK1 ID (hd3) /dev/disk-by-id/DISK2 ID
12.2.6 设置引导口令 #
即使在操作系统引导之前,GRUB 2 也支持对文件系统的访问。没有 root 权限的用户可以访问 Linux 系统中的文件,而在引导系统后,他们将无权访问这些文件。要阻止此类访问或防止用户引导某些菜单项,请设置引导口令。
如果设置了引导口令,则每次引导时都需要输入该口令,这意味着系统不会自动引导。
使用
grub2-mkpasswd-pbkdf2
来加密口令:tux >
sudo
grub2-mkpasswd-pbkdf2 Password: **** Reenter password: **** PBKDF2 hash of your password is grub.pbkdf2.sha512.10000.9CA4611006FE96BC77A...将生成的字符串连同
set superusers
命令一起粘贴到文件/etc/grub.d/40_custom
中。set superusers="root" password_pbkdf2 root grub.pbkdf2.sha512.10000.9CA4611006FE96BC77A...
要将更改导入到主要配置文件中,请运行:
tux >
sudo
grub2-mkconfig -o /boot/grub2/grub.cfg
在重引导后,当您尝试引导某个菜单项时,系统会提示您输入用户名和口令。输入 root
以及您在执行 grub2-mkpasswd-pbkdf2
命令期间键入的口令。如果身份凭证正确,系统将引导选定的引导项。
有关详细信息,请参见https://www.gnu.org/software/grub/manual/grub.html#Security。
12.3 使用 YaST 配置引导加载程序 #
在 SUSE Linux Enterprise Desktop 系统中,配置引导加载程序一般选项最简单的方式就是使用 YaST 模块。在 ,选择 › 。该模块会显示您系统的当前引导加载程序配置,并允许您进行更改。
使用
选项卡可查看和更改类型、位置和高级加载程序设置的相关设置。您可以选择要在标准模式还是 EFI 模式下使用 GRUB 2。如果您使用的是 EFI 系统,则只能安装 GRUB2-EFI,否则您的系统不再能够引导。
要重新安装引导加载程序,请务必在 YaST 中更改设置,然后再将其改回来。例如,要重新安装 GRUB2-EFI,请先选择
,然后立即将其切换回 。否则,可能只会重新安装引导加载程序的一部分。
要使用此处未列出的引导加载程序,请选择
。在选择该选项之前,请仔细阅读您的引导加载程序文档。12.3.1 引导加载程序位置和引导代码选项 #
引导加载程序的默认位置为主引导记录 (MBR) 或 /
分区的引导扇区,具体视分区设置而定。要修改引导加载程序的位置,请遵循以下步骤:
选择
选项卡,然后为 选择以下某个选项:选择此选项将在包含
/boot
目录的磁盘 MBR 中安装引导加载程序。通常,这将是装入到/
的磁盘,但如果/boot
装入到其他磁盘上的独立分区中,则将会使用该磁盘的 MBR。这将在
/
分区的引导扇区安装引导加载程序。手动使用此选项来指定引导加载程序的位置。
单击
以应用您的更改。
选项卡包含以下额外的选项:
激活包含
/boot
目录的分区。对于 POWER 系统,则会激活 PReP 分区。此选项用于具有旧 BIOS 的系统和/或旧式操作系统,因为它们可能无法从非活动的分区引导。您可以放心地启用此选项。如果 MBR 包含自定义的“非 GRUB”代码,此选项会用不受操作系统限制的通用代码替换该代码。如果您停用此选项,系统可能变得无法引导。
启动支持可信计算功能(可信平台模块 (TPM))的 TrustedGRUB2。有关详细信息,请参见 https://github.com/Sirrix-AG/TrustedGRUB2。
12.3.2 调整磁盘顺序 #
如果您的计算机有多个硬盘,您可以指定磁盘的引导顺序。如果从 MBR 引导,将在列表中的第一个磁盘中安装 GRUB 2。默认在该磁盘中安装 SUSE Linux Enterprise Desktop。列表的其余部分是有关 GRUB 2 的设备映射程序的提示(请参见第 12.2.4 节 “BIOS 驱动器与 Linux 设备之间的映射”)。
通常情况下,默认值几乎对所有部署都有效。如果您错误地更改了磁盘的引导顺序,系统下次重引导时可能无法引导。例如,如果列表中的第一个磁盘不在 BIOS 引导序列中,并且列表中的其他磁盘有空 MBR,系统将无法引导。
打开
选项卡。单击
。如果列出了多个磁盘,请选择一个,然后单击
或 来对显示的磁盘重新排序。单击
两次以保存更改。
12.3.3 配置高级选项 #
可以通过
选项卡来配置高级引导参数。12.3.3.1 选项卡 #
通过键入新值或者用鼠标单击相应的方向键来更改
的值。如果选择该选项,引导加载程序将会搜索其他系统(例如 Windows)或其他 Linux 安装。
隐藏引导菜单并引导默认项。
从“默认引导部分”列表中选择所需的项。请注意,引导项名称中的“>”符号用于分隔引导部分及其子部分。
使用一个附加的口令保护引导加载程序和系统。有关详细信息,请参见 第 12.2.6 节 “设置引导口令”。
12.3.3.2 选项卡 #
在此处指定可选的内核参数,以启用/禁用系统功能、添加驱动程序,等等。
如果选中此项,则内核将禁用某些新式 CPU 的同步多线程功能。根据所用的工作负载,禁用此功能可能会影响系统的总体性能。
如果选中该选项,引导菜单会显示在图形启动屏幕中,而不是以文本模式显示。默认情况下,系统会自动设置引导屏幕的分辨率,但您可以通过
手动进行设置。可以使用 文件选择器指定图形主题定义文件。请仅在您想要应用自己的定制主题时,才更改此设置。如果您的计算机是通过串行控制台控制的,则可激活此选项并指定要使用的 COM 端口及其运行速度。请参见
info grub
或 http://www.gnu.org/software/grub/manual/grub.html#Serial-terminal
12.4 IBM Z 上终端使用方式的差异 #
在 3215 和 3270 终端上,光标的移动方式以及在 GRUB 2 中发出编辑命令的方式存在一些差异和限制。
12.4.1 限制 #
- 交互能力
交互性存在严重的限制。键入时通常不能获得直观的反馈。要查看光标所在的位置,请键入下划线 (_)。
注意:3270 与 3215 的对比与 3215 终端相比,3270 终端在显示和刷新屏幕方面要好得多。
- 光标的移动
无法进行“传统的”光标移动操作。Alt、Meta、Ctrl 和光标键不起作用。要移动光标,请使用第 12.4.2 节 “组合键”中列出的组合键。
- 加字符
插入符 (^) 用作控制字符。要键入文本 ^ 后再键入一个字母,请键入 ^、^ 和字母。
- 输入
Enter 键不起作用,请改用 ^–J。
12.4.2 组合键 #
常用的替代键 |
^–J |
确认(“Enter”) |
^–L |
中止,返回前一“状态” | |
^–I |
Tab 键补全(在编辑模式与外壳模式下) | |
菜单模式下可用的键: |
^–A |
移到第一项 |
^–E |
移到最后一项 | |
^–P |
移到上一项 | |
^–N |
移到下一项 | |
^–G |
上移一页 | |
^–C |
下移一页 | |
^–F |
引导选定的项或进入子菜单(与 ^–J 的作用相同) | |
E |
编辑选定的项 | |
C |
进入 GRUB-Shell | |
编辑模式下可用的键: |
^–P |
上移一行 |
^–N |
下移一行 | |
^–B |
向左移一个字符 | |
^–F |
向右移一个字符 | |
^–A |
移到行首 | |
^–E |
移到行尾 | |
^–H |
退格 | |
^–D |
删除 | |
^–K |
删除光标起当前行 | |
^–Y |
复制 | |
^–O |
插入空行 | |
^–L |
刷新屏幕 | |
^–X |
引导项 | |
^–C |
进入 GRUB-Shell | |
命令行模式下可用的键: |
^–P |
上一个命令 |
^–N |
历史中的下一个命令 | |
^–A |
移到行首 | |
^–E |
移到行尾 | |
^–B |
向左移一个字符 | |
^–F |
向右移一个字符 | |
^–高 |
退格 | |
^–D |
删除 | |
^–K |
删除光标起当前行 | |
^–U |
删除行 | |
^–Y |
复制 |
12.5 有用的 GRUB 2 命令 #
grub2-mkconfig
基于
/etc/default/grub
以及/etc/grub.d/
中的脚本生成新的/boot/grub2/grub.cfg
。例 12.1︰ grub2-mkconfig 用法 #grub2-mkconfig -o /boot/grub2/grub.cfg
提示:语法检查运行不带任何参数的
grub2-mkconfig
会将配置打印到 STDOUT 中供用户查看。在写入/boot/grub2/grub.cfg
后使用grub2-script-check
可以检查其语法。重要:grub2-mkconfig
无法修复 UEFI 安全引导表如果要使用 UEFI 安全引导且系统无法再正确连接 GRUB 2,您可能需要另外重新安装 Shim 并重新生成 UEFI 引导表。要执行此操作,请使用:
root #
shim-install --config-file=/boot/grub2/grub.cfggrub2-mkrescue
为安装的 GRUB 2 配置创建一个可引导的救援映像。
例 12.2︰ grub2-mkrescue 用法 #grub2-mkrescue -o save_path/name.iso iso
grub2-script-check
检查给定文件中有无语法错误。
例 12.3︰ grub2-script-check 用法 #grub2-script-check /boot/grub2/grub.cfg
grub2-once
仅设置下次引导的默认引导项。要获取可用引导项的列表,请使用
--list
选项。例 12.4︰ grub2-once 用法 #grub2-once number_of_the_boot_entry
提示:grub2-once
帮助不使用任何选项调用该程序可以获取所有可用选项的完整列表。
12.6 更多信息 #
http://www.gnu.org/software/grub/ 上提供了有关 GRUB 2 的大量信息。还请参见 grub
信息页面。您也可以在技术信息搜索 (“) 中搜索关键字”GRUB 2http://www.suse.com/support,以获取有关特殊问题的信息。
13 systemd
守护程序 #
systemd
程序是进程 ID 为 1 的进程。它负责以所需的方式初始化系统。systemd
由内核直接启动,信号 9(该信号通常会终止进程)对它不起作用。所有其他程序都由 systemd 直接启动,或由它的其中一个子进程启动。
Systemd 取代了 System V init 守护程序。systemd
与 System V init 完全兼容(通过支持 init 脚本实现)。systemd 的其中一个主要优点是可通过激进方式并行启动多项服务来大幅加快引导速度。另外,systemd 只在确实有需要时才会启动服务。守护程序并不是在系统引导时无条件地启动,而是在第一次需要时启动。systemd 还支持内核控制组 (cgroups),以拍摄系统状态快照以及恢复系统状态等等。有关详细信息,请参见http://www.freedesktop.org/wiki/Software/systemd/。
13.1 systemd 概念 #
本节将详细介绍有关 systemd 的概念。
13.1.1 systemd 是什么 #
systemd 是适用于 Linux 的系统和会话管理器,它与 System V 及 LSB init 脚本兼容。主要功能包括:
提供激进式并行化功能
使用套接字及 D-Bus 激活来启动服务
提供按需启动守护程序功能
使用 Linux cgroups 跟踪进程
支持拍摄系统状态快照及恢复系统状态
维护安装点和自动安装点
实施精细的、基于事务依赖项的服务控制逻辑
13.1.2 单元文件 #
单元配置文件包含有关以下项目的信息:服务、套接字、设备、安装点、自动安装点、交换文件或分区、启动目标、监控的文件系统路径、受 systemd 控制和监管的计时器、临时系统状态快照、资源管理部分或一组外部创建的进程。“单元文件”是 systemd 用于描述下列各项的通用术语:
服务: 进程相关信息(例如运行守护程序);文件以 .service 结尾
目标: 用于将单元分组以及在启动期间用作同步点;文件以 .target 结尾
套接字: IPC 或网络套接字或文件系统 FIFO 相关信息,适用于基于套接字的激活(如
inetd
);文件以 .socket 结尾路径: 用于触发其他单元(例如,在文件更改时运行服务);文件以 .path 结尾
计时器: 受控制计时器相关信息,适用于基于计时器的激活;文件以 .timer 结尾
装入点: 通常由 fstab 生成器自动生成;文件以 .mount 结尾
自动安装点: 文件系统自动安装点相关信息;文件以 .automount 结尾
交换: 内存分页的交换设备或文件相关信息;文件以 .swap 结尾
设备: sysfs/udev(7) 设备树中公开的设备相关信息;文件以 .device 结尾
范围/部分: 有关分层管理一组进程的资源的概念;文件以 .scope/.slice 结尾
有关 systemd.unit 的更多信息,请参见 http://www.freedesktop.org/software/systemd/man/systemd.unit.html
13.2 基本用途 #
System V init 系统使用若干命令来处理服务:init 脚本、insserv
、telinit
及其他。systemd 使服务管理变得简单,要运行大部分服务处理任务,只需要记住一条命令:systemctl
。它使用“命令加子命令”表示法,与 git
或 zypper
相似:
systemctl GENERAL OPTIONS SUBCOMMAND SUBCOMMAND OPTIONS
有关完整的手册,请参见 man 1 systemctl
。
如果输出传递到某个终端(而不是某个管道或文件),systemd 命令默认会将长输出发送到分页器。使用 --no-pager
选项可关闭分页模式。
systemd 还支持 bash 补全,允许您输入子命令的头几个字母,然后按 →| 自动补全子命令。此功能只能在 bash
外壳中使用,并且需要安装 bash-completion
包。
13.2.1 管理正在运行的系统中的服务 #
用于管理服务的子命令与使用 System V init 管理服务的子命令相同(start
、stop
等)。服务管理命令的一般语法如下所示:
- systemd
systemctl reload|restart|start|status|stop|... MY_SERVICE(S)
- System V init
rcMY_SERVICE(S) reload|restart|start|status|stop|...
systemd 允许您一次管理多个服务。不用像 System V init 要逐个执行 init 脚本,而是执行如下命令:
tux >
sudo
systemctl start MY_1ST_SERVICE MY_2ND_SERVICE
要列出系统上所有可用的服务,请运行:
tux >
sudo
systemctl list-unit-files --type=service
下表列出了 systemd 和 System V init 最重要的服务管理命令:
任务 |
systemd 命令 |
System V init 命令 |
---|---|---|
启动: |
start |
start |
停止: |
stop |
stop |
重启动: 关闭服务,然后再启动这些服务。如果某项服务尚未运行,它将会启动。 |
restart |
restart |
有条件地重启动: 如果服务当前正在运行,则重启动它们。对未在运行的服务不执行任何操作。 |
try-restart |
try-restart |
重新装载:
让服务在不中断操作的情况下重新装载它们的配置文件。使用案例:让 Apache 重新装载修改过的 |
reload |
reload |
重新装载或重启动: 如果支持重新装载则重新装载服务,否则重启动服务。如果某项服务尚未运行,它将会启动。 |
reload-or-restart |
n/a |
有条件地重新装载或重启动: 如果支持重新装载则重新装载服务,否则,如果服务当前正在运行,则重启动服务。对未在运行的服务不执行任何操作。 |
reload-or-try-restart |
n/a |
获得详细的状态信息:
列出服务状态的相关信息。 |
status |
status |
获得简要的状态信息: 显示服务是否处于活动状态。 |
is-active |
status |
13.2.2 永久启用/禁用服务 #
上一节中提到的服务管理命令可让您操控当前会话的服务。systemd 还允许您永久启用或禁用服务,让它们在用户要求时自动启动或永远不可用。您可以使用 YaST 或在命令行上运行命令来实现此目的。
13.2.2.1 在命令行上启用/禁用服务 #
下表列出了 systemd 和 System V init 用于启用和禁用服务的命令:
在命令行上启用服务时,服务不会自动启动。它会安排在下一次系统启动或运行级别/目标发生更改时启动。要在启用服务之后立即启动它,请显式运行 systemctl start MY_SERVICE
或 rc MY_SERVICE start
。
任务 |
|
System V init 命令 |
---|---|---|
启用: |
|
|
禁用: |
|
|
检查: 显示某项服务是否启用。 |
|
|
重新启用: 与重启动服务相似,此命令先禁用服务,然后再启用该服务。可用来使用默认值重新启用服务。 |
|
无 |
屏蔽: “禁用”某项服务之后,仍然可以手动启动它。要彻底禁用服务,您需要屏蔽它。须谨慎使用该功能。 |
|
无 |
取消屏蔽: 屏蔽某项服务之后,只有在将其取消屏蔽之后才能再次使用它。 |
|
无 |
13.3 系统启动和目标管理 #
启动和关闭系统的整个过程由 systemd 负责维护。从这一点来看,可以将内核视为一个后台进程,其任务是维护所有其他进程,以及根据其他程序的请求来调整 CPU 时间和硬件访问。
13.3.1 目标与运行级别的比较 #
使用 System V init 时,系统引导到所谓的“运行级别”。运行级别定义系统如何启动以及正在运行的系统中有哪些服务可用。运行级别是有编号的;最知名的运行级别是 0
(关闭系统)、3
(联网的多用户模式)和 5
(联网并使用显示管理器的多用户模式)。
systemd 使用所谓的“目标单元”引入新的概念。不过,它仍然与运行级别概念完全兼容。目标单元用名称而不是编号来标识,并具有特定的作用。例如,目标 local-fs.target
和 swap.target
用于装入本地文件系统和交换空间。
目标 graphical.target
提供联网并使用显示管理器的多用户系统,作用与运行级别 5 相当。复杂目标(如 graphical.target
)通过将一部分其他目标组合起来充当“元”目标。systemd 通过组合现有目标简化了创建自定义目标的工作,从而提供了极大的灵活性。
下面的列表显示了最重要的 systemd 目标单元。有关完整列表,请参见 man 7 systemd.special
。
default.target
默认引导的目标。这并不是“实际”目标,而是指向另一个目标(如
graphic.target
)的符号链接,可通过 YaST 永久更改(请参见第 13.4 节 “使用 YaST 管理 服务”)。要为某个会话更改它,请在引导提示处使用内核参数systemd.unit=MY_TARGET.target
。emergency.target
在控制台上启动紧急外壳。请仅在引导提示处按以下格式使用它:
systemd.unit=emergency.target
。graphical.target
启动联网的具有多用户支持和显示管理器的系统。
halt.target
关闭系统。
mail-transfer-agent.target
启动发送和接收邮件所需的所有服务。
multi-user.target
启动联网的多用户系统。
reboot.target
重新引导系统。
rescue.target
启动不联网的单用户系统。
为了与 System V init 运行级别系统保持兼容,systemd 提供了名为 runlevelX.target
的特殊目标,与编号为 X 的相应运行级别相对应。
如果您想知道当前的目标,请使用命令:systemctl get-default
systemd
目标单元 #
System V 运行级别 |
|
目的 |
---|---|---|
0 |
|
系统关闭 |
1、S |
|
单用户模式 |
2 |
|
无远程联网的本地多用户模式 |
3 |
|
完整的联网多用户模式 |
4 |
|
未使用/用户定义 |
5 |
|
联网并使用显示管理器的完整多用户模式 |
6 |
|
系统重引导 |
/etc/inittab
System V init 系统中的运行级别在 /etc/inittab
中配置。systemd 不使用此配置。有关如何创建您自己的可引导目标的指导,请参考第 13.5.3 节 “创建自定义目标”。
13.3.1.1 用于更改目标的命令 #
可使用下列命令来操作目标单元:
任务 |
systemd 命令 |
System V init 命令 |
---|---|---|
更改当前目标/运行级别 |
|
|
更改为默认目标/运行级别 |
|
无 |
获得当前目标/运行级别 |
使用 systemd 时,一般会有多个活动目标。该命令可列出当前处于活动状态的所有目标。 |
或者
|
永久更改默认运行级别 |
使用服务管理器或运行以下命令:
|
使用服务管理器或更改以下行
( |
更改当前引导进程的默认运行级别 |
在引导提示处输入以下选项
|
在引导提示处输入所需的运行级别编号。 |
显示目标/运行级别的依赖项 |
“Requires” 会列出硬性依赖项(必须解决的依赖项),而 “Wants” 会列出软性依赖项(情况允许时解决的依赖项)。 |
无 |
13.3.2 调试系统的启动 #
systemd 提供了分析系统启动过程的方法。您可以查看所有服务及其状态的列表(而不必分析 /varlog/
)。systemd 还允许您扫描启动过程,以了解每项服务启动用了多长时间。
13.3.2.1 查看服务的启动情况 #
要查看系统引导后所启动服务的完整列表,请输入命令 systemctl
。该命令会列出所有活动服务,如下所示(已精简)。要获得特定服务的详细信息,请使用 systemctl status MY_SERVICE
。
root #
systemctl
UNIT LOAD ACTIVE SUB JOB DESCRIPTION
[...]
iscsi.service loaded active exited Login and scanning of iSC+
kmod-static-nodes.service loaded active exited Create list of required s+
libvirtd.service loaded active running Virtualization daemon
nscd.service loaded active running Name Service Cache Daemon
chronyd.service loaded active running NTP Server Daemon
polkit.service loaded active running Authorization Manager
postfix.service loaded active running Postfix Mail Transport Ag+
rc-local.service loaded active exited /etc/init.d/boot.local Co+
rsyslog.service loaded active running System Logging Service
[...]
LOAD = Reflects whether the unit definition was properly loaded.
ACTIVE = The high-level unit activation state, i.e. generalization of SUB.
SUB = The low-level unit activation state, values depend on unit type.
161 loaded units listed. Pass --all to see loaded but inactive units, too.
To show all installed unit files use 'systemctl list-unit-files'.
要想只列出无法启动的服务,请使用 --failed
选项。
root #
systemctl --failed
UNIT LOAD ACTIVE SUB JOB DESCRIPTION
apache2.service loaded failed failed apache
NetworkManager.service loaded failed failed Network Manager
plymouth-start.service loaded failed failed Show Plymouth Boot Screen
[...]
13.3.2.2 调试启动时间 #
为了调试系统启动时间,systemd 提供了 systemd-analyze
命令。该命令会显示总启动时间及按启动时间排序的服务列表,还可以生成 SVG 图,以显示各服务相对于其他服务的启动时间。
- 列出系统启动时间
root #
systemd-analyze Startup finished in 2666ms (kernel) + 21961ms (userspace) = 24628ms- 列出服务启动时间
root #
systemd-analyze blame 6472ms systemd-modules-load.service 5833ms remount-rootfs.service 4597ms network.service 4254ms systemd-vconsole-setup.service 4096ms postfix.service 2998ms xdm.service 2483ms localnet.service 2470ms SuSEfirewall2_init.service 2189ms avahi-daemon.service 2120ms systemd-logind.service 1080ms chronyd.service [...] 75ms fbset.service 72ms purge-kernels.service 47ms dev-vda1.swap 38ms bluez-coldplug.service 35ms splash_early.service- 服务启动时间图
root #
systemd-analyze plot > jupiter.example.com-startup.svg
13.3.2.3 查看完整的启动过程 #
上面提到的命令可让您查看已启动的服务以及启动各服务所需的时间。如果您需要知道更多细节,可以在引导提示处输入下列参数,让 systemd
详细记录整个启动过程:
systemd.log_level=debug systemd.log_target=kmsg
现在,systemd
会将日志讯息写入内核环缓冲区。使用 dmesg
查看该缓冲区:
tux >
dmesg -T | less
13.3.3 System V 兼容性 #
systemd 与 System V 兼容,因此,您仍可以使用现有的 System V init 脚本。但是,至少有一个已知问题会导致 System V init 脚本默认不能与 systemd 配合使用:在 init 脚本中通过 su
或 sudo
以其他用户身份启动服务会导致脚本失败,生成“访问被拒绝”错误。
使用 su
或 sudo
更改用户时,会启动 PAM 会话。完成 init 脚本后会终止此会话。因此,init 脚本启动的服务也会终止。要解决此问题,请执行以下步骤:
创建与 init 脚本同名、扩展名为
.service
的服务文件封装程序:[Unit] Description=DESCRIPTION After=network.target [Service] User=USER Type=forking1 PIDFile=PATH TO PID FILE1 ExecStart=PATH TO INIT SCRIPT start ExecStop=PATH TO INIT SCRIPT stop ExecStopPost=/usr/bin/rm -f PATH TO PID FILE1 [Install] WantedBy=multi-user.target2
将 UPPERCASE LETTERS 中写入的所有值替换为适当的值。
使用
systemctl start 应用程序
启动守护程序。
13.4 使用 YaST 管理 服务 #
基本服务管理也可以通过 YaST 服务管理器模块实现。该模块支持启动、停止、启用和禁用服务。它还可让您显示服务的状态以及更改默认目标。要启动 YaST 模块,请选择
› › 。- 更改
要更改系统引导到的目标,请从
下拉框中选择某个目标。最常用的目标是 (启动图形登录屏幕)和 (以命令行模式启动系统)。- 启动或停止服务
从表中选择一个服务。
列显示它当前是( )否( )正在运行。通过选择 可切换其状态。为当前正在运行的会话启动或停止服务会更改其状态。要更改服务在整个重引导过程中的状态,您需要启用或禁用服务。
- 启用或禁用服务
从表中选择一个服务。
列显示它当前 还是 。通过选择 可更改其状态。通过启用或禁用服务,可配置服务在引导期间是否启动(
或 )。此设置不会影响当前的会话。要更改服务在当前会话中的状态,您需要将其启动或停止。- 查看状态讯息
要查看某个服务的状态讯息,请从列表中选择该服务,然后选择
。您看到的输出与systemctl
-l
status MY_SERVICE 命令生成的输出完全相同。
有问题的运行级别设置可能会导致系统无法使用。在应用您的更改之前,请确保您清楚这些设置可能产生的结果。
13.5 systemd
自定义 #
以下几节介绍了 systemd
自定义的一些示例。
一律在 /etc/systemd/
中进行 systemd 自定义设置,切勿在 /usr/lib/systemd/
中进行。否则,您的更改将在 systemd 下次更新时被覆盖。
13.5.1 自定义单元文件 #
systemd 单元文件位于 /usr/lib/systemd/system
中。如果您要自定义服务文件,请执行下列步骤:
将要修改的文件从
/usr/lib/systemd/system
复制到/etc/systemd/system
。将文件名保持不变。根据需要修改
/etc/systemd/system
中的副本。如需配置更改的概述,请使用
systemd-delta
命令。它会比较并识别覆盖了其他配置文件的配置文件。有关细节,请参考systemd-delta
手册页。
/etc/systemd
中修改过的文件优先于 /usr/lib/systemd/system
中的原始文件,前提是它们的文件名相同。
13.5.1.1 将 xinetd
服务转换为 systemd
#
从 SUSE Linux Enterprise Desktop 15 版本开始,去除了 xinetd
基础架构。本节概述如何将现有的自定义 xinetd
服务文件转换为 systemd
套接字。
对于每个 xinetd
服务文件,您至少要有两个 systemd
单元文件:套接字文件 (*.socket
) 和关联的服务文件 (*.service
)。套接字文件告诉 systemd
要创建哪个套接字,服务文件告诉 systemd
要启动哪个可执行文件。
以下面的 xinetd
服务文件为例:
root #
cat /etc/xinetd.d/example
service example
{
socket_type = stream
protocol = tcp
port = 10085
wait = no
user = user
group = users
groups = yes
server = /usr/libexec/example/exampled
server_args = -auth=bsdtcp exampledump
disable = no
}
要将它转换为 systemd
,需要下面两个配套的文件:
root #
cat /usr/lib/systemd/system/example.socket
[Socket]
ListenStream=0.0.0.0:10085
Accept=false
[Install]
WantedBy=sockets.target
root #
cat /usr/lib/systemd/system/example.service
[Unit]
Description=example
[Service]
ExecStart=/usr/libexec/example/exampled -auth=bsdtcp exampledump
User=user
Group=users
StandardInput=socket
有关 systemd
的“套接字”和“服务”文件选项的完整列表,请参见 systemd.socket 和 systemd.service 手册页(man 5 systemd.socket
、man 5 systemd.service
)。
13.5.2 创建“插入式”文件 #
如果您只想在配置文件中添加几行或修改文件的一小部分,可以使用所谓的“插入式”文件。使用插入式文件,您无需编辑或覆盖单元文件本身,即可扩展单元文件的配置。
例如,要更改位于 /usr/lib/systemd/system/FOOBAR.SERVICE
中 FOOBAR 服务的一个值,请按以下步骤操作:
创建名为
/etc/systemd/system/FOOBAR.service.d/
的目录。注意
.d
后缀。该目录必须命名为与要用插入式文件修补的服务相似的名称。在该目录中,创建
WHATEVERMODIFICATION.conf
文件。确保文件中仅包含要修改的值所在的那一行。
将更改保存到 文件中。它将作为原始文件的扩展。
13.5.3 创建自定义目标 #
System V init SUSE 系统上未使用运行级别 4,以便允许管理员创建自己的运行级别配置。systemd 允许您创建任意数目的自定义目标。建议您从采用 graphical.target
等现有目标开始。
将配置文件
/usr/lib/systemd/system/graphical.target
复制到/etc/systemd/system/MY_TARGET.target
,并根据需要调整该文件。上一步中复制的配置文件已涵盖目标的必要(“硬性”)依赖项。如果还要涵盖需要的(“软性”)依赖项,请创建目录
/etc/systemd/system/MY_TARGET.target.wants
。对每个需要的服务,创建从
/usr/lib/systemd/system
链到/etc/systemd/system/MY_TARGET.target.wants
的符号链接。设置好目标后,重新装载 systemd 配置以使新目标可用。
tux >
sudo
systemctl daemon-reload
13.6 高级用途 #
以下几节介绍了适合系统管理员的高级主题。有关更高级的 systemd 文档,请参考 Lennart Pöttering 撰写的适合管理员的 systemd 相关系列,网址为 http://0pointer.de/blog/projects。
13.6.1 清理临时目录 #
systemd
支持定期清理临时目录。将会自动迁移并激活前一系统版本中的配置。tmpfiles.d
(负责管理临时文件)将从 /etc/tmpfiles.d/*.conf
、/run/tmpfiles.d/*.conf
和 /usr/lib/tmpfiles.d/*.conf
文件中读取其配置。/etc/tmpfiles.d/*.conf
中的配置将覆盖其他两个目录中的相关配置(/usr/lib/tmpfiles.d/*.conf
是包用于储存其配置文件的位置)。
配置格式为每个路径一行,该行包含操作与路径、(可选)模式、所有权、期限和自变量字段,具体取决于操作。以下示例将取消链接 X11 锁定文件:
Type Path Mode UID GID Age Argument r /tmp/.X[0-9]*-lock
要获取 tmpfile 计时器的状态:
tux >
sudo
systemctl status systemd-tmpfiles-clean.timer systemd-tmpfiles-clean.timer - Daily Cleanup of Temporary Directories Loaded: loaded (/usr/lib/systemd/system/systemd-tmpfiles-clean.timer; static) Active: active (waiting) since Tue 2018-04-09 15:30:36 CEST; 1 weeks 6 days ago Docs: man:tmpfiles.d(5) man:systemd-tmpfiles(8) Apr 09 15:30:36 jupiter systemd[1]: Starting Daily Cleanup of Temporary Directories. Apr 09 15:30:36 jupiter systemd[1]: Started Daily Cleanup of Temporary Directories.
有关处理临时文件的详细信息,请参见 man 5 tmpfiles.d
。
13.6.2 系统日志 #
第 13.6.8 节 “调试服务” 介绍如何查看给定服务的日志讯息。但可显示的日志讯息并不仅限于服务日志。您还可以访问和查询 systemd
写入的完整日志,即所谓的“日记”。使用 journalctl
命令可显示完整的日志讯息,从最早的项开始。有关诸如应用过滤器或更改输出格式的选项,请参考 man 1 journalctl
。
13.6.3 快照 #
您可以使用 isolate
子命令将 systemd
的当前状态保存到指定快照中,并在日后还原到该状态。此功能在测试服务或自定义目标时非常有用,因为它可让您随时回到定义的状态。快照仅在当前会话中可用,重引导时将自动删除。快照名称必须以 .snapshot
结尾。
- 创建快照
tux >
sudo
systemctl snapshot MY_SNAPSHOT.snapshot- 删除快照
tux >
sudo
systemctl delete MY_SNAPSHOT.snapshot- 查看快照
tux >
sudo
systemctl show MY_SNAPSHOT.snapshot- 激活快照
tux >
sudo
systemctl isolate MY_SNAPSHOT.snapshot
13.6.4 装载内核模块 #
通过使用 systemd
以及 /etc/modules-load.d
中的配置文件,可以在引导时自动装载内核模块。该文件应该命名为 MODULE.conf 并包含以下内容:
# load module MODULE at boot time MODULE
如果某个包安装了用于装载内核模块的配置文件,该文件将安装到 /usr/lib/modules-load.d
。如果存在两个同名的配置文件,将优先使用 /etc/modules-load.d
中的那个配置文件。
有关详细信息,请参见 modules-load.d(5)
手册页。
13.6.5 装载服务之前执行必要操作 #
使用 System V init 时,需要在装载服务之前执行的操作必须在 /etc/init.d/before.local
中指定。systemd 不再支持此过程。如果您需要在启动服务之前执行操作,请执行以下步骤:
- 装载内核模块
在
/etc/modules-load.d
目录中创建一个 drop-in 文件(有关语法,请参见man modules-load.d
)- 创建文件或目录、清理目录、更改所有权
在
/etc/tmpfiles.d
中创建一个 drop-in 文件(有关语法,请参见man tmpfiles.d
)- 其它任务
基于下面的模板创建一个系统服务文件,例如
/etc/systemd/system/before.service
:[Unit] Before=NAME OF THE SERVICE YOU WANT THIS SERVICE TO BE STARTED BEFORE [Service] Type=oneshot RemainAfterExit=true ExecStart=YOUR_COMMAND # beware, executable is run directly, not through a shell, check the man pages # systemd.service and systemd.unit for full syntax [Install] # target in which to start the service WantedBy=multi-user.target #WantedBy=graphical.target
创建服务文件后,应运行以下命令(以
root
身份):tux >
sudo
systemctl daemon-reloadtux >
sudo
systemctl enable before每次修改服务文件时,都需要运行:
tux >
sudo
systemctl daemon-reload
13.6.6 内核控制组 (cgroups) #
在传统 System V init 系统上,并不总是能够明确地将某个进程指派给生成它的服务。一些服务(例如 Apache)会生成大量第三方进程(例如 CGI 或 Java 进程),这些进程本身又会生成更多进程。这使得明确指派变得非常困难,甚至无法做到。另外,服务可能不会正常终止,导致部分子服务仍保持运行状态。
systemd 通过将每个服务放入它自己的 cgroup 中,解决了这个问题。cgroups 是一项内核功能,允许将进程及其所有子进程聚合到分层组织的组中。systemd 根据每个 cgroup 的服务名称命名各 cgroup。因为非特权进程不允许“离开”它的 cgroup,这提供了一种行之有效的方式,可通过服务名称来标记该服务生成的所有进程。
要列出属于某个服务的所有进程,请使用命令 systemd-cgls
。结果将如下所示(已精简):
root #
systemd-cgls --no-pager
├─1 /usr/lib/systemd/systemd --switched-root --system --deserialize 20
├─user.slice
│ └─user-1000.slice
│ ├─session-102.scope
│ │ ├─12426 gdm-session-worker [pam/gdm-password]
│ │ ├─15831 gdm-session-worker [pam/gdm-password]
│ │ ├─15839 gdm-session-worker [pam/gdm-password]
│ │ ├─15858 /usr/lib/gnome-terminal-server
[...]
└─system.slice
├─systemd-hostnamed.service
│ └─17616 /usr/lib/systemd/systemd-hostnamed
├─cron.service
│ └─1689 /usr/sbin/cron -n
├─postfix.service
│ ├─ 1676 /usr/lib/postfix/master -w
│ ├─ 1679 qmgr -l -t fifo -u
│ └─15590 pickup -l -t fifo -u
├─sshd.service
│ └─1436 /usr/sbin/sshd -D
[...]
有关 cgroups 的更多信息,请参见Book “System Analysis and Tuning Guide”, Chapter 9 “Kernel Control Groups”。
13.6.7 终止服务(发送信号) #
如第 13.6.6 节 “内核控制组 (cgroups) ”中所述,在 System V init 系统中,并不总是能够将某个进程指派给其父服务。这导致终止服务及其所有子进程变得很困难。尚未终止的子进程将一直保持为僵停状态。
systemd 将每个服务限定在某个 cgroup 中的概念使您可以明确识别一个服务的所有子进程,从而向这些进程中的每一个发送信号。您可使用 systemctl kill
向服务发送信号。有关可用信号的列表,请参考 man 7 signals
。
- 向服务发送
SIGTERM
SIGTERM
是发送的默认信号。tux >
sudo
systemctl kill MY_SERVICE- 向服务发送 SIGNAL
可使用
-s
选项指定应该发送的信号。tux >
sudo
systemctl kill -s SIGNAL MY_SERVICE- 选择进程
默认情况下,
kill
命令会向指定 cgroup 的所有
进程发送信号。您可以将发送范围限制为control
或main
进程。后一个选项可用于通过发送SIGHUP
强制服务重新装载其配置的情况:tux >
sudo
systemctl kill -s SIGHUP --kill-who=main MY_SERVICE
D-Bus 服务是 systemd 客户端与作为 pid 1 运行的 systemd 管理器之间进行通讯的讯息总线。虽然 dbus
是个独立的守护程序,但它也是初始化基础架构的组成部分。
在正在运行的系统中终止或重启动 dbus
的效果类似于尝试终止或重启动 pid 1。此操作将中断 systemd 客户端与服务器间的通讯,并使大部分 systemd 功能不可用。
因此,不建议也不支持终止或重启动 dbus
。
13.6.8 调试服务 #
默认情况下,systemd 的输出不会太详细。如果服务启动成功,则不会产生任何输出。如果服务启动失败,则会显示简短的错误讯息。不过,systemctl status
提供了调试服务的启动和操作的途径。
systemd 附带了自己的日志记录机制(“日志”)来记录系统讯息。这可让您一并显示服务讯息与状态讯息。status
命令的工作方式与 tail
相似,也可以采用不同的格式显示日志讯息,是一个功能强大的调试工具。
- 显示服务启动失败讯息
每当服务启动失败时,使用
systemctl status MY_SERVICE
可获得详细的错误讯息:root #
systemctl start apache2 Job failed. See system journal and 'systemctl status' for details.root #
systemctl status apache2 Loaded: loaded (/usr/lib/systemd/system/apache2.service; disabled) Active: failed (Result: exit-code) since Mon, 04 Apr 2018 16:52:26 +0200; 29s ago Process: 3088 ExecStart=/usr/sbin/start_apache2 -D SYSTEMD -k start (code=exited, status=1/FAILURE) CGroup: name=systemd:/system/apache2.service Apr 04 16:52:26 g144 start_apache2[3088]: httpd2-prefork: Syntax error on line 205 of /etc/apache2/httpd.conf: Syntax error on li...alHost>- 显示最后 N 条服务讯息
status
子命令的默认行为是显示服务发出的最后 10 条讯息。若要更改要显示的讯息数目,请使用--lines=N
参数:tux >
sudo
systemctl status chronydtux >
sudo
systemctl --lines=20 status chronyd- 以附加模式显示服务讯息
要显示服务讯息的“实时流”,请使用
--follow
选项,效果与tail
-f
相似:tux >
sudo
systemctl --follow status chronyd- 讯息输出格式
--output=模式
参数可让您更改服务讯息的输出格式。最重要的可用模式包括:short
默认格式。显示日志讯息,以及用户能看懂的时戳。
verbose
所有字段的完整输出。
cat
精简输出,不含时戳。
13.7 更多信息 #
有关 systemd 的更多信息,请参考下列联机资源:
- 主页
- systemd for Administrators(面向管理员的 systemd)
作者:Lennart Pöttering,一位 systemd 作家,他撰写了一系列博客(写本章时为 2013 年)。它们可在 http://0pointer.de/blog/projects 找到。
第 III 部分 系统 #
- 14 64 位系统环境中的 32 位和 64 位应用程序
SUSE® Linux Enterprise Desktop 可用于 64 位平台。开发商尚未将所有 32 位应用程序移植到 64 位系统。但是,SUSE Linux Enterprise Desktop 支持在 64 位系统环境中使用 32 位应用程序。本章简要概述了如何在 64 位 SUSE Linux Enterprise Desktop 平台上实现 32 位支持。
- 15
journalctl
:查询systemd
日记 systemd
在取代 SUSE Linux Enterprise 12 中的传统 init 脚本时(参见第 13 章 “systemd
守护程序”),引入了自身的称为日记的日志记录系统。由于所有系统事件都将写入到日记中,因此,用户不再需要运行基于syslog
的服务。- 16
update-alternatives
:管理命令和文件的多个版本 系统上往往会安装同一个工具的多个版本。为了让管理员可以选择,以及能一起安装和使用多个不同的版本,备选项系统提供了以一致的方式管理此类版本的功能。
- 17 基本联网知识
Linux 提供集成进各类网络结构中所需的联网工具和功能。可以通过 YaST 配置使用网络卡进行的网络访问。也可以手动进行配置。在本章中,仅描述基础机制和相关网络配置文件。
- 18 打印机操作
SUSE® Linux Enterprise Desktop 支持使用多种类型的打印机进行打印,其中包括远程网络打印机。可以手动或使用 YaST 配置打印机。有关配置描述,请参见Book “Deployment Guide”, Chapter 15 “Setting Up Hardware Components with YaST”, Section 15.3 “Setting Up a Printer”。启动和管理打印任务时既可以使用图形实用程序,也可以使用命令行实用程序。如果打印机未能按预期正常工作,请参见第 18.8 节 “查错”。
- 19 图形用户界面。
SUSE Linux Enterprise Desktop 包含 X.org 服务器、Wayland 和 GNOME 桌面。本章介绍用于所有用户的图形用户界面配置。
- 20 使用 FUSE 访问文件系统
FUSE 是用户空间中的文件系统 (file system in user space) 的缩写。这表示您可以将文件系统作为非特权用户配置和装入。通常,只有
root
用户才能执行此任务。FUSE 自身是一个内核模块。它与插件组合,允许您扩展 FUSE 以访问几乎所有文件系统,如远程 SSH 连接、ISO 映像等。- 21 管理内核模块
虽然 Linux 属于单内核,但可通过内核模块加以扩展。这些特殊对象可以插入到内核中,并可按需去除。就实际角度而言,内核模块使添加和去除内核本身未包含的驱动程序和接口成为现实。Linux 提供了若干用于管理内核模块的命令。
- 22 使用
udev
进行动态内核设备管理 内核几乎可以添加或删除运行系统中的任何设备。设备状态的更改(无论插入还是移除设备)需要传播给用户空间。插入及识别设备后需要对其进行配置。某个设备已识别状态的任何更改都需要通知给此设备的用户。
udev
可提供所需的基础结构来动态维护/dev
目录中的设备节点文件和符号链接。udev
规则提供了将外部工具插入内核设备事件处理的方式。因而,您可以通过添加在内核设备处理过程中执行的特定脚本,来自定义udev
设备处理方式,或者可以在设备处理期间请求并导入其他数据进行评估。- 23 使用 kGraft 在线增补 Linux 内核
本文档介绍 kGraft 在线增补技术的基本原理,并提供 SLE Live Patching 服务的使用准则。
- 24 特别的系统功能组件
本章首先提供有关各种软件包、虚拟控制台和键盘布局的信息。讨论诸如
bash
、cron
和logrotate
等软件组件,因为在最后的发行周期中已对这些组件进行了更改或增强。即使这些组件很小或者被认为不太重要,用户也应该更改它们的默认行为,因为这些组件往往与系统密切相关。本章的最后是有关语言和国家/地区特定设置(I18N 和 L10N)的内容。- 25 使用 NetworkManager
NetworkManager 是用于便携式计算机和其他可移动计算机的理想解决方案。它支持网络连接的顶级加密类型和标准,包括 802.1x 保护的网络的连接。802.1X 是“基于端口的网络访问控制的本地和城域网 IEEE 标准”。使用 NetworkManager,您在外出时就不必顾虑网络接口的配置,以及在有线或无线网络之间切换的问题。NetworkManager 可自动连接到已知无线网络或并行管理多个网络连接 - 然后将最快的连接用作默认连接。而且,您还可手动在可用网络之间切换,并使用系统盘中的小程序管理网络连接。
- 26 电源管理
电源管理对于便携式计算机特别重要,但对于其他系统也是有用的。ACPI(高级配置和电源接口)在所有通用计算机(便携式计算机、台式机和服务器)上都可用。电源管理技术需要合适的硬件和 BIOS 例程。大多数便携式计算机、许多目前的台式机和服务器都符合这些要求。还可以通过控制 CPU 频率调节以达到省电或降低噪音的目的。
- 27 VM Guest
本章包含有关在虚拟机中使用 SUSE Linux Enterprise Desktop 的附加信息。
- 28 持久内存
本章包含有关使用配备非易失性主内存的 SUSE Linux Enterprise Desktop 的附加信息。此类内存称为持久内存,由一个或多个 NVDIMM 构成。
14 64 位系统环境中的 32 位和 64 位应用程序 #
SUSE® Linux Enterprise Desktop 可用于 64 位平台。开发商尚未将所有 32 位应用程序移植到 64 位系统。但是,SUSE Linux Enterprise Desktop 支持在 64 位系统环境中使用 32 位应用程序。本章简要概述了如何在 64 位 SUSE Linux Enterprise Desktop 平台上实现 32 位支持。
用于 64 位平台 AMD64 和 Intel 64 的 SUSE Linux Enterprise Desktop 可让现有的 32 位应用程序“无需额外配置”即可在 64 位环境中运行。这种支持意味着您可以继续使用所需的 32 位应用程序,而无需等待对应的 64 位端口可用。
SUSE Linux Enterprise Desktop 不支持编译 32 位应用程序。它只为 32 位二进制文件提供运行时支持。
14.1 运行时支持 #
如果某个应用程序同时适用于 32 位和 64 位环境,安装这两个版本可能会导致出现问题。在这种情况下,请决定要安装哪一个版本,以避免潜在的运行时错误。
此规则的一个例外是 PAM(可插入身份验证模块)。SUSE Linux Enterprise Desktop 在身份验证过程中使用 PAM 充当用户和应用程序之间的中间层。在同时运行了 32 位应用程序的 64 位操作系统上,请始终安装 32 位和 64 位 PAM 版本。
每个应用程序都需要一系列的库才能正常执行。不巧的是,这些库的 32 位和 64 位版本的名称是相同的。必须通过另一种方法对它们加以区分。
为了与 32 位版本保持兼容,64 位和 32 位库将储存在同一位置。在 32 位和 64 位环境中,libc.so.6
的 32 位版本都位于 /lib/libc.so.6
下。
所有 64 位库和对象文件都位于名为 lib64
的目录中。以往通常出现在 /lib
和 /usr/lib
下的 64 位对象文件现在位于 /lib64
和 /usr/lib64
下。这意味着 /lib
和 /usr/lib
下有储存 32 位库的空间,因此两个版本的文件名都可以保持不变。
如果 /lib
下的 32 位子目录的数据内容与字词大小无关,则不会移动这些子目录。此方案符合 LSB(Linux 标准库)和 FHS(文件系统层次标准)。
14.2 内核规范 #
适用于 AMD 64/Intel 64 的 64 位内核提供了 64 位和 32 位两种内核 ABI(应用程序二进制接口)。后者与对应的 32 位内核的 ABI 相同。这意味着,32 位和 64 位应用程序与 64 位内核的通讯方式是相同的。
针对 64 位内核的 32 位系统调用仿真不支持系统程序使用的某些 API。这取决于平台。因此,必须对 lspci
之类的一些应用程序进行编译。
64 位内核只能装载 64 位内核模块。必须专门为 64 位内核编译 64 位模块。无法将 32 位内核模块与 64 位内核搭配使用。
某些应用程序需要单独的内核可装载模块。如果您想要在 64 位系统环境中使用 32 位应用程序,请与应用程序供应商和 SUSE 联系。确保 64 位版本的内核可装载模块以及 32 位编译版本的内核 API 适用于此模块。
15 journalctl
:查询 systemd
日记 #
systemd
在取代 SUSE Linux Enterprise 12 中的传统 init 脚本时(参见第 13 章 “systemd
守护程序”),引入了自身的称为日记的日志记录系统。由于所有系统事件都将写入到日记中,因此,用户不再需要运行基于 syslog
的服务。
日记本身是 systemd
管理的系统服务,全名为 systemd-journald.service
。它会根据从内核、用户进程、标准输入和系统服务错误收到的日志记录信息,维护结构化的索引日记,并以此方式来收集和储存日志记录数据。systemd-journald
服务默认处于启用状态。
tux >
sudo
systemctl status systemd-journald systemd-journald.service - Journal Service Loaded: loaded (/usr/lib/systemd/system/systemd-journald.service; static) Active: active (running) since Mon 2014-05-26 08:36:59 EDT; 3 days ago Docs: man:systemd-journald.service(8) man:journald.conf(5) Main PID: 413 (systemd-journal) Status: "Processing requests..." CGroup: /system.slice/systemd-journald.service └─413 /usr/lib/systemd/systemd-journald [...]
15.1 将日记设为永久 #
默认情况下,日记在 /run/log/journal/
中储存日志数据。由于 /run/
目录具有易失本性,因此,在重引导时会丢失日志数据。要永久保存日志数据,/var/log/journal/
目录必须存在且具有正确的所有权和权限,使 systemd-journald 服务能够储存其数据。systemd
将为您创建该目录,如果您执行以下操作,它将会切换到永久日志记录:
以
root
身份打开/etc/systemd/journald.conf
进行编辑。root #
vi /etc/systemd/journald.conf将包含
Storage=
的行取消注释,并将它更改为[...] [Journal] Storage=persistent #Compress=yes [...]
保存该文件,然后重启动 systemd-journald:
root #
systemctl restart systemd-journald
15.2 journalctl
的有用开关 #
本节介绍了一些可用来增强 journalctl
默认行为的常见有用选项。journalctl
手册页 man 1 journalctl
中介绍了所有开关。
要显示与特定可执行文件相关的所有日记讯息,请指定该可执行文件的完整路径:
tux >
sudo
journalctl /usr/lib/systemd/systemd
- -f
仅显示最近的日记讯息,另外,在将新的日志项添加到日记时会列显这些新项。
- -e
列显讯息并跳转到日记末尾,以便在页导航中显示最新的项。
- -r
以倒序列显日记讯息,让最新的项列在最前面。
- -k
仅显示内核讯息。这等效于字段匹配
_TRANSPORT=kernel
(参见第 15.3.3 节 “根据字段过滤”)。- -u
仅显示指定
systemd
单元的讯息。这等效于字段匹配_SYSTEMD_UNIT=UNIT
(参见 第 15.3.3 节 “根据字段过滤”)。tux >
sudo
journalctl -u apache2 [...] Jun 03 10:07:11 pinkiepie systemd[1]: Starting The Apache Webserver... Jun 03 10:07:12 pinkiepie systemd[1]: Started The Apache Webserver.
15.3 过滤日记输出 #
如果不结合任何开关调用 journalctl
,它将显示日记的整个内容,最旧的项列在最前面。您可按特定的开关和字段过滤输出。
15.3.1 根据引导编号过滤 #
journalctl
可以根据特定的系统引导过滤讯息。要列出所有可用引导,请运行
tux >
sudo
journalctl --list-boots -1 097ed2cd99124a2391d2cffab1b566f0 Mon 2014-05-26 08:36:56 EDT—Fri 2014-05-30 05:33:44 EDT 0 156019a44a774a0bb0148a92df4af81b Fri 2014-05-30 05:34:09 EDT—Fri 2014-05-30 06:15:01 EDT
第一列列出引导偏移:0
表示当前引导,-1
表示上一次引导,-2
表示再上一次引导,以此类推。第二列包含引导 ID,其后是特定引导的限制时间戳。
显示当前引导中的所有讯息:
tux >
sudo
journalctl -b
如果需要查看来自前一引导的日记讯息,请加一个偏移参数。下面的示例将输出前一引导的讯息:
tux >
sudo
journalctl -b -1
另一种方法是根据引导 ID 列出引导讯息。要实现此目的,请使用 _BOOT_ID 字段:
tux >
sudo
journalctl _BOOT_ID=156019a44a774a0bb0148a92df4af81b
15.3.2 根据时间间隔过滤 #
您可通过指定开始日期和/或结束日期来过滤 journalctl
的输出。日期规范应采用类似于“2014-06-30 9:17:16”的格式。如果省略时间部分,则会假设为午夜。如果省略秒,则会假设为“:00”。如果省略日期部分,则会假设为当日。您也可以不采用数字表示,而是指定关键字“yesterday”、“today”或“tomorrow”。它们表示当日前一天、当日或者当日后一天的午夜。如果指定“now”,则表示当前时间。您还可以指定以 -
或 +
为前缀的相对时间,分别表示当前时间之前或之后的特定时间。
仅显示从现在开始生成的新讯息,并持续更新输出:
tux >
sudo
journalctl --since "now" -f
显示从昨天午夜到 3:20AM 的所有讯息:
tux >
sudo
journalctl --since "today" --until "3:20"
15.3.3 根据字段过滤 #
您可以按特定的字段过滤日记输出。要匹配的字段语法为 FIELD_NAME=MATCHED_VALUE
,例如 _SYSTEMD_UNIT=httpd.service
。您可以在单个查询中指定多个匹配条件,以进一步过滤输出讯息。有关默认字段的列表,请参见 man 7 systemd.journal-fields
。
显示特定进程 ID 生成的讯息:
tux >
sudo
journalctl _PID=1039
显示属于特定用户 ID 的讯息:
# journalctl _UID=1000
显示来自内核环缓冲区的讯息(与 dmesg
的生成结果相同):
tux >
sudo
journalctl _TRANSPORT=kernel
显示来自服务的标准输出或错误输出的讯息:
tux >
sudo
journalctl _TRANSPORT=stdout
仅显示指定服务生成的讯息:
tux >
sudo
journalctl _SYSTEMD_UNIT=avahi-daemon.service
如果指定了两个不同的字段,则仅显示同时与两个表达式匹配的项:
tux >
sudo
journalctl _SYSTEMD_UNIT=avahi-daemon.service _PID=1488
如果两个匹配条件引用了相同的字段,则显示与两个表达式中任意一个匹配的所有项:
tux >
sudo
journalctl _SYSTEMD_UNIT=avahi-daemon.service _SYSTEMD_UNIT=dbus.service
您可以使用“+”分隔符将两个表达式组合成一个逻辑“OR”。以下示例将显示来自进程 ID 为 1480 的 Avahi 服务进程的所有讯息,以及来自 D-Bus 服务的所有讯息:
tux >
sudo
journalctl _SYSTEMD_UNIT=avahi-daemon.service _PID=1480 + _SYSTEMD_UNIT=dbus.service
15.4 调查 systemd
错误 #
本节将介绍一个简单的示例,演示如何找出并修复在 apache2
启动期间 systemd
报告的错误。
尝试启动 apache2 服务:
# systemctl start apache2 Job for apache2.service failed. See 'systemctl status apache2' and 'journalctl -xn' for details.
我们来看看该服务的状态如何:
tux >
sudo
systemctl status apache2 apache2.service - The Apache Webserver Loaded: loaded (/usr/lib/systemd/system/apache2.service; disabled) Active: failed (Result: exit-code) since Tue 2014-06-03 11:08:13 CEST; 7min ago Process: 11026 ExecStop=/usr/sbin/start_apache2 -D SYSTEMD -DFOREGROUND \ -k graceful-stop (code=exited, status=1/FAILURE)导致错误的进程 ID 为 11026。
显示与进程 ID 11026 相关的详细讯息:
tux >
sudo
journalctl -o verbose _PID=11026 [...] MESSAGE=AH00526: Syntax error on line 6 of /etc/apache2/default-server.conf: [...] MESSAGE=Invalid command 'DocumenttRoot', perhaps misspelled or defined by a module [...]修复
/etc/apache2/default-server.conf
中的拼写错误,启动 apache2 服务,然后列显其状态:tux >
sudo
systemctl start apache2 && systemctl status apache2 apache2.service - The Apache Webserver Loaded: loaded (/usr/lib/systemd/system/apache2.service; disabled) Active: active (running) since Tue 2014-06-03 11:26:24 CEST; 4ms ago Process: 11026 ExecStop=/usr/sbin/start_apache2 -D SYSTEMD -DFOREGROUND -k graceful-stop (code=exited, status=1/FAILURE) Main PID: 11263 (httpd2-prefork) Status: "Processing requests..." CGroup: /system.slice/apache2.service ├─11263 /usr/sbin/httpd2-prefork -f /etc/apache2/httpd.conf -D [...] ├─11280 /usr/sbin/httpd2-prefork -f /etc/apache2/httpd.conf -D [...] ├─11281 /usr/sbin/httpd2-prefork -f /etc/apache2/httpd.conf -D [...] ├─11282 /usr/sbin/httpd2-prefork -f /etc/apache2/httpd.conf -D [...] ├─11283 /usr/sbin/httpd2-prefork -f /etc/apache2/httpd.conf -D [...] └─11285 /usr/sbin/httpd2-prefork -f /etc/apache2/httpd.conf -D [...]
15.5 Journald 配置 #
通过修改 /etc/systemd/journald.conf
可调整 systemd-journald 服务的行为。本节只介绍了基本的选项设置。有关完整的文件描述,请参见 man 5 journald.conf
。请注意,要使更改生效,需要使用以下命令重启动日记
tux >
sudo
systemctl restart systemd-journald
15.5.1 更改日记大小限制 #
如果将日记日志数据保存到永久位置(参见第 15.1 节 “将日记设为永久”),这些数据最多会占用 /var/log/journal
所在文件系统空间的 10%。例如,如果 /var/log/journal
位于一个 30 GB /var
的分区中,则日记最多会占用 3 GB 磁盘空间。要更改此限制,请更改(并取消注释)SystemMaxUse
选项:
SystemMaxUse=50M
15.5.2 将日记转发到 /dev/ttyX
#
您可以将日记转发到终端设备,以便在首选的终端屏幕(例如 /dev/tty12
)上了解相关的系统讯息。将以下 journald 选项更改为
ForwardToConsole=yes TTYPath=/dev/tty12
15.5.3 将日记转发到 Syslog 工具 #
Journald 与传统的 syslog 实施(例如 rsyslog
)向后兼容。请确保满足以下条件:
已安装 rsyslog。
tux >
sudo
rpm -q rsyslog rsyslog-7.4.8-2.16.x86_64已启用 rsyslog 服务。
tux >
sudo
systemctl is-enabled rsyslog enabled已在
/etc/systemd/journald.conf
中启用转发到 syslog 设置。ForwardToSyslog=yes
15.6 使用 YaST 过滤 systemd
日记 #
过滤 systemd 日记的简单方法(无需处理 journalctl 语法)是使用 YaST 日记模块。使用 sudo zypper in yast2-journal
安装该模块后,请在 YaST 中选择 › 启动该模块。也可以在命令行中输入 sudo yast2 journal
来启动该模块。
模块将在表中显示日志项。使用顶部的搜索框可以搜索包含特定字符的项,这类似于使用 grep
。要按日期和时间、单位、文件或优先级过滤项,请单击 ,然后设置相应的选项。
15.7 在 GNOME 中查看日志 #
您可以使用 GNOME 日志来查看日记。可从应用程序菜单启动它。要查看系统日志讯息,需要以 root 身份运行它,例如使用 xdg-su gnome-logs
。按 Alt–F2 时可执行此命令。
16 update-alternatives
:管理命令和文件的多个版本 #
系统上往往会安装同一个工具的多个版本。为了让管理员可以选择,以及能一起安装和使用多个不同的版本,备选项系统提供了以一致的方式管理此类版本的功能。
16.1 概述 #
在 SUSE Linux Enterprise Desktop 上,有些程序执行的是相同或类似的任务。例如,如果系统上既安装了 Java 1.7,也安装了 Java 1.8,则会从 RPM 包中调用备选项系统脚本 (update-alternatives
)。备选项系统默认将参照版本 1.8:版本越高,优先级就越高。不过,管理员可以更改该默认设置,并可将通用名称指向版本 1.7。
本章使用了下列术语:
- 管理目录
默认的
/var/lib/rpm/alternatives
目录,其中包含有关备选项当前状态的信息。- 备选项
文件系统中某个特定文件的名称,可使用备选项系统通过通用名称访问。
- 备选项目录
包含符号链接的默认
/etc/alternatives
目录。- 通用名称
该名称(例如
/usr/bin/edit
)参照可通过备选项系统使用的多个文件中的一个。- 链接组
一组相关的符号链接,可作为一个组更新。
- 主链接
链接组中用于确定如何配置组中其他链接的链接。
- 从属链接
链接组中受主链接控制的链接。
- 符号链接 (Symlink)
在同一文件系统中作为另一个文件的参照的文件。备选项系统使用备选项目录中的符号链接在一个文件的各个版本之间切换。
管理员可通过
update-alternatives
命令修改备选项目录中的符号链接。
备选项系统提供 update-alternatives
命令供您创建、去除、维护和显示有关符号链接的信息。虽然这些符号链接通常是指向命令,但它们也可以指向 JAR 存档、手册页及其他文件。本章中的示例使用了命令和手册页,但它们也适用于其他文件类型。
备选项系统使用备选项目录来收集指向可能的备选项的链接。安装包含备选项的新包时,就会将新的备选项添加至系统。是否将新包的备选项选为默认值取决于它的优先级和设置的模式。一般而言,版本较高的包优先级也较高。备选项系统可以在两种模式下工作:
自动模式: 在此模式下,备选项系统会确保组中的链接指向适合组且优先级最高的备选项。
手动模式: 在此模式下,备选项系统不会对系统管理员的设置进行任何更改。
例如,在备选项系统中,java
命令具有以下链接层次结构:
16.2 使用案例 #
默认从 RPM 包中调用 update-alternatives
脚本。安装或去除一个包时,该脚本会处理该包所有的符号链接。不过,您可以从命令行中手动运行该脚本,以便:
显示通用名称的当前备选项。
更改备选项的默认值。
为备选项创建一组相关的文件。
16.3 获取备选项的概览 #
要检索所有已配置备选项的名称,请使用:
tux >
ls /var/lib/alternatives
要获取所有已配置备选项的概览及其值,请使用
tux >
sudo
update-alternatives --get-selections
asadmin auto /usr/bin/asadmin-2.7 awk auto /usr/bin/gawk chardetect auto /usr/bin/chardetect-3.6 dbus-launch auto /usr/bin/dbus-launch.x11 default-displaymanager auto /usr/lib/X11/displaymanagers/gdm [...]
16.4 查看有关特定备选项的细节 #
检查备选项最简单的方法就是查看命令的符号链接。例如,如果您想知道 java
命令参照的是什么,请使用以下命令:
tux >
readlink --canonicalize /usr/bin/java
/usr/lib64/jvm/jre-10-openjdk/bin/java
如果您看到相同的路径(在本例中为 /usr/bin/java
),则此命令没有备选项。
要查看全部的备选项(包括从属链接),请使用 --display
选项:
tux >
sudo
update-alternatives --display java
java - auto mode link best version is /usr/lib64/jvm/jre-1.8.0-openjdk/bin/java link currently points to /usr/lib64/jvm/jre-1.8.0-openjdk/bin/java link java is /usr/bin/java slave java.1.gz is /usr/share/man/man1/java.1.gz slave jre is /usr/lib64/jvm/jre slave jre_exports is /usr/lib64/jvm-exports/jre slave keytool is /usr/bin/keytool slave keytool.1.gz is /usr/share/man/man1/keytool.1.gz slave orbd is /usr/bin/orbd slave orbd.1.gz is /usr/share/man/man1/orbd.1.gz [...]
16.5 设置备选项的默认版本 #
/usr/bin
中的命令默认会参照优先级最高的备选项目录。例如,java
命令默认会显示下面的版本号:
tux >
java -version
openjdk version "10.0.1" 2018-04-17 OpenJDK Runtime Environment (build 10.0.1+10-suse-lp150.1.11-x8664) OpenJDK 64-Bit Server VM (build 10.0.1+10-suse-lp150.1.11-x8664, mixed mode)
要将默认 java
命令更改为参照先前的版本,请运行:
tux >
sudo
update-alternatives --config java
root's password: There are 2 choices for the alternative java (providing /usr/bin/java). Selection Path Priority Status ------------------------------------------------------------ * 0 /usr/lib64/jvm/jre-10-openjdk/bin/java 2005 auto mode 1 /usr/lib64/jvm/jre-1.8.0-openjdk/bin/java 1805 manual mode 2 /usr/lib64/jvm/jre-10-openjdk/bin/java 2005 manual mode 3 /usr/lib64/jvm/jre-11-openjdk/bin/java 0 manual mode Press <enter> to keep the current choice[*], or type selection number:
根据您的系统和安装的版本,具体的 Java 版本号会有所不同。选择 1
之后,java
会显示下面的版本号:
tux >
java -version
java version "1.8.0_171" OpenJDK Runtime Environment (IcedTea 3.8.0) (build 1.8.0_171-b11 suse-lp150.2.3.1-x86_64) OpenJDK 64-Bit Server VM (build 25.171-b11, mixed mode)
另外,请记住以下几点:
在手动模式下安装另一个 Java 版本时,备选项系统既不会更改链接,也不会更改通用名称。
在自动模式下安装另一个 Java 版本时,备选项系统会更改 Java 主链接及所有从属链接(如第 16.4 节 “查看有关特定备选项的细节”中所示)。要检查主/从关系,请使用:
tux >
sudo
update-alternatives --display java
16.6 安装自定义备选项 #
本节介绍如何在系统上设置自定义备选项。示例做了以下假设:
有两个具有类似功能的脚本:
foo-2
和foo-3
。这些脚本储存在
/usr/local/bin
目录中,以免与/usr/bin
中的系统工具产生任何冲突。有一个主链接
foo
指向foo-2
或foo-3
。
要在您的系统上提供备选项,请执行以下步骤:
将您的脚本复制到
/usr/local/bin
目录中。让脚本可执行:
tux >
sudo
chmod +x /usr/local/bin/foo-{2,3}
针对两个脚本运行
update-alternatives
:tux >
sudo
update-alternatives --install \ /usr/local/bin/foo 1\ foo 2\ /usr/local/bin/foo-2 3\ 200 4tux >
sudo
update-alternatives --install \ /usr/local/bin/foo 1\ foo 2\ /usr/local/bin/foo-3 3\ 300 4--install
后面的选项含义如下:检查主链接:
tux >
sudo
update-alternatives --display foo
foo - auto mode link best version is /usr/local/bin/foo-3 link currently points to /usr/local/bin/foo-3 link foo is /usr/local/bin/foo /usr/local/bin/foo-2 - priority 200 /usr/local/bin/foo-3 - priority 300
完成所述步骤后,便可以使用主链接 /usr/local/bin/foo
了。
如果需要,可以安装其他的备选项。要去除备选项,请使用以下命令:
tux >
sudo
update-alternatives --remove foo /usr/local/bin/foo-2
去除此脚本之后,foo 组的备选项系统看上去如下所示:
tux >
sudo
update-alternatives --display foo
foo - auto mode link best version is /usr/local/bin/foo-3 link currently points to /usr/local/bin/foo-3 link foo is /usr/local/bin/foo /usr/local/bin/foo-3 - priority 300
16.7 定义依赖备选项 #
如果您有备选项,则仅凭脚本本身不足以完成任务。大部分命令都不是完全独立的:它们通常随附其他文件,例如扩展、配置或手册页。要创建依赖于主链接的备选项,请使用从属备选项。
我们假设要扩展第 16.6 节 “安装自定义备选项”中的示例,并提供手册页和配置文件:
两个手册页(
foo-2.1.gz
和foo-3.1.gz
)储存在/usr/local/man/man1
目录中。两个配置文件(
foo-2.conf
和foo-3.conf
)储存在/etc
中。
请执行以下步骤将其他文件添加至备选项中:
将配置文件复制到
/etc
中:tux >
sudo
cp foo-{2,3}.conf /etc
将手册页复制到
/usr/local/man/man1
目录中:tux >
sudo
cp foo-{2,3}.1.gz /usr/local/man/man1/
使用
--slave
选项将从属链接添加至主脚本:tux >
sudo
update-alternatives --install \ /usr/local/bin/foo foo /usr/local/bin/foo-2 200 \ --slave /usr/local/man/man1/foo.1.gz \ foo.1.gz \ /usr/local/man/man1/foo-2.1.gz \ --slave /etc/foo.conf \ foo.conf \ /etc/foo-2.conf
tux >
sudo
update-alternatives --install \ /usr/local/bin/foo foo /usr/local/bin/foo-3 300 \ --slave /usr/local/man/man1/foo.1.gz \ foo.1.gz \ /usr/local/man/man1/foo-3.1.gz \ --slave /etc/foo.conf \ foo.conf \ /etc/foo-3.conf
检查主链接:
foo - auto mode link best version is /usr/local/bin/foo-3 link currently points to /usr/local/bin/foo-3 link foo is /usr/local/bin/foo slave foo.1.gz is /usr/local/man/man1/foo.1.gz slave foo.conf is /etc/foo.conf /usr/local/bin/foo-2 - priority 200 slave foo.1.gz: /usr/local/man/man1/foo-2.1.gz slave foo.conf: /etc/foo-2.conf /usr/local/bin/foo-3 - priority 300 slave foo.1.gz: /usr/local/man/man1/foo-3.1.gz slave foo.conf: /etc/foo-3.conf
如果您使用 update-alternatives --config foo
将链接更改为 foo-2
,则所有从属链接也会随之更改。
17 基本联网知识 #
Linux 提供集成进各类网络结构中所需的联网工具和功能。可以通过 YaST 配置使用网络卡进行的网络访问。也可以手动进行配置。在本章中,仅描述基础机制和相关网络配置文件。
Linux 和其他 Unix 操作系统均使用 TCP/IP 协议。该协议不是单个网络协议,而是提供多种服务的一系列网络协议。TCP/IP 系列协议中的若干协议中所列的协议专用于在两台计算机之间通过 TCP/IP 交换数据。由 TCP/IP 连接而成的网络构成了全球网络,也称作“因特网”。
RFC 指注释请求 (Request for Comments)。RFC 由一些文档组成,用来描述各种因特网协议和操作系统及其应用程序的实施过程。RFC 文档用来描述如何设置因特网协议。有关 RFC 的更多信息,请参见 http://www.ietf.org/rfc.html。
- TCP
传送控制协议:面向连接的安全协议。要传输的数据首先由应用程序作为数据流发送,然后由操作系统转换为相应的格式。数据到达目标主机上的相应应用程序时采用最初发送时的原始数据流格式。TCP 确定在传输过程中是否有任何数据丢失或发生混乱。只要涉及到数据序列就会实施 TCP。
- UDP
用户数据报协议:无连接、不安全的协议。要传送的数据以应用程序生成的数据包的形式发送。不能保证数据以正确的顺序到达接收方,也可能丢失数据。UDP 适用于面向记录的应用程序。它的等待时间比 TCP 稍短。
- ICMP
因特网控制消息协议:这不是面向最终用户的协议,而是用来发出错误报告的特殊控制协议,能够控制参与 TCP/IP 数据传送的计算机的行为。此外,它还提供一种特殊的回应方式,可以通过 ping 程序查看该方式。
- IGMP
因特网组管理协议:此协议控制实施 IP 多路广播时的计算机行为。
如图 17.1 “TCP/IP 的简化层次模型” 中所示,数据交换在不同的层中进行。实际的网络层是通过 IP(因特网协议)的不安全数据传送。IP 的上面是 TCP(传送控制协议),它能够确保一定程度的数据传送安全性。IP 层由底层硬件相关协议(例如以太网)提供支持。
该图为每一层都提供了一到两个示例。层次按照抽象程度排序。最底层非常接近硬件。最上层则几乎就是硬件的完全抽象化。每一层都有自己的特殊功能。每一层的特殊功能多隐含在其描述中。数据链路层和物理层表示所用的物理网络(如以太网)。
几乎所有硬件协议都在面向数据包的基础上发挥作用。要传送的数据收集在包中(一次无法发送所有数据)。TCP/IP 包最大约为 64 KB。包通常要小得多,因为可能受到网络硬件的限制。以太网上的数据包最大约为 1500 个字节。通过以太网发送数据时,TCP/IP 包的大小不能超过这个限额。如果传送更多数据,操作系统需要发送更多的数据包。
为使层实现其指定功能,必须在数据包中保存与每层相关的附加信息。这些信息保存在数据包的报头中。每一层都在每个新包的开头附加一小块称为协议报头的数据。图 17.2 “TCP/IP 以太网包”中演示了一个通过以太网电缆传送的 TCP/IP 数据包示例。校验和位于包的末尾而不是开头,这样更便于网络硬件处理。
当应用程序通过网络发送数据时,数据会穿越每个层次,所有传递都在 Linux 内核中实施(只有物理层除外)。每一层都负责准备好数据,以便传递到下一层。最底层最后负责发送数据。接收数据时则逆向执行整个过程。正像剥洋葱皮那样,在每一层中都要从传输数据中删除协议报头。最后,传输层负责使数据可供目标上的应用程序使用。通过这种方式,每一层只与其上一层或下一层通讯。对于应用程序来说,无论数据是通过 100 Mbit/s(兆位/秒)的 FDDI 网络传送还是通过 56 Kbit/s(千位/秒)的调制解调器线路传送,都毫不相关。同样,只要数据包的格式正确,传送哪种数据对数据线也无关紧要。
17.1 IP 地址和路由 #
各节的论述仅限于 IPv4 网络。有关 IPv6 协议(IPv4 的后续协议)的信息,请参见第 17.2 节 “IPv6 — 下一代的因特网”。
17.1.1 IP 地址 #
因特网上的每台计算机都有一个唯一的 32 位地址。这些 32 位(或 4 字节)地址通常按例 17.1 “编写 IP 地址”的第二行所示的格式书写。
IP Address (binary): 11000000 10101000 00000000 00010100 IP Address (decimal): 192. 168. 0. 20
在十进制格式中,四字节以十进制数书写,其间以句点分隔。IP 地址被指派给主机或网络接口。它在全球只能使用一次。这条规则也有例外,但这些例外与下文无关。
IP 地址中的点表示分级系统。直到 20 世纪 90 年代,IP 地址仍然有严格的分类。但是,此系统经证实太过死板,已经废止。现已改为使用无类别路由 - (CIDR,无类别域间路由)。
17.1.2 网络掩码和路由 #
网络掩码用于定义子网的地址范围。如果两台主机位于同一子网中,它们可直接相互访问。如果它们位于不同子网中,则需要用于处理此子网的所有通讯的网关地址才能相互访问。要检查两个 IP 地址是否位于同一个子网中,只需分别将两个地址与网络掩码进行“AND”操作。如果结果相同,则两个 IP 地址在同一个本地网络中。如果结果不同,则仅能通过网关连接远程 IP 地址和远程接口。
要了解网络掩码如何工作,可查看例 17.2 “将 IP 地址链接到网络掩码”。网络掩码有 32 位,它确定 IP 地址有多少属于网络。对于所有为 1
的位,将它们在 IP 地址中的相应位标记为属于网络。对于所有值为 0
的位,标记其属于子网内。这意味着值为 1
的位越多,子网就越小。因为网络掩码总是由多个连续的 1
位组成,所以也可通过计算网络掩码中的位数来确定。在例 17.2 “将 IP 地址链接到网络掩码”中,第一个 24 位的网络也可写作 192.168.0.0/24
。
IP address (192.168.0.20): 11000000 10101000 00000000 00010100 Netmask (255.255.255.0): 11111111 11111111 11111111 00000000 --------------------------------------------------------------- Result of the link: 11000000 10101000 00000000 00000000 In the decimal system: 192. 168. 0. 0 IP address (213.95.15.200): 11010101 10111111 00001111 11001000 Netmask (255.255.255.0): 11111111 11111111 11111111 00000000 --------------------------------------------------------------- Result of the link: 11010101 10111111 00001111 00000000 In the decimal system: 213. 95. 15. 0
再举个例子:通过同一以太网电缆相连的所有计算机通常都位于同一子网中,可直接访问。即使用交换机或网桥物理分隔该子网,这些主机仍然可以直接访问。
仅在网关是为目标网络配的时,才能访问本地子网外部的 IP 地址。通常情况下,只有一个网关处理所有外部流量。然而,也可能为不同的子网配置多个网关。
如果配置了网关,所有的外部 IP 包将发送到相应的网关。此网关随后会尝试以相同的方式转发该包(从主机到主机)直到到达目标主机或超过该包的 TTL(存活时间)。
- 基础网络地址
这是网络掩码和该网络中的任意地址,如例 17.2 “将 IP 地址链接到网络掩码” 中的
Result
(结果)所示。不能将此地址指派给任何主机。- 广播地址
这可以解释为:“访问此子网中的所有主机”。要生成此地址,需要将网络掩码反转为二进制格式,并使用逻辑 OR 链接到基本网络地址。因此,以上示例会生成 192.168.0.255。该地址无法指派给任何主机。
- 本地主机
地址
127.0.0.1
指派给每台主机的“回路设备”。可以使用此地址以及通过 IPv4 定义的完整127.0.0.0/8
回写网络中的所有地址为您自己的计算机设置一个连接。对于 IPv6,仅存在一个回写地址 (::1
)。
由于 IP 地址必须在全球范围内唯一,您不能随机选择地址。共有三个地址域可用于建立基于 IP 的专用网络。这些地址无法与因特网上的其他地址建立任何连接,因为它们不能通过因特网传送。这些地址域在 RFC 1597 中指定,并且列在表 17.1 “专用 IP 地址域” 中。
网络/网络掩码 |
域 |
---|---|
|
|
|
|
|
|
17.2 IPv6 — 下一代的因特网 #
由于万维网 (WWW) 的出现,过去十五年内,越来越多的计算机通过 TCP/IP 进行通讯,因特网的规模发生了爆炸性的增长。自从 1990 年在 CERN (http://public.web.cern.ch) 任职的 Tim Berners-Lee 开创了 WWW,因特网主机的数量已从几千台猛增至上亿台。
如上所述,IPv4 地址只有 32 位。而且还有不少 IP 地址丢失,它们因网络组织结构的原因而无法使用。子网中可用的地址数量是位数的平方减 2。举例来说,某个子网可以有 2 个、6 个或 14 个可用地址。如果要将 128 台主机连接到因特网,您的子网要提供 256 个 IP 地址,其中只有 254 个可用,因为有两个 IP 地址需要供该子网本身的结构使用:广播和基础网络地址。
在当前的 IPv4 协议下,DHCP 或 NAT(网络地址转换)是用来避免出现地址短缺的典型机制。这些方法与用来分隔专用地址空间和公用地址空间的规定相结合,肯定能够缓解短缺状况; 它们的问题在于不仅配置烦琐,而且也加重了维护的负担。要在 IPv4 网络中设置主机,您需要若干地址项,如主机本身的 IP 地址、子网掩码、网关地址,可能还要提供名称服务器地址。所有这些项都是必需的,而且无法从其他任何地方得到这些项。
利用 IPv6,地址的短缺和复杂的配置都将成为过去。以下各节进一步描述了 IPv6 带来的改进和优点,以及如何从旧协议过渡到新协议。
17.2.1 优点 #
新协议中最为重要同时也最为显著的改进在于对可用地址空间的极大扩容。IPv6 地址由 128 位值而不是传统的 32 位值组成,它提供的 IP 地址数目多达 10 的 15 次方的若干倍。
不过,IPv6 与以前的不同不仅限于长度,其内部结构也发生了变化,这种结构可以包含更多的有关系统和系统所属网络的具体信息。有关详细信息,请参见第 17.2.2 节 “地址类型和结构”。
下面列出了新协议的其他优点:
- 自动配置
IPv6 使网络可以支持“即插即用”,这意味着无需任何手动配置即可将新安装的系统集成到(本地)网络中。新主机可以使用其自动配置机制,依赖名为邻居发现 (ND) 的协议从邻近的路由器提供的信息中得到自己的地址。这种方法不要求管理员参与,并且无需维护用于分配地址的中央服务器,这是 IPv4 无法媲美的(IPv4 中需要使用 DHCP 服务器来自动分配地址)。
不过,如果路由器已连接到交换机,则路由器应发送带标志的定期通告,告知网络中的主机彼此应如何交互。有关更多信息,请参见 RFC 2462 和
radvd.conf(5)
手册页以及 RFC 3315。- 移动能力
利用 IPv6,为一个网络接口同时指派多个地址成为可能。这使得用户能方便地访问多个网络,可媲美手机公司提供的国际漫游服务。当您出国时,进入相应区域后手机会自动登录国外服务,因此无论您身在何处,别人都可以用同一个号码联系到您,您也可以像在国内一样拨打电话。
- 安全通讯
在 IPv4 中,网络安全是一项附加功能。IPv6 则将 IPsec 作为其核心功能之一,允许系统通过安全隧道通讯,避免被因特网上的外来者窃听。
- 向后兼容性
实际上,要想将整个因特网一下子从 IPv4 转换为 IPv6 是不可能的。因此,这两个协议不仅要能在因特网上共存,还应能够共存于一个系统中,这一点至关重要。要实现这一点,一方面两种地址应兼容(IPv4 地址可以轻松转换为 IPv6 地址),另一方面还要使用多个隧道。请参见第 17.2.3 节 “IPv4 与 IPv6 并存”。此外,系统可以依赖双栈 IP 技术同时支持两种协议,这意味着系统中有两种完全分开的网络堆栈,从而避免这两种版本的协议相互影响。
- 通过多路广播的自定义服务
在 IPv4 中,有些服务(如 SMB)需要向本地网络中的所有主机广播其数据包。IPv6 使服务器能够通过多路广播对主机寻址(即将多个主机作为组的一部分寻址),因而提供了更精细的方法。这种方法与通过广播对所有主机寻址,或通过单路广播单独对每个主机寻址均不同。将哪些主机作为一组来寻址可能要取决于具体的应用程序。可使用一些预定义的组来寻址,例如对所有名称服务器寻址(所有名称服务器多路广播组),或对所有路由器寻址(所有路由器多路广播组)。
17.2.2 地址类型和结构 #
如上所述,当前的 IP 协议存在两个重要限制:IP 地址日益短缺,并且配置网络、维护路由选择表的任务变得越来越复杂繁重。IPv6 通过将地址空间扩展到 128 位解决了第一个问题。通过引入分级地址结构,结合先进的网络地址分配技术和多宿主功能(将多个地址指派给同一个设备,从而支持对多个网络的访问),第二个问题也得到缓解。
使用 IPv6 时,了解三种类型的地址十分有用:
- 单路广播
这类地址只与一个网络接口关联。采用这类地址的包只传递到一个目标。因此,使用单路广播地址可以将包传送到本地网络或因特网上的单个主机。
- 多路广播
这类地址与一组网络接口相关。采用这类地址的包将传递到属于该组的所有目标。多路广播地址主要供特定网络服务使用,用于以有序的方式与特定的主机组通讯。
- 任意广播
这类地址与一组接口相关。采用这类地址的包将根据基础路由协议的原则,传递给该组中与发送方最为接近的成员。任意广播地址便于主机在特定网络区域内找到提供特定服务的服务器。同一类型的所有服务器都具有相同的任意广播地址。在请求服务时,主机会收到路由协议决定的最接近它的服务器的回复。如果出于某种原因此服务器无法回复,协议会自动选择距离稍远一些的服务器,依此类推。
IPv6 地址分为八组,每组四位数字,代表十六位,采用十六进制表示法。它们之间用冒号 (:
) 分隔。可以删除某组中的前置零字节,但不能删除组中或组末的零。另一个约定是:连续的零字节若超过四个,则可以省略为双冒号形式。不过,每个地址只允许有一个这样的 ::
。中演示了这种简写表示法,其中的三行全部表示同一地址。例 17.3 “示例 IPv6 地址”
fe80 : 0000 : 0000 : 0000 : 0000 : 10 : 1000 : 1a4 fe80 : 0 : 0 : 0 : 0 : 10 : 1000 : 1a4 fe80 : : 10 : 1000 : 1a4
IPv6 地址的每个部分都有明确的功能。前面的字节构成前缀,用于指定地址类型。中间部分是地址的网络部分,但可以不用。地址的结尾构成主机部分。在 IPv6 中,网络掩码是通过在地址末尾的斜杠后指明前缀的长度来定义的。例 17.4 “指定前缀长度的 IPv6 地址” 中的地址包含上述信息,即:前 64 位构成地址的网络部分,后 64 位构成地址的主机部分。换言之,64
表示网络掩码由左起的 64 个 1 位值构成。与 IPv4 一样,IP 地址使用 AND 结合网络掩码值,以确定主机位于同一子网中还是其他网络中。
fe80::10:1000:1a4/64
IPv6 可以识别几种预定义的前缀类型。各种 IPv6 前缀中列出了其中的一部分。
00
IPv4 地址和 IPv6 上的 IPv4 兼容地址。这些用于与 IPv4 保持兼容。要使用这些地址,仍然需要依赖路由器将 IPv6 包转换为 IPv4 包。有若干特殊地址(如用于回路设备的地址)也采用此前缀。
2
或3
作为第一个数字可聚合全局单路广播地址。类似 IPv4 的情况,可以指定某个接口作为特定子网的一部分。目前,有以下地址空间:
2001::/16
(生产质量地址空间)和2002::/16
(6to4 地址空间)。fe80::/10
链路本地地址。不应路由带有这种前缀的地址,而只能从同一子网中访问。
fec0::/10
站点本地地址。可以路由这种地址,但只局限在它们所属的组织的网络之内。实际上,这些是相当于当前的专用网络地址空间(如
10.x.x.x
)的 IPv6 地址。ff
这些是多路广播地址。
单路广播地址由三个基本部分组成:
- 公共拓扑结构
第一部分(也包含上述前缀之一)用于通过公共因特网路由数据包。其中包含提供因特网访问的公司或机构的相关信息。
- 站点拓朴结构
第二部分包含要将包传递到的子网的路由信息。
- 接口 ID
第三部分标识要将包传递到的接口。其中允许使用 MAC。由于 MAC 是硬件厂商编程到设备中的全球唯一的固定标识符,配置过程得到了极大简化。事实上,前 64 个地址位共同构成
EUI-64
令牌,后 48 位从 MAC 中提取,其余的 24 位包含有关令牌类型的特殊信息。这样还可以将EUI-64
令牌指派给没有 MAC 的接口,如基于 PPP 的接口。
在这个基础结构之上,IPv6 还区分五种不同的单路广播地址:
::
(未指定)在首次初始化接口时(此时尚无法通过其他方法确定地址),这类地址可被主机用作其源地址。
::1
(回路)回路设备的地址。
- IPv4 兼容地址
IPv6 地址由 IPv4 地址和 96 个零位组成的前缀构成。这类兼容地址用于隧道通讯进程(请参见第 17.2.3 节 “IPv4 与 IPv6 并存”),以便 IPv4 和 IPv6 主机与在纯 IPv4 环境中操作的其他主机通讯。
- 映射到 IPv6 的 IPv4 地址
这类地址以 IPv6 表示法指定纯 IPv4 地址。
- 本地地址
有两类地址可供本地使用:
- 链路本地
这类地址只能在本地子网中使用。不能具有此类源地址或目标地址的包路由到因特网或其他子网。这些地址包含特殊的前缀 (
fe80::/10
) 和网卡的接口 ID,中间部分为零字节。这类地址在自动配置过程中使用,用于与同一子网中的其他主机通讯。- 站点本地
可以将采用这类地址的包路由到其他子网,但不能路由到更广阔的因特网 — 不能跨越组织自身的网络。这类地址用于内部网,相当于 IPv4 定义的专用地址空间。其中包含特殊的前缀 (
fec0::/10
)、接口 ID,及指定子网 ID 的 16 位字段。其余部分也会填入零字节。
作为 IPv6 引进的全新功能,每个网络接口通常可以获得多个 IP 地址,这个功能的优点即在于:可以通过同一接口访问多个网络。其中一个网络可以用 MAC 和已知前缀进行全自动配置,这样当启用 IPv6 (使用链路本地地址)后,即可访问本地网络中的所有主机。由于其中使用了 MAC,所用的任何 IP 地址都是全球唯一的。地址中只有指定站点拓朴结构和公共拓朴结构的部分才是可变部分,这取决于主机当前运行所在的实际网络。
要使主机在不同网络间切换,主机至少需要两个地址。其中之一 - 本地地址,不仅包含接口 ID 而且包含该主机通常所属的本地网络的标识符(以及相应的前缀)。本地地址是静态地址,因此一般不变。所有要发送到移动主机的包仍可以传递到该主机,不管它是在本地网络还是其他任何网络中操作。这一点得益于 IPv6 引进的全新功能,如无状态自动配置和邻居发现。除本地地址之外,移动主机还获得一个或多个额外的地址,这些地址属于该主机漫游到的外地网络。这些地址称为转交地址。本地网络有一种功能,可以在主机漫游到外地时转发要发送给该主机的所有包。在 IPv6 环境中,这项任务由本地代理来完成,该代理可以接收要发送到本地地址的所有包,并通过隧道进行转发。另一方面,发送到转交地址的那些包可直接转发到移动主机,而不必进行任何特殊的迂回处理。
17.2.3 IPv4 与 IPv6 并存 #
将与因特网相连的所有主机从 IPv4 迁移到 IPv6 是一个逐步的过程。这两种协议将在未来一定时间内并存。通过双栈技术来实施这两种协议,可以在同一系统上同时支持这两种协议。但这仍然没有解决启用了 IPv6 的主机如何与 IPv4 主机通讯,以及应如何通过当前的网络(绝大部分都基于 IPv4)传输 IPv6 数据包的问题。最好的解决方案就是提供隧道处理功能和兼容地址(请参见 第 17.2.2 节 “地址类型和结构”)。
IPv6 主机多少孤立于(全球)IPv4 网络,它可通过隧道通讯:IPv6 包封装为 IPv4 包,以便在 IPv4 网络中移动。这种在两个 IPv4 主机间的连接被称为隧道。要实现这种功能,包必须包含 IPv6 目标地址(或相应的前缀),以及隧道接收端远程主机的 IPv4 地址。根据主机管理员间的协议,可以手动配置基本的隧道。这也称作静态隧道。
但是,静态隧道的配置和维护往往过于烦琐,不能适应日常通讯需要。因此,IPv6 提供了三种不同的动态隧道方法:
- 6over4
IPv6 包被自动封装为 IPv4 包,并通过支持多路广播的 IPv4 网络发送。这种方法诱导 IPv6 将整个网络(因特网)视为一个巨大的局域网 (LAN)。这样即可自动确定 IPv4 隧道的接收端。不过,这种方法的可扩展性不够好,而且不易推行,因为 IP 多路广播在因特网上尚未普及。因此,它提供的解决方案仅适用于支持多路广播的小型公司网络或机构网络。RFC 2529 中对这种方法作出了规定。
- 6to4
利用这种方法,可以从 IPv6 地址自动生成 IPv4 地址,从而支持孤立的 IPv6 主机通过 IPv4 网络进行通讯。不过,用这种方法在孤立的 IPv6 主机和因特网之间通讯时存在一些问题。RFC 3056 中对这种方法进行了描述。
- IPv6 隧道中介程序
这种方法依赖特殊的服务器为 IPv6 主机提供专用隧道。RFC 3053 中对此进行了描述。
17.2.4 配置 IPv6 #
要配置 IPv6,通常无需在各个工作站上执行任何更改。默认情况下启用 IPv6。要在已安装系统上禁用或启用 IPv6,请使用 YaST root
身份输入 modprobe
-i ipv6
。装载 IPv6 模块后无法将其卸载。
由于 IPv6 使用自动配置,将给网卡指派链路-本地网络中的地址。一般不在工作站上管理路由选择表。工作站可以使用路由器广告协议查询网络路由器,了解应实施的前缀和网关。使用 radvd 程序可以设置 IPv6 路由器。此程序会通知工作站对 IPv6 地址使用哪个前缀和哪个路由器。或者,可以使用 zebra/quagga 自动配置两个地址和路由选择。
有关如何使用 /etc/sysconfig/network
文件设置各种隧道的信息,请参见 ifcfg-tunnel
的手册页 (man ifcfg-tunnel
)。
17.2.5 更多信息 #
上文的概述中并未全面论述 IPv6 这一主题。有关这种新协议的深入讨论,请参见以下联机文档和书目:
- http://www.ipv6.org/
学习 IPv6 知识的起点。
- http://www.ipv6day.org
启动您自己的 IPv6 网络所需的所有信息。
- http://www.ipv6-to-standard.org/
已启用 IPv6 的产品列表。
- http://www.bieringer.de/linux/IPv6/
在此可找到 Linux IPv6-HOWTO 以及许多与该主题有关的链接。
- RFC 2460
有关 IPv6 的基础 RFC。
- IPv6 Essentials
Silvia Hagen 所著的 IPv6 Essentials(ISBN 0-596-00125-8) 中描述了该主题的所有重要方面。
17.3 名称解析 #
DNS 有助于将 IP 地址指派给一个或多个名称,并将名称指派给 IP 地址。在 Linux 中,这种转换通常由一种特殊的称为 bind 的软件来完成。负责这种转换的计算机称为名称服务器。这些名称构成了具有层次结构的系统,各个名称组成部分之间用句点分隔。不过,这个名称层次与上述 IP 地址层次无关。
考虑以 hostname.domain
格式书写的完整名称,如 jupiter.example.com
。完整名称,即完全限定的域名 (FQDN),由主机名和域名 (example.com
) 组成。后者还包含顶级域或 TLD (com
)。
TLD 的指派由于历史原因已经变得十分混乱。传统的指派方法是美国所用的三字母域名,而世界其他地方采用的标准是双字母 ISO 国家/地区代码。此外,2000 年还引进了较长的 TLD,表示特定的活动领域(例如 .info
、.name
和 .museum
)。
在因特网发展的早期阶段( 1990 年之前),文件 /etc/hosts
被用来储存因特网上表示的所有计算机的名称。后来事实证明随着接入因特网的计算机与日俱增,这种方法很快就行不通了。为此人们开发了一个分散式数据库,以十分分散的方式储存主机名。这个数据库类似名称服务器,它并不储存与因特网上的所有主机相关的数据,但可以向其他名称服务器发送请求。
位于层次顶级的是 root 名称服务器。这些 root 名称服务器管理顶级域,并由网络信息中心 (NIC) 运行。每个 root 名称服务器都了解负责特定顶级域的名称服务器。有关顶级域 NIC 的信息,请参见 http://www.internic.net。
DNS 不仅可以解析主机名,还能够为整个域识别出负责接收电子邮件的主机,即邮件交换器 (MX)。
为解析 IP 地址,您的计算机必须了解至少一个名称服务器及其 IP 地址。使用 YaST 可轻松指定此类名称服务器。
whois
协议与 DNS 密切相关。使用此程序可以快速找出负责给定域的服务器。
.local
顶级域由解析程序视为 link-local 域。DNS 请求作为多路广播 DNS 请求(而不是常规 DNS 请求)发送。如果已在名称服务器配置中使用 .local
域,必须在 /etc/host.conf
中关闭此选项。有关更多信息,请参见 host.conf
手册页。
要在安装期间关闭 MDNS,请使用 nomdns=1
引导参数。
有关多路广播 DNS 的详细信息,请参见 http://www.multicastdns.org。
17.4 使用 YaST 配置网络连接 #
Linux 上有多个支持的联网类型。其中多数使用不同的设备名,配置文件分布在文件系统上的多个位置。关于手动网络配置方面的详细概述,请参见第 17.6 节 “手动配置网络连接”。
在 NetworkManager 默认处于活动状态的 SUSE Linux Enterprise Desktop 上,所有网卡都会加以配置。如果 NetworkManager 不处于活动状态,那么系统只会自动配置使用链路连通的第一个接口(已连接网络电缆)。可随时在已安装系统中配置额外的硬件。以下章节将介绍 SUSE Linux Enterprise Desktop 支持的所有网络连接类型的网络配置。
17.4.1 使用 YaST 配置网卡 #
要在 YaST 中配置以太网卡或 Wi-Fi/蓝牙卡,请选择
› 。启动模块后,YaST 将显示 对话框,其中包括四个选项卡: 、 、 和 。 选项卡可设置常规联网选项,例如网路设置方法、IPv6 和常规 DHCP 选项。有关详细信息,请参见第 17.4.1.3 节 “配置未检测到的网卡”。要更改所配置网卡的配置,请参见第 17.4.1.2 节 “更改网卡的配置”。
选项卡包含关于已安装网络接口和配置的信息。会列出已正确检测到的所有网卡及其名称。您可在此对话框中手动配置新卡、删除或更改其配置。要手动配置未自动检测到的网卡,请参见 选项卡可设置计算机的主机名和要使用的服务器名称。有关详细信息,请参见 选项卡用于配置路由选择。有关更多信息,请参见17.4.1.1 配置全局联网选项 #
通过 YaST
模块的 选项卡,可设置重要的全局联网选项,如使用 NetworkManager、IPv6 和 DHCP 客户端选项。这些设置适用于所有网络接口。
在nm-applet
配置网络选项,并且 模块的 、 和 选项卡会被禁用。有关 NetworkManager 的更多信息,请参见第 25 章 “使用 NetworkManager”。
在
中,选择是否使用 IPv6 协议。可将 IPv6 与 IPv4 一起使用。默认情况下,会启用 IPv6。但是在不使用 IPv6 协议的网络中,如果禁用 IPv6 协议,响应时间会更快。要禁用 IPv6,请停用 。如果禁用了 IPv6,内核将不再自动装载 IPv6 模块。重启动后会应用此设置。在
中,配置 DHCP 客户端的选项。在单个网络上,每个 DHCP 客户端的 必须不同。如果保留为空,会默认为网络接口的硬件地址。但是,如果正在运行若干使用相同网络接口(即相同硬件地址)的虚拟机,则在此处指定唯一的自由格式标识符。
AUTO
,将发送当前的主机名(即 /etc/HOSTNAME
中定义的主机名)。将选项字段保留空白则不会发送任何主机名。
如果您不希望根据 DHCP 中的信息更改默认路由,请停用
。17.4.1.2 更改网卡的配置 #
要更改网卡的配置,请在 YaST
› 中已检测到的网卡列表中选择一个网卡,然后单击 。将显示 对话框,可在其中使用 、 和 选项卡调整网卡配置。17.4.1.2.1 配置 IP 地址 #
您可在
对话框的 选项卡中设置网卡的 IP 地址或 IP 地址的确定方法。同时支持 IPv4 和 IPv6 地址。网卡可设置为 (对于绑定设备很有用)、 (IPv4 或 IPv6)或通过 和/或 指派的 。如果使用
,则选择是使用 (用于 DHCPv4)、 (用于 DHCPv6)还是 。如果可能,安装期间的首个带链接的可用网卡将会通过 DHCP 自动配置为使用自动 IP 地址。在 NetworkManager 默认处于活动状态的 SUSE Linux Enterprise Desktop 上,所有网卡都会加以配置。
如果使用的是 DSL 线路,但 ISP(因特网服务提供商)没有指派静态 IP,此时还应使用 DHCP。如果决定使用 DHCP,请打开 YaST 网卡配置模块的
对话框,在 选项卡的 中配置细节。如果您使用虚拟主机设置,其中不同的主机都通过同一接口通信,则需要用 来区分。DHCP 比较适合客户端配置,但不太适合服务器配置。要设置静态 IP 地址,请如下继续操作:
在 YaST 网卡配置模块的
选项卡中,于已检测到的网卡列表中选择一个网卡,然后单击 。在
选项卡中,选择 。输入
。IPv4 和 IPv6 地址均可使用。在 中输入子网掩码。如果使用 IPv6 地址,则对于前缀长度使用/64
格式的 。或者,您可以为此地址输入一个完全限定的
,该主机名将写入到/etc/hosts
配置文件。单击
。要激活配置,请单击
。
在激活网络接口期间,wicked
会检查载波,并且只有在检测到链路之后,才会应用 IP 配置。如果不管链路状态为何,您都需要应用配置(例如,您要测试侦听某个地址的服务),则可以在 /etc/sysconfig/network/ifcfg
内的接口配置文件中添加变量 LINK_REQUIRED=no
来跳过链路检测。
另外,您可以使用变量 LINK_READY_WAIT=5
来指定等待链路的超时值(以秒为单位)。
有关 ifcfg-*
配置文件的详细信息,请参见第 17.6.2.5 节 “/etc/sysconfig/network/ifcfg-*
”和 man 5 ifcfg
。
如果使用静态地址,则不会自动配置名称服务器和默认网关。要配置名称服务器,请按照第 17.4.1.4 节 “配置主机名和 DNS” 中所述进行。要配置网关,请按照第 17.4.1.5 节 “配置路由选择” 中所述进行。
17.4.1.2.2 配置多个地址 #
一个网络设备可以有多个 IP 地址。
这些所谓的别名或标签只能分别用于 IPv4。对于 IPv6 则忽略它们。使用 iproute2
网络接口可以有一个或多个地址。
要使用 YaST 设置网卡的其他地址,请执行以下步骤:
在 YaST
对话框的 选项卡中,于已检测到的网卡列表中选择一个网卡,然后单击 。在
› 选项卡中,单击 。输入
、 和 。不要在别名中包含接口名称。要激活该配置,请确认设置。
17.4.1.2.3 更改设备名称和 Udev 规则 #
可更改网卡在使用时的设备名称。还可确定 udev 是通过网卡的硬件 (MAC) 地址还是通过总线 ID 来标识网卡。后一个选项更适合大型服务器,因为便于热插拔网卡。要使用 YaST 设置这些选项,请执行以下步骤:
在 YaST
对话框的 选项卡中,于已检测到的网卡列表中选择一个网卡,然后单击 。转到
选项卡。当前设备名称显示在 中。单击 。选择 udev 应通过网卡的
还是 来识别网卡。网卡的当前 MAC 地址和总线 ID 显示在对话框中。要更改设备名称,请选中
选项并编辑名称。要激活该配置,请确认设置。
17.4.1.2.4 更改网卡内核驱动程序 #
对于某些网卡,可能会提供某些内核驱动程序。如果网卡已配置,YaST 允许您从可用的合适驱动程序列表中选择一个要使用的内核驱动程序。还可为内核驱动程序指定选项。要使用 YaST 设置这些选项,请执行以下步骤:
在 YaST 网络设置模块的
选项卡中,于已检测到的网卡列表中选择一个网卡,然后单击 。转到
选项卡。在
中选择要使用的内核驱动程序。在 中以=
=VALUE 格式为所选驱动程序输入任何选项。如果使用多个选项,应用空格分隔这些选项。要激活该配置,请确认设置。
17.4.1.2.5 激活网络设备 #
如果使用结合 wicked
的方法,便可以将设备配置为在引导期间、连接电缆时或检测到网卡时启动、以手动方式启动或永不启动设备。要更改设备启动,请如下继续操作:
在 YaST 的
› 中,于已检测到的网卡列表中选择一个网卡,然后单击 。在
选项卡中,从 选择所希望的项。选择
可在系统引导时启动设备。使用 将对任何现有物理连接监视接口。使用 ,可在接口可用时对其进行设置。这与 选项很相似,唯一区别是如果引导时接口不存在,将不会发生错误。选择 可通过ifup
手动控制接口。选择 将不启动设备。 与 相似,区别是使用systemctl stop wicked.service
命令不会关闭接口;如果wicked
处于活动状态,则network
服务还会处理wicked
服务。如果您使用 NFS 或 iSCSI 根文件系统,则选择此选项。要激活该配置,请确认设置。
在通过网络以 NFS 共享形式装入根分区的(无磁盘)系统中,配置可供访问 NFS 共享的网络设备时需保持谨慎。
关闭或重引导系统时,默认的处理顺序是关闭网络连接,然后卸载根分区。对于 NFS 根分区,这种顺序会产生问题,因为在尚未激活与 NFS 共享的网络连接的情况下,根分区无法完全卸载。为防止系统停用相关的网络设备,请按第 17.4.1.2.5 节 “激活网络设备”中所述打开网络设备配置选项卡,然后在 窗格中选择 。
17.4.1.2.6 设置最大传输单位大小 #
您可为接口设置最大传输单位 (MTU)。MTU 是指允许的最大包大小(以字节为单位)。更高的 MTU 可带来更高的带宽效率。但是较大的包有时可能会堵塞较慢的接口,从而增加后续包的延迟。
在 YaST 的
› 中,于已检测到的网卡列表中选择一个网卡,然后单击 。在
选项卡中,从 列表中选择所需项。要激活该配置,请确认设置。
17.4.1.2.7 PCIe 多功能设备 #
系统支持对以下技术提供支持的多功能设备:LAN、iSCSI 和 FCoE。YaST FCoE 客户端 (yast2 fcoe-client
) 会在额外的列中显示私用标志,以允许用户选择用于 FCoE 的设备。YaST 网络模块 (yast2 lan
) 会针对网络配置排除“仅储存设备”。
17.4.1.2.8 IP-over-InfiniBand (IPoIB) 的 Infiniband 配置 #
在 YaST 的
› 中选择 InfiniBand 设备,然后单击 。在
选项卡中,选择一种 (IPoIB) 模式: (默认)或 。要激活该配置,请确认设置。
有关 InfiniBand 的更多信息,请参见 /usr/src/linux/Documentation/infiniband/ipoib.txt
。
17.4.1.2.9 配置防火墙 #
您不必按Book “Security and Hardening Guide”, Chapter 22 “Masquerading and Firewalls”, Section 22.4 “firewalld
”中所述执行详细的防火墙设置,只需在设置设备的过程中决定设备的基本防火墙配置。按如下所示继续:
打开 YaST 的
› 模块。在 选项卡中,从已检测到的网卡列表中选择一个网卡,然后单击 。进入
对话框的 选项卡。确定要将接口指派到的
。下列选项可用:- 防火墙已禁用
此选项只有在禁用防火墙和防火墙未在运行时才可用。仅当计算机属于受外部防火墙保护的大型网络时才使用此选项。
- 自动指派区域
此选项只有在启用防火墙后才可用。防火墙正在运行且接口自动指派给防火墙区域。包含关键字
any
的区域或外部区域将用于此类接口。- 内部区域(未保护)
防火墙正在运行,但不会强制执行任何规则来保护此接口。当计算机属于受外部防火墙保护的大型网络时才使用此选项。当计算机具有多个网络接口时,此选项还可用于连接到内部网络的接口。
- 隔离区域
隔离区域是位于内部网络和(恶意)因特网之前的附加防线。可从内部网络和因特网访问指派到此区域的主机,但指派到此区域的主机无法访问内部网络。
- 外部区域
防火墙在此接口上运行,并且全面保护其抵御其他假定有害的网络流量。这是默认选项。
要激活该配置,请确认设置。
17.4.1.3 配置未检测到的网卡 #
如果未正确检测到某个网卡,该卡将不会包含在已检测到的网卡列表中。如果确定系统包含网卡的驱动程序,则可以手动对其进行配置。还可以配置特殊网络设备类型,例如网桥、绑定、TUN 或 TAP。要配置未检测到的网卡(或特殊设备),请如下操作:
在 YaST 的
› › 对话框中,单击 。在
对话框中,从可用选项中设置接口的 和 。如果网卡为 USB 设备,请激活相应的复选框,并单击 退出此对话框。或者,如果需要,您可定义要用于网卡的内核 及其 。在
中,您可以为接口设置ifup
使用的ethtool
选项。有关可用选项的信息,请参见ethtool
手册页。如果选项字符串以
-
开头(例如,-K INTERFACE_NAME rx on
),则会用当前接口名称替换字符串中的第二个词。否则(例如,autoneg off speed 10
)ifup
会在开头添加-s INTERFACE_NAME
。单击
。- 、 和 选项卡中,配置所有所需的选项,如接口的 IP 地址、设备激活或防火墙区域。有关配置选项的更多信息,请参见
如果选择
作为接口的设备类型,则在下一个对话框中配置无线连接。要激活新的网络配置,请确认设置。
17.4.1.4 配置主机名和 DNS #
如果您在安装期间未更改网络配置,并且已有以太网卡可用,则系统会自动为您的计算机生成主机名并激活 DHCP。这同样适用于主机连接到网络环境所需的名称服务信息。如果网络地址设置使用了 DHCP,则会向域名服务器列表自动填充相应数据。如果希望使用静态设置,则手动设置这些值。
要更改计算机名称并调整名称服务器搜索列表,则如下继续操作:
转到 YaST 的
› 网络设置 选项卡。输入
,如果需要,也输入 。如果此计算机是邮件服务器,则该域特别重要。请注意,主机名是全局性的,将应用到所有已设置的网络接口。如果使用 DHCP 获取 IP 地址,则计算机的主机名将由 DHCP 自动设置。如果连接到不同网络,您应禁用此行为,因为其他网络可能会指派不同的主机名,而在运行时更改主机名可能会导致混淆图形桌面。要禁止使用 DHCP 获取 IP 地址,请停用
。/etc/hosts
中的127.0.0.2
(回写)IP 地址关联。如果您想让主机名即使在没有活动的网络情况下也可随时解析,则可使用该选项。在
中,请选择修改 DNS 配置(名称服务器、搜索列表以及/run/netconfig/resolv.conf
文件的内容)的方式。如果选择了
选项,则配置由netconfig
脚本处理,该脚本合并了静态定义的数据(通过 YaST 或在配置文件中)与动态获取的数据(来自 DHCP 客户端或 NetworkManager)。此默认策略可满足通常情况。如果选择了
选项,则不允许netconfig
修改/run/netconfig/resolv.conf
文件。但是,此文件可手动编辑。如果已选择
选项,则应指定用于定义合并策略的 字符串。该字符串包含了接口名称的逗号分隔列表,可考虑作为设置的有效源。除完整接口名外,也可使用基本通配符来匹配多个接口。例如,eth* ppp?
首先以所有 eth 为目标,然后是 ppp0 到 ppp9 的所有接口。有两个特殊策略值表示如何应用/etc/sysconfig/network/config
文件中定义的静态设置:STATIC
静态设置需要与动态设置合并到一起。
STATIC_FALLBACK
仅当动态配置不可用时,才使用静态设置。
有关更多信息,请参见
netconfig
(8) 的手册页 (man 8 netconfig
)。输入
并填写 列表。名称服务器必须由 IP 地址指定(如 192.168.1.116),而非由主机名指定。 选项卡中指定的名称是用于解析主机名(未指定域)的域名。如果使用多个 ,则使用逗号或空格分隔域。要激活该配置,请确认设置。
也可以使用 YaST 从命令行编辑主机名。YaST 所做更改会立即生效(手动编辑 /etc/HOSTNAME
文件时则不是这样)。要更改主机名,请使用以下命令:
root #
yast dns edit hostname=HOSTNAME
要更改名称服务器,请使用以下命令:
root #
yast dns edit nameserver1=192.168.1.116root #
yast dns edit nameserver2=192.168.1.117root #
yast dns edit nameserver3=192.168.1.118
17.4.1.5 配置路由选择 #
要使计算机能够与其他计算机和其他网络进行通信,必须提供路由选择信息以使网络流量使用正确的路径。如果使用 DHCP,则将自动提供此信息。如果使用静态设置,则必须手动添加此数据。
在 YaST 中,转到
› 。输入
(如果需要是 IPv4 和 IPv6)的 IP 地址。默认网关与每个可能的目标匹配,但是如果存在与所需地址匹配的路由表项,则会使用此项,而不是通过默认网关使用默认路由。可在
中输入多个项。输入 网络 IP 地址、 IP 地址和 。选择将流量路由到定义的网络要经过的 (减号代表任何设备)。要忽略这些值中的任何值,请使用减号-
。要在表中输入默认网关,请在 字段中使用默认
。注意:路由优先级如果使用更多的默认路由,则可以指定用于确定具有更高优先级的路由的度量选项。要指定度量选项,请在
中输入- metric NUMBER
。默认情况下使用具有最高度量的路由。如果网络设备已断开连接,则删除其路由并使用下一个路由。但是,当前内核不在静态路由中使用度量,只有multipathd
等路由守护程序使用度量。如果系统是路由器,请根据需要在
中启用 和 。要激活该配置,请确认设置。
17.5 NetworkManager #
NetworkManager 是用于便携式计算机和其他可移动计算机的理想解决方案。有了 NetworkManager,您便无需担心配置网络接口并且无需移动时在网络之间切换。
17.5.1 NetworkManager 和 wicked
#
但是 NetworkManager 解决方案并非适用于所有情况,因此您仍可在 wicked
控制方法(用于管理网络连接)和 NetworkManager 之间进行选择。如果您希望使用 NetworkManager 管理网络连接,则在 YaST 网络设置模块中启用 NetworkManager(如第 25.2 节 “启用或禁用 NetworkManager”中所述),然后使用 NetworkManager 配置网络连接。有关用例的列表以及如何配置和使用 NetworkManager 的详细说明,请参见第 25 章 “使用 NetworkManager”。
wicked 和 NetworkManager 的一些区别:
root
特权如果使用 NetworkManager 进行网络设置,则可以随时使用一个小程序在您的桌面环境内轻松地切换、停止或启动网络连接。NetworkManager 也可以改变和配置无线网卡连接,无需
root
特权。因此,NetworkManager 是一种用于移动工作站的理想解决方案。wicked
也提供一些像用户管理的设备那样切换、停止或启动连接的途径(有的需要用户干预,有的则不需要)。但是,此方法始终需要root
特权才能更改或配置网络设备。这对于移动计算是个常见问题,因为移动计算不可能预配置所有的连接功能。- 网络连接的类型
wicked
和 NetworkManager 都可以处理与无线网络(WEP、WPA-PSK 和 WPA-Enterprise 访问)和使用 DHCP 及静态配置的有线网络之间的网络连接。它们还支持拨号连接和 VPN 连接。使用 NetworkManager 还可以连接移动宽带 (3G) 调制解调器或设置 DSL 连接,而传统配置则不能进行这种连接。NetworkManager 尝试使用可用的最好连接使您的计算机随时保持连接状态。如果网络电缆意外断开,它将尝试重连接。它可以从您的无线连接列表中找到具有最佳信号强度的网络并自动用其进行连接。如果想使用
wicked
获得相同的功能,需要执行更多配置工作。
17.5.2 NetworkManager 功能和配置文件 #
用 NetworkManager 创建的单个网络连接设置储存在配置文件中。用 NetworkManager 或 YaST 配置的系统连接保存在 /etc/NetworkManager/system-connections/*
或 /etc/sysconfig/network/ifcfg-*
中。对于 GNOME,所有用户定义的连接都储存在 GConf 中。
如果未配置任何配置文件,NetworkManager 将自动创建一个配置文件,并将其命名为 Auto $INTERFACE-NAME
。这样做是试图无需为任意多的(安全)案例进行任何配置就能使用。如果自动创建的配置文件不适合您的需要,请使用 GNOME 提供的网络连接配置对话框,根据需要修改它们。有关更多信息,请参见第 25.3 节 “配置网络连接”。
17.5.3 控制和锁定 NetworkManager 功能 #
在集中管理的计算机上,可以使用 PolKit 控制或禁用某些 NetworkManager 功能,例如,是否允许某用户修改管理员定义的连接,或者是否允许某用户定义自己的网络配置。要查看或更改相关的 NetworkManager 策略,请启动 PolKit 的图形Book “Security and Hardening Guide”, Chapter 17 “The Polkit authentication framework”。
工具。在左侧的树中 条目下找到它们。有关 PolKit 的介绍及其使用方法细节,请参见17.6 手动配置网络连接 #
应该将手动配置网络软件作为最后的选择。建议使用 YaST。但是,对网络配置背景信息的了解将对您使用 YaST 有所帮助。
17.6.1 wicked
网络配置 #
名为 wicked
的工具和库提供了一个用于配置网络的新框架。
传统网络接口管理面临的其中一项挑战是,各种不同的网络管理层混杂在一个脚本中,最多在两个不同的脚本中。这些脚本彼此之间如何交互没有明确的定义。这会导致出现无法预测的问题、模糊的约束和约定等情况。针对各种不同的情况部署多个特殊入侵层增大了维护负担。所用的地址配置协议是通过 dhcpcd 等守护程序实现的,而这些守护程序与基础架构中其他组件的交互很不通畅。为了持续识别接口,引入了新潮的接口命名模式,而这需要繁重的 udev 支持。
wicked 的理念是通过多种方式剖析问题。它没有采用任何全新的技术,而是尝试将不同项目中的观点集中起来,以建立一个更好的整体解决方案。
实现此目的的方法之一是使用客户端/服务器模型。wicked 可借此为地址配置等任务定义能够很好地集成到整个框架中的标准化工具。例如,使用特定的地址配置时,管理员可能要求应该通过 DHCP 或 IPv4 zeroconf 配置接口。在这种情况下,地址配置服务只会从它的服务器获得租用,并传递到安装了所请求地址和路由的 wicked 服务器进程。
剖析问题的另一种方法是强制实施分层机制。对于任何类型的网络接口,都可以定义一个 dbus 服务,用于配置网络接口的设备层 — VLAN、桥接、绑定或超虚拟化设备。地址配置等常用功能通过在这些设备特定的服务基础上分层的联合服务实现,您不必专门实施这些功能。
wicked 框架使用各种 dbus 服务来实现这两个方面的功能,这些服务将会根据其类型挂接到网络接口。本文提供了 wicked 中的当前对象层次的简要概述。
每个网络接口以 /org/opensuse/Network/Interfaces
的子对象表示。该子对象的名称由其 ifindex 指定。例如,ifindex 通常为 1 的回写接口是 /org/opensuse/Network/Interfaces/1
,注册的第一个以太网接口是 /org/opensuse/Network/Interfaces/2
。
每个网络接口都有一个关联的“类”,该类用于选择该接口支持的 dbus 接口。默认情况下,每个网络接口的类为 netif
,wickedd 将自动挂接与此类兼容的所有接口。在当前实施中,这些兼容的接口包括:
- org.opensuse.Network.Interface
一般网络接口功能,例如,打开或关闭链路、指派 MTU 等
- org.opensuse.Network.Addrconf.ipv4.dhcp, org.opensuse.Network.Addrconf.ipv6.dhcp, org.opensuse.Network.Addrconf.ipv4.auto
适用于 DHCP、IPv4 zeroconf 等的地址配置服务
除此之外,网络接口可能还需要或者提供特殊的配置机制。例如,对于某个以太网设备,您应该能够控制链路速度、校验和卸载等。为了实现此目的,以太网设备都有一个名为 netif-ethernet
的自己的类,该类属于 netif
的子类。因此,指派给以太网接口的 dbus 接口具有上面列出的所有服务以及 org.opensuse.Network.Ethernet
服务,后者只适用于属于 netif-ethernet
类的对象。
同样,桥接、VLAN、绑定或 infiniband 等接口类型也存在适用类。
您要如何与某个首先需要创建的接口(例如 VLAN,它实际上是位于以太网设备上的虚拟网络接口)交互呢?为此,wicked 定义了出厂接口,例如 org.opensuse.Network.VLAN.Factory
。这种出厂接口只提供单一功能,就是让您创建所请求类型的接口。这些出厂接口将挂接到 /org/opensuse/Network/Interfaces
列表节点。
17.6.1.1 wicked
体系结构和功能 #
如图 17.4 “wicked
体系结构”中所述,wicked
服务由几个部分组成。
wicked
体系结构 #
wicked
目前支持以下功能:
使用配置文件后端来分析 SUSE 样式的
/etc/sysconfig/network
文件。使用内部配置后端以 XML 格式表示网络接口配置。
打开和关闭“常规”网络接口,例如以太网或 InfiniBand,VLAN、网桥、绑定、tun、tap、虚设设备、macvlan、macvtap、hsi、qeth、iucv 和无线(当前限制为一个 wpa-psk/eap 网络)设备。
内置 DHCPv4 客户端和内置 DHCPv6 客户端。
默认启动的 nanny 守护程序有助于在设备可用(接口热插入)时自动激活配置的接口,以及在检测到链路(载波)时设置 IP 配置。有关详细信息,请参见 第 17.6.1.3 节 “Nanny”。
wicked
过去是以与 systemd 集成的 DBus 服务组形式来实现的。因此,一般的systemctl
命令将会适用于wicked
。
17.6.1.2 使用 wicked
#
在 SUSE Linux Enterprise 上,默认会运行 wicked
。如果您要检查当前启用了哪个组件以及该组件是否正在运行,请调用:
systemctl status network
如果已启用 wicked
,您将看到类似于下面的行:
wicked.service - wicked managed network interfaces Loaded: loaded (/usr/lib/systemd/system/wicked.service; enabled) ...
如果运行的是其他组件(例如 NetworkManager)并且您想切换到 wicked
,请先停止正在运行的组件,然后启用 wicked
:
systemctl is-active network && \ systemctl stop network systemctl enable --force wicked
如此会启用 wicked 服务、创建从 network.service
到 wicked.service
的别名链路,并在下次引导时启动网络。
启动服务器进程:
systemctl start wickedd
这将会启动 wickedd
(主服务器)和关联的请求方:
/usr/lib/wicked/bin/wickedd-auto4 --systemd --foreground /usr/lib/wicked/bin/wickedd-dhcp4 --systemd --foreground /usr/lib/wicked/bin/wickedd-dhcp6 --systemd --foreground /usr/sbin/wickedd --systemd --foreground /usr/sbin/wickedd-nanny --systemd --foreground
然后激活网络:
systemctl start wicked
或者使用 network.service
别名:
systemctl start network
这些命令使用 /etc/wicked/client.xml
中定义的默认配置源或系统配置源。
要启用调试,请在 /etc/sysconfig/network/config
中设置 WICKED_DEBUG
,例如:
WICKED_DEBUG="all"
或者,要省略一些信息:
WICKED_DEBUG="all,-dbus,-objectmodel,-xpath,-xml"
使用客户端实用程序显示所有接口的接口信息,或者显示以 IFNAME 指定的接口的接口信息:
wicked show all wicked show IFNAME
XML 格式的输出:
wicked show-xml all wicked show-xml IFNAME
打开一个接口:
wicked ifup eth0 wicked ifup wlan0 ...
由于未指定配置源,wicked 客户端将检查 /etc/wicked/client.xml
中为它定义的默认配置源:
firmware:
iSCSI 引导固件表 (iBFT)compat:
ifcfg
文件 — 为兼容性而实施
将会应用 wicked
从指定接口的这些源中获取的任何设置。预期的重要性顺序为 firmware
、compat
- 将来此顺序可能会发生变化。
有关更多信息,请参见 wicked
手册页。
17.6.1.3 Nanny #
Nanny 是一个事件与策略驱动的守护程序,负责热插拔设备等异步或被动性方案。因此,Nanny 守护程序可帮助启动或者重启动延迟的设备或临时消失的设备。Nanny 将监视设备和链路变化,并集成当前策略集定义的新设备。即使 ifup
已经因指定的超时约束而退出,Nanny 也会继续设置。
默认情况下,Nanny 守护程序在系统上处于活动状态。您可在 /etc/wicked/common.xml
配置文件中启用它:
<config> ... <use-nanny>true</use-nanny> </config>
如果使用此设置,ifup 和 ifreload 会将包含有效配置的策略应用到 Nanny 守护程序;然后,Nanny 将配置 wickedd
,从而确保支持热插拔。它将在后台等待事件或更改(例如,打开新的设备或载体)。
17.6.1.4 打开多个接口 #
对于绑定和网桥,有效的做法是在一个文件 (ifcfg-bondX) 中定义整个设备拓扑,并一次性将它激活。然后,当您指定(网桥或绑定的)顶级接口名称时,wicked 可以激活整个配置:
wicked ifup br0
此命令会按适当的顺序自动设置网桥及其依赖项,而无需分别列出依赖项(端口等)。
要在一个命令中激活多个接口:
wicked ifup bond0 br0 br1 br2
要激活所有接口:
wicked ifup all
17.6.1.5 通过 Wicked 使用隧道 #
如果您需要将隧道与 Wicked 结合使用,可以使用专门针对此用途的 TUNNEL_DEVICE
。它可让您指定一个可选的设备名称,以将隧道绑定至该设备。隧道式包将只能通过此设备路由。
有关详细信息,请参见 man 5 ifcfg-tunnel
。
17.6.1.6 处理增量变化 #
有了 wicked
,当您要重新配置某个接口时,并不需要真正将它关闭(除非内核有此要求)。例如,要将另一个 IP 地址或路由添加到静态配置的网络接口,请将该 IP 地址添加到接口定义,然后再次执行“ifup”操作。服务器会尽量做到只更新那些已更改的设置。这适用于链路级选项,例如设备 MTU 或 MAC 地址;也适用于网络级设置,例如地址、路由,甚至地址配置模式(例如,从静态配置转为 DHCP 时)。
当然,对于合并了多个实体设备(例如桥接或绑定设备)的虚拟接口,事情会变得有些棘手。对于绑定设备,当设备运行时,您无法更改某些参数,否则会导致出错。
但是,您仍可以添加或去除绑定设备或桥接的子设备,或者选择绑定设备的主接口。
17.6.1.7 Wicked 扩展:地址配置 #
wicked
设计为使用外壳脚本扩展。这些扩展可在 config.xml
文件中定义。
目前支持多个种类的扩展:
链路配置:这些脚本负责根据客户端提供的配置来设置设备的链路层,以及负责将链路层再次拆解。
地址配置:这些脚本负责管理设备的地址配置。通常,地址配置和 DHCP 由
wicked
自身管理,但是,可借助扩展来实现。防火墙扩展:这些脚本可以应用防火墙规则。
通常,扩展中包含一个启动命令和一个停止命令、一个可选的“pid 文件”,以及传递给脚本的一组环境变量。
为了演示此扩展的工作原理,请查看 etc/server.xml
中定义的防火墙扩展:
<dbus-service interface="org.opensuse.Network.Firewall"> <action name="firewallUp" command="/etc/wicked/extensions/firewall up"/> <action name="firewallDown" command="/etc/wicked/extensions/firewall down"/> <!-- default environment for all calls to this extension script --> <putenv name="WICKED_OBJECT_PATH" value="$object-path"/> <putenv name="WICKED_INTERFACE_NAME" value="$property:name"/> <putenv name="WICKED_INTERFACE_INDEX" value="$property:index"/> </dbus-service>
该扩展附加到
<dbus-service>
标记,并定义针对此接口的操作应执行的命令。此外,声明可以定义并初始化传递给操作的环境变量。
17.6.1.8 Wicked 扩展:配置文件 #
您也可以使用脚本来扩展配置文件的处理。例如,extensions/resolver
脚本根据 server.xml
中配置的行为来最终处理租用中的 DNS 更新:
<system-updater name="resolver"> <action name="backup" command="/etc/wicked/extensions/resolver backup"/> <action name="restore" command="/etc/wicked/extensions/resolver restore"/> <action name="install" command="/etc/wicked/extensions/resolver install"/> <action name="remove" command="/etc/wicked/extensions/resolver remove"/> </system-updater>
当 wickedd
中收到更新时,系统更新程序例程将分析租用,并调用解析程序脚本中的适当命令(backup
、install
等)。此后便可以使用 /sbin/netconfig
或者通过手动写入 /run/netconfig/resolv.conf
(作为回退)来配置 DNS 设置。
17.6.2 配置文件 #
本节对网络配置文件进行了概述并解释了它们的作用和所使用的格式。
17.6.2.1 /etc/wicked/common.xml
#
/etc/wicked/common.xml
文件包含所有应用程序应使用的通用定义。该文件源自/包含在此目录中的其他配置文件中。尽管您可以使用此文件允许在所有 wicked
组件间进行调试,但建议使用 /etc/wicked/local.xml
文件来实现此目的。应用维护更新后,您所做的更改可能会丢失,因为 /etc/wicked/common.xml
可能会被覆盖。/etc/wicked/common.xml
文件包含默认安装中的 /etc/wicked/local.xml
,因此您通常不需要修改 /etc/wicked/common.xml
。
如果要通过将 <use-nanny>
设置为 false
来禁用 nanny
,请重启动 wickedd.service
,然后运行以下命令以应用所有配置和策略:
tux >
sudo
wicked ifup all
如果 wickedd
、wicked
或 nanny
程序自身的配置文件不存在,则会尝试读取 /etc/wicked/common.xml
。
17.6.2.2 /etc/wicked/server.xml
#
wickedd
服务器进程会在启动时读取文件 /etc/wicked/server.xml
。该文件将扩展储存到 /etc/wicked/common.xml
中。除此之外,此文件可配置解析程序的处理方式,以及从 addrconf
请求方(例如 DHCP)接收信息的方式。
建议您将需要对此文件进行的所有更改都添加到单独的文件 /etc/wicked/server-local.xml
(/etc/wicked/server.xml
)。使用单独的文件可避免在维护更新期间覆盖您的更改。
17.6.2.3 /etc/wicked/client.xml
#
/etc/wicked/client.xml
供 wicked
命令使用。该文件指定发现 ibft 管理的设备时所用脚本的位置,并可配置网络接口配置的位置。
建议您将需要对此文件进行的所有更改都添加到单独的文件 /etc/wicked/client-local.xml
(/etc/wicked/server.xml
会包含该文件的内容)。使用单独的文件可避免在维护更新期间覆盖您的更改。
17.6.2.4 /etc/wicked/nanny.xml
#
/etc/wicked/nanny.xml
配置链接层的类型。建议您将特定配置添加到单独的文件 /etc/wicked/nanny-local.xml
中,以免在维护更新期间丢失更改。
17.6.2.5 /etc/sysconfig/network/ifcfg-*
#
这些文件包含网络接口的传统配置。在 SUSE Linux Enterprise 11 中,这是除 iBFT 固件以外唯一支持的格式。
wicked
和 ifcfg-*
文件
如果您指定 compat:
前缀,wicked
将读取这些文件。根据 /etc/wicked/client.xml
中 SUSE Linux Enterprise Desktop 的默认配置,wicked
将尝试先读取这些文件,然后再读取 /etc/wicked/ifconfig
中的 XML 配置文件。
通常,提供 --ifconfig
开关仅用于测试。如果指定该开关,则不会应用 /etc/wicked/ifconfig
中定义的默认配置源。
ifcfg-*
文件包含启动模式和 IP 地址等信息。可能的参数在 ifup
的手册页中有所介绍。此外,如果一个常规设置只能用于一个接口,则文件 dhcp
和 wireless
中的大多数变量可用于 ifcfg-*
文件。但是,/etc/sysconfig/network/config
中的大多数变量是全局变量,不能在 ifcfg-files 中被覆盖。例如,NETCONFIG_*
变量是全局变量。
要配置 macvlan
和 macvtab
接口,请参见 ifcfg-macvlan
和 ifcfg-macvtap
手册页。例如,对于 macvlan 接口,请提供使用以下设置的 ifcfg-macvlan0
:
STARTMODE='auto' MACVLAN_DEVICE='eth0' #MACVLAN_MODE='vepa' #LLADDR=02:03:04:05:06:aa
有关 ifcfg.template
的信息,请参见第 17.6.2.6 节 “/etc/sysconfig/network/config
、/etc/sysconfig/network/dhcp
和 /etc/sysconfig/network/wireless
”。
17.6.2.6 /etc/sysconfig/network/config
、/etc/sysconfig/network/dhcp
和 /etc/sysconfig/network/wireless
#
文件 config
包含 ifup
、ifdown
和 ifstatus
行为的常规设置。dhcp
包含用于无线 LAN 卡的 DHCP 和 wireless
设置。所有三个配置文件中的变量均已注释掉。/etc/sysconfig/network/config
中的一些变量也可用于 ifcfg-*
文件,在这些文件中它们具有更高优先级。/etc/sysconfig/network/ifcfg.template
文件列出可以按接口指定的变量。但是,/etc/sysconfig/network/config
中的大多数变量是全局变量,不能在 ifcfg-files 中被覆盖。例如,NETWORKMANAGER
或 NETCONFIG_*
变量是全局变量。
在 SUSE Linux Enterprise 11 中,即使是在未正确配置 IPv6 路由器广播 (RA) 的网络中,DHCPv6 一向也能正常工作。从 SUSE Linux Enterprise 12 开始,DHCPv6 将适当地要求网络中至少有一个路由器发出 RA,用于指示此网络由 DHCPv6 管理。
对于无法在其中正确配置路由器的网络,用户可以通过在 ifcfg
文件中指定 DHCLIENT6_MODE='managed'
,使用 ifcfg
选项来覆盖此行为。您也可以在安装系统中使用引导参数来启用这种解决方法:
ifcfg=eth0=dhcp6,DHCLIENT6_MODE=managed
17.6.2.7 /etc/sysconfig/network/routes
和 /etc/sysconfig/network/ifroute-*
#
TCP/IP 包的静态路由是 /etc/sysconfig/network/routes
和 /etc/sysconfig/network/ifroute-*
文件确定的。可以在 /etc/sysconfig/network/routes
中指定各种系统任务所需的所有静态路由:主机的路由、主机通过网关的路由以及网络的路由。对于需要个别路由的每个接口,定义另一个配置文件:/etc/sysconfig/network/ifroute-*
。将通配符 (*
) 替换为接口名称。路由选择配置文件中的项如下所示:
# Destination Gateway Netmask Interface Options
路由目标位于首列。此列可以包含网络或主机的 IP 地址,或者在有可访问名称服务器时,包含完全限定的网络或主机名。应该以 CIDR 表示法(地址加上关联的路由前缀长度)输入网络名称,例如 10.10.0.0/16(对于 IPv4 路由)或 fc00::/7(对于 IPv6 路由)。关键字 default
表示该路由是与网关位于相同地址系列中的默认网关。对于没有网关的设备,请使用显式 0.0.0.0/0 或 ::/0 目标。
第二列包含默认网关或通过其可访问主机或网络的网关。
第三列已弃用;它用于包含目标的 IPv4 网络掩码。对于 IPv6 路由、默认路由,或者如果在第一列中使用了前缀长度(CIDR 表示法),请在此处输入破折号 (-
)。
第四列包含接口名称。如果使用破折号 (-
) 将它保留空白,可能会导致 /etc/sysconfig/network/routes
出现意外的行为。有关更多信息,请参见 routes
手册页。
第五列(可选)可用于指定特殊选项。有关详细信息,请参见 routes
手册页。
# --- IPv4 routes in CIDR prefix notation: # Destination [Gateway] - Interface 127.0.0.0/8 - - lo 204.127.235.0/24 - - eth0 default 204.127.235.41 - eth0 207.68.156.51/32 207.68.145.45 - eth1 192.168.0.0/16 207.68.156.51 - eth1 # --- IPv4 routes in deprecated netmask notation" # Destination [Dummy/Gateway] Netmask Interface # 127.0.0.0 0.0.0.0 255.255.255.0 lo 204.127.235.0 0.0.0.0 255.255.255.0 eth0 default 204.127.235.41 0.0.0.0 eth0 207.68.156.51 207.68.145.45 255.255.255.255 eth1 192.168.0.0 207.68.156.51 255.255.0.0 eth1 # --- IPv6 routes are always using CIDR notation: # Destination [Gateway] - Interface 2001:DB8:100::/64 - - eth0 2001:DB8:100::/32 fe80::216:3eff:fe6d:c042 - eth0
17.6.2.8 /var/run/netconfig/resolv.conf
#
主机所属的域在 /var/run/netconfig/resolv.conf
中指定(关键字 search
)。使用 search
选项最多可以指定六个域,总共 256 个字符。当解析不是完全限定的名称时,将尝试通过附加单独的 search
项生成一个完全限定的名称。使用 nameserver
选项最多可以指定三个名称服务器,每行指定一个。注释以井号或分号(#
或 ;
)开头。有关示例,请参见例 17.6 “/var/run/netconfig/resolv.conf
”。
但是,不应手动编辑 /etc/resolv.conf
。此文件由 netconfig
脚本生成,它是 /run/netconfig/resolv.conf
的符号链接。要定义静态 DNS 配置而不使用 YaST,请手动编辑 /etc/sysconfig/network/config
文件中的相应变量:
NETCONFIG_DNS_STATIC_SEARCHLIST
用于主机名查找的 DNS 域名列表
NETCONFIG_DNS_STATIC_SERVERS
用于主机名查找的名称服务器 IP 地址列表
NETCONFIG_DNS_FORWARDER
需要配置的 DNS 转发器名称,例如
bind
或resolver
NETCONFIG_DNS_RESOLVER_OPTIONS
将写入到
/var/run/netconfig/resolv.conf
的任意选项,例如:debug attempts:1 timeout:10
有关更多信息,请参见
resolv.conf
手册页。NETCONFIG_DNS_RESOLVER_SORTLIST
最多包含 10 项的列表,例如:
130.155.160.0/255.255.240.0 130.155.0.0
有关更多信息,请参见
resolv.conf
手册页。
要使用 netconfig 禁用 DNS 配置,请设置 NETCONFIG_DNS_POLICY=''
。有关 netconfig
的更多信息,请参见 netconfig(8)
手册页 (man 8 netconfig
)。
/var/run/netconfig/resolv.conf
## Our domain search example.com # # We use dns.example.com (192.168.1.116) as nameserver nameserver 192.168.1.116
17.6.2.9 /sbin/netconfig
#
netconfig
是一个用于管理附加网络配置设置的模块化工具。它合并了静态定义的设置和自动配置机制根据预定义策略以 DHCP 或 PPP 形式提供的设置。通过调用负责修改配置文件和重启动服务或相似操作的 netconfig 模块将所需更改应用于系统。
netconfig
识别三种主要操作。netconfig modify
和 netconfig remove
命令由诸如 DHCP 或 PPP 的守护程序用于在 netconfig 中提供设置或从中删除设置。仅 netconfig update
命令可用于用户:
modify
netconfig modify
命令修改特定于当前接口和服务的动态设置并更新网络配置。Netconfig 会从标准输入或从使用--lease-file FILENAME
选项指定的文件中读取设置,并将其储存在内部,直到系统重引导(或者执行下一个修改或删除操作)为止。已存在的相同接口和服务组合设置将会重写。该接口由-i INTERFACE_NAME
参数指定。该服务由-s SERVICE_NAME
参数指定。remove
netconfig remove
命令为指定接口和服务组合删除由修改操作提供的动态设置并更新网络配置。该接口由-i INTERFACE_NAME
参数指定。该服务由-s SERVICE_NAME
参数指定。update
netconfig update
命令使用当前设置更新网络配置。当策略或静态配置更改时,这非常有用。如果只想更新指定的服务(dns
、nis
或ntp
),请使用-m MODULE_TYPE
参数。
netconfig 策略和静态配置设置可手动定义或者使用 YaST 在 /etc/sysconfig/network/config
文件中定义。自动配置工具(例如 DHCP 或 PPP)提供的动态配置设置由这些工具通过 netconfig modify
和 netconfig remove
操作直接递送。启用 NetworkManager 时,netconfig(在策略模式 auto
中)仅使用 NetworkManager 设置,忽略使用传统 ifup 方法配置的任何其他接口的设置。如果 NetworkManager 未提供任何设置,将使用静态设置作为后备设置。不支持混合使用 NetworkManager 和 wicked
方法。
有关 netconfig
的更多信息,请参见 man 8 netconfig
。
17.6.2.10 /etc/hosts
#
在此文件中,如例 17.7 “/etc/hosts
”中所示,将为主机名指派 IP 地址。如果未实施名称服务器,则将与其建立 IP 连接的所有主机必须列在此处。在此文件中为每个主机输入一行数据,包含 IP 地址、完全限定的主机名和主机名。IP 地址必须在每行的开头,各项用空格和制表符隔开。注释总是以 #
符号开头。
/etc/hosts
#127.0.0.1 localhost 192.168.2.100 jupiter.example.com jupiter 192.168.2.101 venus.example.com venus
17.6.2.11 /etc/networks
#
在这里,网络名称被转换为网络地址。格式类似于 hosts
文件的格式,只是网络名称在地址的前面。请参见例 17.8 “/etc/networks
”。
/etc/networks
#loopback 127.0.0.0 localnet 192.168.0.0
17.6.2.12 /etc/host.conf
#
此文件控制名称解析,即通过解析程序库转换主机名和网络名称。此文件只用于链接到 libc4 或 libc5 的程序。对于当前的 glibc 程序,请参见 /etc/nsswitch.conf
中的设置。每个参数都必须始终在单独的一行中输入。注释以 #
符号开头。表 17.2 “/etc/host.conf 的参数” 显示了可用的参数。例 17.9 “/etc/host.conf
” 中显示了 /etc/host.conf
的示例。
order hosts、bind |
指定访问服务以进行名称解析的顺序。可用参数有(使用空格或逗号隔开): |
hosts:搜索 | |
bind:访问名称服务器 | |
nis:使用 NIS | |
multi on/off |
定义 |
nospoof on spoofalert on/off |
这些参数影响名称服务器 spoofing,但对网络配置没有任何影响。 |
trim domainname |
在主机名解析后,指定的域名将与主机名分开(前提是主机名包含域名)。此选项仅当本地域名在 |
/etc/host.conf
## We have named running order hosts bind # Allow multiple address multi on
17.6.2.13 /etc/nsswitch.conf
#
GNU C Library 2.0 的引入与 名称服务转换 (NNS) 的引入是同时进行的。有关详细信息,请参见 nsswitch.conf(5)
手册页和《GNU C 库参考手册》。
查询的顺序是在文件 /etc/nsswitch.conf
中定义的。例 17.10 “/etc/nsswitch.conf
” 中显示了 nsswitch.conf
的示例。注释以 #
符号开头。在本例中,hosts
数据库下的项意味着通过 DNS 将请求发送到 /etc/hosts
(files
)。
/etc/nsswitch.conf
#passwd: compat group: compat hosts: files dns networks: files dns services: db files protocols: db files rpc: files ethers: files netmasks: files netgroup: files nis publickey: files bootparams: files automount: files nis aliases: files nis shadow: compat
表 17.3 “通过 /etc/nsswitch.conf 可用的数据库” 中列出了 NSS 上可用的“数据库”。表 17.4 “NSS“数据库”的配置选项”中列出了 NSS 数据库的配置选项。
|
|
|
以太网地址。 |
|
网络及其子网掩码的列表。只有在使用子网划分时才需要。 |
|
|
|
|
|
网络中用于控制访问权限的有效主机和用户列表,请参见 |
|
|
|
NFS 和 NIS+ 使用的 Secure_RPC 的公钥和密钥。 |
|
|
|
网络协议,由 |
|
|
|
|
|
用户阴影口令,由 |
|
直接访问文件,例如 |
|
通过数据库访问 |
|
NIS,另请参见Book “Security and Hardening Guide”, Chapter 3 “Using NIS” |
|
仅可用作 |
|
仅可用作 |
17.6.2.14 /etc/nscd.conf
#
此文件用于配置 nscd(名称服务缓存守护程序)。请参见 nscd(8)
和 nscd.conf(5)
手册页。默认情况下,passwd
、groups
和 hosts
的系统项由 nscd 进行缓存。这对 NIS 和 LDAP 等目录服务的性能而言非常重要,否则,每次访问名称、组或主机都需要网络连接。
如果激活 passwd
的缓存,则通常需要 15 秒才能识别新添加的本地用户。使用以下命令重启动 nscd,缩短这段等待时间:
tux >
sudo
systemctl restart nscd
17.6.2.15 /etc/HOSTNAME
#
/etc/HOSTNAME
包含完全限定的主机名 (FQHN)。完全限定的主机名是附有域名的主机名。此文件只能包含一行(在此行中设置主机名)。计算机引导时会读取此文件。
17.6.3 测试配置 #
向配置文件写配置之前,可对其进行测试。要设置测试配置,请使用 ip
命令。要测试连接,请使用 ping
命令。
命令 ip
会直接更改网络配置,而不会将其保存到配置文件中。如果未在正确的配置文件中输入配置,重引导时将丢失已更改的网络配置。
ifconfig
和 route
已过时
ifconfig
和 route
工具已过时。请改为使用 ip
。例如,ifconfig
会将接口名限制为 9 个字符。
17.6.3.1 使用 ip
配置网络接口 #
ip
是用来显示和配置网络设备、路由选择、策略路由选择以及隧道的工具。
ip
是非常复杂的工具。它的常用语法为 ip
OPTIONS
OBJECT
COMMAND
。可使用以下对象:
- link
此对象表示网络设备。
- address
此对象表示设备的 IP 地址。
- neighbor
此对象表示 ARP 或 NDISC 超速缓存项。
- route
此对象表示路由选择表项。
- rule
此对象表示路由选择策略数据库中的规则。
- maddress
此对象表示多路广播地址。
- mroute
此对象表示多路广播路由缓存项。
- tunnel
此对象表示 IP 上的隧道。
如果未提供命令,则将使用默认命令(通常为 list
)。
使用 ip link set
DEVICE_NAME
命令更改设备的状态。例如,要停用设备 eth0,请输入
ip link set
eth0 down
。要重激活它,可使用 ip link set
eth0 up
。
激活设备后,可对设备进行配置。要设置 IP 地址,可使用 ip addr add
IP_ADDRESS + dev DEVICE_NAME
。例如,要将接口 eth0 的地址设置为带标准广播(选项 brd
)的 192.168.12.154/30,则输入 ip addr
add 192.168.12.154/30 brd + dev eth0
。
要拥有活动连接,还必须配置默认网关。要设置系统的网关,请输入 ip route add
gateway_ip_address
。要将一个 IP 地址转换为另一个 IP 地址,请使用 nat
: ip route add nat
ip_address
via
other_ip_address
。
要显示所有设备,可使用 ip link ls
。要只显示正在运行的接口,可使用 ip link ls up
。要打印设备的接口统计信息,可输入 ip -s link ls
device_name
。要查看设备的地址,请输入 ip addr
。在 ip addr
的输出中,还可找到有关设备 MAC 地址的信息。要显示所有路由,可使用 ip route show
。
有关使用 ip
的更多信息,请输入 ip
help
或参见 ip(8)
手册页。help
选项还可用于所有 ip
子命令。例如,如果需要有关 ip
addr
的帮助,请输入 ip
addr help
。可在 /usr/share/doc/packages/iproute2/ip-cref.pdf
中找到 ip
手册。
17.6.3.2 使用 ping 测试连接 #
ping
命令是用于测试 TCP/IP 连接是否有效的标准工具。它使用 ICMP 协议来将小数据包和 ECHO_REQUEST 数据报文发送到目标主机,并请求即时答复。如果成功,ping
将显示表示这一结果的消息。这表示网络链路正在运作。
ping
不仅能测试两台计算机之间的连接功能:它还能提供关于连接质量的一些基本信息。在例 17.11 “命令 ping 的输出” 中,可查看 ping
输出示例。倒数第二行包含有关已传输的包数、丢失的包和 ping
的总运行时间的信息。
因此,您可以使用主机名或 IP 地址(例如 ping
example.com
或 ping
192.168.3.100
)。程序会一直发送包,直到您按 Ctrl–C。
如果只需要检查连接功能,则可使用 -c
选项来限制包数。例如,要将 ping 限制为三个包,请输入 ping
-c 3 example.com
。
ping -c 3 example.com PING example.com (192.168.3.100) 56(84) bytes of data. 64 bytes from example.com (192.168.3.100): icmp_seq=1 ttl=49 time=188 ms 64 bytes from example.com (192.168.3.100): icmp_seq=2 ttl=49 time=184 ms 64 bytes from example.com (192.168.3.100): icmp_seq=3 ttl=49 time=183 ms --- example.com ping statistics --- 3 packets transmitted, 3 received, 0% packet loss, time 2007ms rtt min/avg/max/mdev = 183.417/185.447/188.259/2.052 ms
两个包之间的默认时间间隔为一秒。ping 提供了选项 -i
来更改间隔。例如,要将 ping 间隔增加到十秒,请输入 ping
-i 10 example.com
。
在带有多个网络设备的系统中,有时通过特定接口地址发送 ping 将会非常有用。要执行此操作,可将 -I
选项结合选定设备名称一起使用,例如 ping
-I wlan1 example.com
。
有关使用 ping 的更多选项和信息,请输入 ping
-h
或查看 ping (8)
手册页。
对于 IPv6 地址,请使用 ping6
命令。请注意,要 ping 本地链路地址,必须用 -I
指定接口。如果通过 eth1
可获取地址,则以下命令有效:
ping6 -I eth1 fe80::117:21ff:feda:a425
17.6.4 单元文件和启动脚本 #
除了上面介绍的配置文件之外,还存在一些负责在引导计算机时装载网络服务的 systemd 单元文件和多个脚本。系统切换到 multi-user.target
目标后,即会启动这些文件和脚本。网络程序的一些单元文件和启动脚本中介绍了其中的部分单元文件和脚本。有关 systemd
的更多信息,请参见第 13 章 “systemd
守护程序”;有关 systemd
目标的更多信息,请参见 systemd.special
的手册页 (man systemd.special
)。
network.target
network.target
是网络的 systemd 目标,但其具体含义取决于系统管理员提供的设置。有关详细信息,请参见 http://www.freedesktop.org/wiki/Software/systemd/NetworkTarget/。
multi-user.target
multi-user.target
是包含所有必需网络服务的多用户系统的 systemd 目标。rpcbind
启动用于将 RPC 程序号转换为通用地址的 rpcbind 实用程序。它是 RPC 服务所必需的,如 NFS 服务器。
ypserv
启动 NIS 服务器。
ypbind
启动 NIS 客户端。
/etc/init.d/nfsserver
启动 NFS 服务器。
/etc/init.d/postfix
控制 postfix 进程。
17.7 设置绑定设备 #
对于某些系统,需要实施高于典型以太网设备的标准数据安全性或可用性要求的网络连接。在这些情况下,可以将多个以太网设备聚合到单个绑定设备。
绑定设备的配置通过绑定模块选项来完成。其行为主要受绑定设备模式的影响。默认情况下是 active-backup
,即如果活动从属设备发生故障,则另一个从属设备将变成活动从属设备。可以使用以下绑定模式:
- (balance-rr)
数据包依次通过第一个到最后一个可用接口传输。提供容错和负载平衡。
- (active-backup)
只有一个网络接口处于活动状态。如果它发生故障,另一个接口将变成活动状态。此设置是 SUSE Linux Enterprise Desktop 的默认设置。提供容错。
- (balance-xor)
根据以下策略在所有可用接口间拆分通讯:
[(source MAC address XOR'd with destination MAC address XOR packet type ID) modulo slave count]
需要交换机的支持。提供容错和负载平衡。- (broadcast)
在所有接口上广播所有通讯。需要交换机的支持。提供容错。
- (802.3ad)
将接口聚合成共享相同速度和双工设置的组。需要接口驱动程序中的
ethtool
支持,以及支持 IEEE 802.3ad 动态链路聚合并进行了相应配置的交换机。提供容错和负载平衡。- (balance-tlb)
自适应传输负载平衡。需要接口驱动程序中的
ethtool
支持,但不需要交换机支持。提供容错和负载平衡。- (balance-alb)
自适应负载平衡。需要接口驱动程序中的
ethtool
支持,但不需要交换机支持。提供容错和负载平衡。
有关各种模式的详细说明,请参见https://www.kernel.org/doc/Documentation/networking/bonding.txt。
绑定设备只对于有多个真实网卡可用的计算机有效。这意味着在大多数配置中,您仅应在 Dom0 中使用绑定配置。换言之,只有当您将多个网卡指派给一个 VM Guest 系统时,在 VM Guest 中设置绑定才有效。
tlb/alb 绑定配置与 Power 固件之间存在冲突。简单而言,处于 tlb/alb 模式的绑定驱动程序会发送同时包含源和目标 MAC 地址(列作虚拟以太网 MAC 地址)的以太网回写包。Power 固件并不支持这些包。因此,ibmveth 不支持绑定模式 5 和 6。
要配置绑定设备,请使用以下过程:
17.7.1 绑定从属的热插拔 #
在特定网络环境(如高可用性)下,有几种情况需要替换绑定从属接口。原因可能在于网络设备持续故障。解决方案是设置绑定从属的热插拔。
按常规配置绑定(按照 man 5 ifcfg-bonding
),例如:
ifcfg-bond0 STARTMODE='auto' # or 'onboot' BOOTPROTO='static' IPADDR='192.168.0.1/24' BONDING_MASTER='yes' BONDING_SLAVE_0='eth0' BONDING_SLAVE_1='eth1' BONDING_MODULE_OPTS='mode=active-backup miimon=100'
使用 STARTMODE=hotplug
和 BOOTPROTO=none
指定从属:
ifcfg-eth0 STARTMODE='hotplug' BOOTPROTO='none' ifcfg-eth1 STARTMODE='hotplug' BOOTPROTO='none'
BOOTPROTO=none
使用 ethtool
选项(如果提供),但不会在 ifup eth0
上设置链路,因为从属接口由绑定主接口控制。
STARTMODE=hotplug
会使从属接口在可用时自动加入绑定。
需要更改 /etc/udev/rules.d/70-persistent-net.rules
中的 udev
规则,以便按总线 ID(udev KERNELS
关键字等同于 hwinfo --netcard
中的“SysFS BusID”)而不是 MAC 地址匹配设备。这样允许更换有缺陷的硬件(位于同一插槽但 MAC 不同的网卡),并避免在绑定更改其所有从属设备的 MAC 地址时出现混淆。
例如:
SUBSYSTEM=="net", ACTION=="add", DRIVERS=="?*", KERNELS=="0000:00:19.0", ATTR{dev_id}=="0x0", ATTR{type}=="1", KERNEL=="eth*", NAME="eth0"
在引导时,systemd network.service
不会等待热插拔从属,但会等待绑定准备就绪,而这需要至少有一个从属可用。当从系统中去除一个从属接口时(从 NIC 驱动程序拆开联结、执行 NIC 驱动程序的 rmmod
命令或 PCI 热插拔去除为 true),内核会自动从绑定中将其去除。当向系统添加新网卡时(替换插槽中的硬件),udev
会使用基于总线的网卡设备名称规则将其重命名为从属接口的名称,并为其调用 ifup
命令。ifup
命令会自动调用以将新网卡加入绑定。
17.8 设置小组设备以进行网络协作 #
“链路聚合”属于通用术语,指组合(或聚合)网络连接以提供逻辑层。有时,您还会看到“通道聚合”、“以太网绑定”、“端口汇聚”等术语,这些同义词都是指同一个概念。
这个概念通常被称为“绑定”,最初是集成到 Linux 内核中的(请参见第 17.7 节 “设置绑定设备”了解最初的实现方式)。网络协作一词用来指代这个概念的新实现方式。
绑定和网络协作之间的主要差别在于,协作提供一组小型内核模块,由它们负责提供用于 teamd 实例的接口。其他一切都在用户空间中处理。这一点与最初的绑定实现方式不同,后者是将自己的所有功能都专门包含在内核中。如需两者的比较,请参见表 17.5 “绑定与组合的功能比较”。
特性 | 绑定 | 组合 |
---|---|---|
广播、循环 TX 策略 | 是 | 是 |
活动备份 TX 策略 | 是 | 是 |
LACP (802.3ad) 支持 | 是 | 是 |
基于哈希的 TX 策略 | 是 | 是 |
用户可以设置哈希函数 | 否 | 是 |
TX 负载平衡支持 (TLB) | 是 | 是 |
针对 LACP 的 TX 负载平衡支持 | 否 | 是 |
Ethtool 链接监视 | 是 | 是 |
ARP 链接监视 | 是 | 是 |
NS/NA (IPV6) 链接监视 | 否 | 是 |
针对 TX/RX 路径的 RCU 锁定 | 否 | 是 |
端口优先级和粘性 | 否 | 是 |
单独的按端口链接监视设置 | 否 | 是 |
多链接监视设置 | 有限制 | 是 |
VLAN 支持 | 是 | 是 |
多设备堆叠 | 是 | 是 |
源: http://libteam.org/files/teamdev.pp.pdf |
绑定和网络协作这两种实现方式可以并行使用。可将网络协作作为现有绑定实现方式的备选。它不会取代绑定。
网络协作可用于不同使用情况。稍后将会介绍其中两种最重要的使用情况,它们涉及:
不同网络设备之间的负载平衡。
从一个网络设备到另一个网络设备的故障转移(当其中一个设备出现故障时)。
目前没有用于支持创建协作设备的 YaST 模块。您需要手动配置网络协作。以下是适用于所有网络协作配置的一般过程:
确保已安装所有必需的包。安装包 libteam-tools、 libteamdctl0 和 python-libteam。
在
/etc/sysconfig/network/
下创建一个配置文件,通常为ifcfg-team0
。如果您需要多个网络协作设备,请为它们指定依次递增的编号。该配置文件包含若干变量,手册页中对这些变量做了说明(请参见
man ifcfg
和man ifcfg-team
)。系统内的/etc/sysconfig/network/ifcfg.template
文件中提供了示例配置。去除将用于协作设备的接口的配置文件(通常为
ifcfg-eth0
和ifcfg-eth1
)。建议您先备份这两个文件,然后再将其去除。Wicked 将会使用协作的必要参数重新创建配置文件。
(可选)检查 Wicked 的配置文件中是否已包含所有内容:
tux >
sudo
wicked show-config
启动网络协作设备
team0
:tux >
sudo
wicked ifup all team0
如果您需要其他调试信息,请在
all
子命令后面使用--debug all
选项。检查网络协作设备的状态。通过执行以下命令可以完成该操作:
从 Wicked 获取 teamd 实例的状态:
tux >
sudo
wicked ifstatus --verbose team0
获取整个实例的状态:
tux >
sudo
teamdctl team0 state
获取 teamd 实例的 systemd 状态:
tux >
sudo
systemctl status teamd@team0
以上各命令将根据您的需要分别显示稍有不同的视图。
如果您之后需要对
ifcfg-team0
文件中的内容进行更改,请使用以下命令重新装载其配置:tux >
sudo
wicked ifreload team0
请勿使用 systemctl
来启动或停止协作设备!而是使用如上所示的 wicked
命令。
要彻底去除组合设备,请执行以下过程:
停止网络组合设备
team0
:tux >
sudo
wicked ifdown team0
将文件
/etc/sysconfig/network/ifcfg-team0
重命名为/etc/sysconfig/network/.ifcfg-team0
。在文件名前面插入一个点,以使 wicked“看不到”它。如果您确实不再需要该配置,也可以去除该文件。重新装载配置:
tux >
sudo
wicked ifreload all
17.8.1 使用案例:网络协作间的负载平衡 #
负载平衡用于提高带宽。使用下面的配置文件可创建具有负载平衡功能的网络协作设备。继续过程 17.1 “一般过程”以设置设备。使用 teamdctl
检查输出。
STARTMODE=auto 1 BOOTPROTO=static 2 IPADDRESS="192.168.1.1/24" 2 IPADDR6="fd00:deca:fbad:50::1/64" 2 TEAM_RUNNER="loadbalance" 3 TEAM_LB_TX_HASH="ipv4,ipv6,eth,vlan" TEAM_LB_TX_BALANCER_NAME="basic" TEAM_LB_TX_BALANCER_INTERVAL="100" TEAM_PORT_DEVICE_0="eth0" 4 TEAM_PORT_DEVICE_1="eth1" 4 TEAM_LW_NAME="ethtool" 5 TEAM_LW_ETHTOOL_DELAY_UP="10" 6 TEAM_LW_ETHTOOL_DELAY_DOWN="10" 6
控制协作设备的启动。
如果您需要自己来控制设备(并阻止其自动启动),请将 | |
设置静态 IP 地址(此处对于 IPv4 指定
如果网络协作设备应该使用动态 IP 地址,请设置 | |
将 | |
指定应聚合以创建网络协作设备的一个或多个设备。 | |
定义链路监视器,以监视从属设备的状态。只有当设备已启动并可访问时,默认值
如果您需要确保连接的可信度更高,请使用 | |
定义链路启动(或关闭)与运行程序收到通知之间的延迟(以毫秒为单位)。 |
17.8.2 使用案例:使用网络协作实现故障转移 #
故障转移用于确保关键网络协作设备的高可用性,方法是纳入并行的备用网络设备。备用网络设备时刻都在运行,并在主设备出现故障时接替主设备。
使用以下配置文件可创建具有故障转移功能的网络协作设备。继续过程 17.1 “一般过程”以设置设备。使用 teamdctl
检查输出。
STARTMODE=auto 1 BOOTPROTO=static 2 IPADDR="192.168.1.2/24" 2 IPADDR6="fd00:deca:fbad:50::2/64" 2 TEAM_RUNNER=activebackup 3 TEAM_PORT_DEVICE_0="eth0" 4 TEAM_PORT_DEVICE_1="eth1" 4 TEAM_LW_NAME=ethtool 5 TEAM_LW_ETHTOOL_DELAY_UP="10" 6 TEAM_LW_ETHTOOL_DELAY_DOWN="10" 6
控制协作设备的启动。
如果您需要自己来控制设备(并阻止其自动启动),请将 | |
设置静态 IP 地址(此处对于 IPv4 指定
如果网络协作设备应该使用动态 IP 地址,请设置 | |
将 | |
指定应聚合以创建网络协作设备的一个或多个设备。 | |
定义链路监视器,以监视从属设备的状态。只有当设备已启动并可访问时,默认值
如果您需要确保连接的可信度更高,请使用 | |
定义链路启动(或关闭)与运行程序收到通知之间的延迟(以毫秒为单位)。 |
17.8.3 用例:组合设备上的 VLAN #
VLAN 是虚拟局域网 (Virtual Local Area Network) 的缩写。它允许在单个物理以太网上运行多个逻辑(虚拟)以太网。它以逻辑方式将网络分为不同的广播域,以便数据包仅在为同一 VLAN 指定的端口之间交换。
下面的用例会在组合设备的基础上创建两个静态 VLAN:
vlan0
,绑定到 IP 地址192.168.10.1
vlan1
,绑定到 IP 地址192.168.20.1
按如下所示继续:
在交换机上启用 VLAN 标记。要针对组合设备使用负载平衡,交换机需要支持链接聚合控制协议 (LACP) (802.3ad)。有关细节,请查阅硬件手册。
确定是否要针对组合设备使用负载平衡或故障转移。按第 17.8.1 节 “使用案例:网络协作间的负载平衡”或第 17.8.2 节 “使用案例:使用网络协作实现故障转移”中所述设置组合设备。
在
/etc/sysconfig/network
中,创建包含以下内容的ifcfg-vlan0
文件:STARTMODE="auto" BOOTPROTO="static" 1 IPADDR='192.168.10.1/24' 2 ETHERDEVICE="team0" 3 VLAN_ID="0" 4 VLAN='yes'
将
/etc/sysconfig/network/ifcfg-vlan0
文件复制到/etc/sysconfig/network/ifcfg-vlan1
,并更改以下值:IPADDR
,从192.168.10.1/24
更改为192.168.20.1/24
。VLAN_ID
,从0
更改为1
。
启动两个 VLAN:
root #
wicked
ifup vlan0 vlan1检查
ifconfig
的输出:root #
ifconfig
-a [...] vlan0 Link encap:Ethernet HWaddr 08:00:27:DC:43:98 inet addr:192.168.10.1 Bcast:192.168.10.255 Mask:255.255.255.0 inet6 addr: fe80::a00:27ff:fedc:4398/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:0 errors:0 dropped:0 overruns:0 frame:0 TX packets:12 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:0 (0.0 b) TX bytes:816 (816.0 b) vlan1 Link encap:Ethernet HWaddr 08:00:27:DC:43:98 inet addr:192.168.20.1 Bcast:192.168.20.255 Mask:255.255.255.0 inet6 addr: fe80::a00:27ff:fedc:4398/64 Scope:Link UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 RX packets:0 errors:0 dropped:0 overruns:0 frame:0 TX packets:12 errors:0 dropped:0 overruns:0 carrier:0 collisions:0 txqueuelen:1000 RX bytes:0 (0.0 b) TX bytes:816 (816.0 b)
18 打印机操作 #
SUSE® Linux Enterprise Desktop 支持使用多种类型的打印机进行打印,其中包括远程网络打印机。可以手动或使用 YaST 配置打印机。有关配置描述,请参见Book “Deployment Guide”, Chapter 15 “Setting Up Hardware Components with YaST”, Section 15.3 “Setting Up a Printer”。启动和管理打印任务时既可以使用图形实用程序,也可以使用命令行实用程序。如果打印机未能按预期正常工作,请参见第 18.8 节 “查错”。
CUPS(通用 Unix 打印系统)是 SUSE Linux Enterprise Desktop 中的标准打印系统。
可以根据接口(例如 USB 或网络)以及打印机语言对打印机进行区分。购买打印机时,确保打印机配有支持的接口(USB、以太网或 Wi-Fi)和合适的打印机语言。可以按照以下三类打印机语言对打印机进行分类:
- PostScript 打印机
Linux 和 Unix 中的内部打印系统使用 PostScript 这种打印机语言生成并处理大部分打印任务。如果打印机可以直接处理 PostScript 文档而不需要在打印系统中通过附加步骤转换这些文档,则可以降低可能出现的错误的数目。
PDF 正在逐渐取代 PostScript,成为标准打印作业格式。可直接打印 PDF(而不仅仅是 PostScript)的 PostScript+PDF 打印机已经面世。传统的 PostScript 打印机需要在打印工作流程中将 PDF 转换为 PostScript。
- 标准打印机(PCL 和 ESC/P 等语言)
对于已知的打印机语言,打印系统可以借助 Ghostscript 将 PostScript 作业转换为相应的打印机语言。此处理阶段称为解释。最有名的语言有 PCL(主要是 HP 打印机及其克隆产品使用)和 ESC/P(Epson 打印机使用)。这些打印机语言通常受 Linux 支持,可以生成令人满意的打印效果。Linux 可能无法使用某些特殊打印机功能。除了 HP 和 Epson 之外,当前尚没有其他打印机制造商开发 Linux 驱动程序,并通过开放源代码许可证将这些驱动程序提供给 Linux 发行套件供应商。
- 专有打印机(也称作 GDI 打印机)
这些打印机不支持任何常见的打印机语言。这些打印机使用自己的无文档记录打印机语言,该语言在发布新版本时可能发生变化。通常只有 Windows 驱动程序供这些打印机使用。有关更多信息,请参见第 18.8.1 节 “打印机没有标准打印机语言支持”。
在您购买新打印机之前,请参考以下资源以了解您要购买的打印机的支持情况:
- http://www.linuxfoundation.org/OpenPrinting/
包含打印机数据库的 OpenPrinting 主页。数据库显示最新的 Linux 支持状态。但是,Linux 分发只能集成生产时可用的驱动程序。因此,当前评定为“完全支持”的打印机在最新的 SUSE Linux Enterprise Desktop 版本发布后,不一定还具有此称号。这样,数据库不一定可以指出正确的状态,只是提供大致估计而已。
- http://pages.cs.wisc.edu/~ghost/
Ghostscript 网页
/usr/share/doc/packages/ghostscript/catalog.devices
内置 Ghostscript 驱动程序列表。
18.1 CUPS 工作流程 #
用户创建一个打印任务。打印作业由要打印的数据和有关假脱机程序的信息组成。其中包括打印机的名称或打印队列的名称,还有可能包括有关过滤器(例如特定于打印机的选项)的信息。
每台打印机至少有一个专用打印队列。假脱机程序储存着队列中的打印任务,直到所需打印机已做好接收数据的准备。打印机准备就绪后,假脱机程序通过过滤器和后端将数据发送到打印机。
过滤器将转换正在打印的应用程序生成的数据(通常为 PostScript 或 PDF,也可能为 ASCII、JPEG 等)特定于打印机的数据(PostScript、PCL、ESC/P 等)。PPD 文件中描述了打印机的功能。PPD 文件包含打印机特定的选项以及在打印机上启用这些选项所需的参数。过滤器系统用于确保用户选择的选项被启用。
如果使用的是 PostScript 打印机,则过滤器系统将数据转换为打印机特定的 PostScript。这样做不需要打印机驱动程序。如果使用的是非 PostScript 打印机,则过滤器系统将数据转换为打印机专用的数据。这样做需要一个适合您的打印机的 打印机驱动程序。后端从过滤器接收打印机特定的数据,然后将其传递到打印机。
18.2 连接打印机的方法和协议 #
可以通过多种方法将打印机连接到系统。CUPS 的配置不能区分本地打印机和通过网络连接到系统的打印机。有关打印机连接的更多信息,请阅读 http://en.opensuse.org/SDB:CUPS_in_a_Nutshell 上的文章 CUPS in a Nutshell(CUPS 概述)。
当将打印机连接到计算机时,一定不要忘记操作期间只能插入或拔下 USB 设备。为防止损坏系统或打印机,请在更改任何非 USB 连接前先关闭系统。
18.3 安装软件 #
PPD(PostScript 打印机描述)是描述属性(例如,分辨率)和选项(例如,双面打印单位的可用性)的计算机语言。这些描述对于使用 CUPS 中的各个打印机选项是必需的。如果没有 PPD 文件,打印数据将被以“原始”状态转发到打印机,通常这不是希望出现的情况。
要配置 PostScript 打印机,最佳的方法是获得一个合适的 PPD 文件。manufacturer-PPDs
和 OpenPrintingPPDs-postscript
包中提供了许多 PPD 文件。请参见第 18.7.3 节 “多种包中的 PPD 文件”和第 18.8.2 节 “没有合适的 PPD 文件可用于 PostScript 打印机”。
新的 PPD 文件可以储存在目录 /usr/share/cups/model/
中,或如Book “Deployment Guide”, Chapter 15 “Setting Up Hardware Components with YaST”, Section 15.3.1.1 “Adding Drivers with YaST”中所述使用 YaST 添加到打印系统中。随后,可以在打印机设置过程中选择 PPD 文件。
如果打印机制造商希望您安装整个软件包,请务必小心。这种安装类型可能导致 SUSE Linux Enterprise Desktop 提供的支持失效。另外,打印命令可能会以不同的方式工作,并且系统可能不再能够对其他制造商的设备寻址。出于此原因,不建议安装制造商软件。
18.4 网络打印机 #
网络打印机可以支持多种协议,有些甚至支持并发打印不同协议。尽管大部分支持的协议都已标准化,但某些制造商可能修改了标准。他们仅提供适用于少数操作系统的驱动程序。不过很少提供 Linux 驱动程序。当前的情况是您在执行操作时不能假定每个协议都可以在 Linux 中正常工作。因此,您可能需要试验不同的选项以找出起作用的配置。
CUPS 支持 socket
、LPD
、IPP
和 smb
协议。
- 套接字
套接字是指将纯文本打印数据直接发送到 TCP 套接字的连接。一些常用的套接字端口号包括
9100
或35
。设备 URI(统一资源标识符)的语法为 socket://IP.OF.THE.PRINTER:PORT,例如socket://192.168.2.202:9100/
。- LPD(行式打印机守护程序)
LPD 协议如 RFC 1179 中所述。使用此协议,打印队列 ID 等作业相关数据将先于实际打印数据发送。因此,配置 LPD 协议时必须指定打印队列。各打印机制造商的实施非常灵活,可以接受为打印队列指定任何名称。如果需要,打印机手册应该指出要使用的名称。通常使用 LPT、LPT1、LP1 或类似的名称。LPD 服务的端口号是
515
。设备 URI 示例:lpd://192.168.2.202/LPT1
。- IPP(因特网打印协议)
IPP 是一个基于 HTTP 协议的相对较新的协议 (1999)。使用 IPP,所传送的与任务有关的数据比其他协议要多一些。CUPS 使用 IPP 进行内部数据传送。要正确配置 IPP,必须提供打印队列的名称。IPP 的端口号是
631
。设备 URI 示例:ipp://192.168.2.202/ps
和ipp://192.168.2.202/printers/ps
。- SMB(Windows 共享)
CUPS 还支持在连接到 Windows 共享的打印机上进行打印。用于此目的的协议是 SMB。SMB 使用端口号
137
、138
和139
。设备 URI 示例:smb://user:password@workgroup/smb.example.com/printer
、smb://user:password@smb.example.com/printer
和smb://smb.example.com/printer
。
必须在配置之前确定打印机支持的协议。如果制造商未提供所需的信息,则可以使用命令 nmap
(随 nmap
包提供)来确定协议。nmap
检查主机端口是否打开。例如:
tux >
nmap -p 35,137-139,515,631,9100-10000 IP.OF.THE.PRINTER
18.5 使用命令行工具配置 CUPS #
CUPS 可使用 lpinfo
、lpadmin
和 lpoptions
之类的命令行工具配置。您需要一个包含一个后端(例如 USB)和多个参数的设备 URI。要确定系统上的有效设备 URI,请使用命令 lpinfo -v | grep ":/"
:
tux >
sudo
lpinfo -v | grep ":/" direct usb://ACME/FunPrinter%20XL network socket://192.168.2.253
使用 lpadmin
,CUPS 服务器管理员可以添加、删除或管理打印队列。要添加打印队列,请使用以下语法:
tux >
sudo
lpadmin -p QUEUE -v DEVICE-URI -P PPD-FILE -E
设备 (-v
) 便会用作 QUEUE (-p
),并使用指定的 PPD 文件 (-P
)。这意味着如果要手动配置打印机,则必须了解 PPD 文件和设备 URI。
不要使用 -E
作为第一个选项。对于所有 CUPS 命令,将 -E
用作第一个参数设置使用加密连接。要启用打印机,必须使用 -E
,如下面的示例所示:
tux >
sudo
lpadmin -p ps -v usb://ACME/FunPrinter%20XL -P \ /usr/share/cups/model/Postscript.ppd.gz -E
以下示例配置了网络打印机:
tux >
sudo
lpadmin -p ps -v socket://192.168.2.202:9100/ -P \ /usr/share/cups/model/Postscript-level1.ppd.gz -E
有关 lpadmin
的更多选项,请参考 lpadmin(8)
的手册页。
在系统安装期间,某些选项被设置为默认值。可以为每个打印任务修改这些选项(根据所使用的打印工具)。也可以使用 YaST 来更改这些默认选项。使用命令行工具设置默认选项,如下所示:
首先,列出所有选项:
tux >
sudo
lpoptions -p QUEUE -l示例:
Resolution/Output Resolution: 150dpi *300dpi 600dpi
激活的默认选项通过加星号前缀 (
*
) 进行标识。使用
lpadmin
更改选项:tux >
sudo
lpadmin -p QUEUE -o Resolution=600dpi检查新设置:
tux >
sudo
lpoptions -p QUEUE -l Resolution/Output Resolution: 150dpi 300dpi *600dpi
普通用户运行 lpoptions
时,设置将写到 ~/.cups/lpoptions
。但是,根
设置将写到 /etc/cups/lpoptions
。
18.6 从命令行打印 #
要从命令行打印,请输入 lp -d
QUEUENAME FILENAME,并用相应的名称替换 QUEUENAME 和 FILENAME。
有些应用程序依赖于 lp
命令来进行打印。在这种情况下,请在应用程序的打印对话框中输入正确的命令(通常无需指定 FILENAME),例如 lp -d
QUEUENAME。
18.7 SUSE Linux Enterprise Desktop 中的特殊功能 #
某些 CUPS 功能已针对 SUSE Linux Enterprise Desktop 进行调整。这里将介绍一些最重要的更改。
18.7.1 CUPS 和防火墙 #
执行默认的 SUSE Linux Enterprise Desktop 安装后,firewalld
将处于活动状态,并且网络接口配置为位于 public
区域中,这会阻止传入通讯。Book “Security and Hardening Guide”, Chapter 22 “Masquerading and Firewalls”, Section 22.4 “firewalld
”中和 http://en.opensuse.org/SDB:CUPS_and_SANE_Firewall_settings 上提供了有关 firewalld
配置的更多信息。
18.7.1.1 CUPS 客户端 #
通常 CUPS 客户端在使用防火墙的可信网络环境中的常规工作站上运行。在这种情况下,建议将网络接口配置为在内部区域
中,这样可以从网络内部访问工作站。
18.7.1.2 CUPS 服务器 #
如果 CUPS 服务器在受防火墙保护的可信网络环境中,则应将网络接口配置为在防火墙的内部区域
中。建议不要在不可信网络环境中安装 CUPS 服务器,除非您确定该服务器受到特殊防火墙规则和 CUPS 配置中的安全设置的保护。
18.7.2 浏览网络打印机 #
CUPS 服务器会定期在网络上公告共享打印机的可用性及状态信息。客户端可以访问此信息,以便在打印对话框中显示可用打印机列表。此过程称为“浏览”。
CUPS 服务器通过传统的 CUPS 浏览协议或 Bonjour/DNS-SD 在网络上通告它们的打印队列。为了能够浏览网络打印队列,通过 CUPS 服务器打印的所有客户端上都需要运行 cups-browsed
服务。默认情况下,cups-browsed
不会启动。要为活动会话启动它,请使用 sudo systemctl start cups-browsed
。要确保它在系统引导后自动启动,请在所有客户端上使用 sudo systemctl enable cups-browsed
启用它。
如果在启动 cups-browsed
之后浏览不起作用,则表明 CUPS 服务器可能是通过 Bonjour/DNS-SD 通告网络打印队列的。在此情况下,您需要另外安装 avahi
包,并在所有客户端上使用 sudo systemctl start avahi-daemon
启动关联的服务。
18.7.3 多种包中的 PPD 文件 #
YaST 打印机配置使用 /usr/share/cups/model
中安装的 PPD 文件为 CUPS 设置队列。为查找适用于打印机型号的 PPD 文件,YaST 将对照硬件检测过程中确定的供应商和型号比较所有 PPD 文件中的供应商和型号。为此,YaST 打印机配置根据从 PPD 文件抽取的供应商和型号信息生成一个数据库。
仅使用 PPD 文件而不使用其他信息源的配置的优点在于可以随意修改 /usr/share/cups/model/
中的 PPD 文件。例如,如果您有 PostScript 打印机,可直接将 PPD 文件复制到 /usr/share/cups/model
(如果这些文件尚不存在于 manufacturer-PPDs
或 OpenPrintingPPDs-postscript
包中),以实现打印机最佳配置。
其他 PPD 文件由下列包提供:
gutenprint
:Gutenprint 驱动程序及其匹配的 PPDsplix
:SpliX 驱动程序及其匹配的 PPDOpenPrintingPPDs-ghostscript
:Ghostscript 内置驱动程序的 PPDOpenPrintingPPDs-hpijs
:适用于非 HP 打印机的 HPIJS 驱动程序的 PPD
18.8 查错 #
下面几节介绍一些最常遇到的打印机硬件和软件问题以及解决或避免这些问题的方法。讨论的主题有 GDI 打印机、PPD 文件和端口配置。另外还讨论常见网络打印机问题、打印件问题以及队列处理。
18.8.1 打印机没有标准打印机语言支持 #
这些打印机不支持任何常见的打印机语言,只能使用专门的专有控制系列来进行寻址。因此这些打印机只能用于制造商提供了驱动程序的操作系统版本。GDI 是 Microsoft* 为图形设备开发的编程接口。通常制造商只提供 Windows 的驱动程序,而因为 Windows 驱动程序使用 GDI 界面,所以这些打印机也称作 GDI 打印机。问题实际并不是出在编程接口上,而是因这些打印机只能通过相应打印机型号的专用打印机语言来寻址所造成。
某些 GDI 打印机可切换成以 GDI 方式或一种标准打印机语言进行操作。请参见打印机手册以了解这是否可行。有些型号需要有专门的 Windows 软件来进行切换(注:Windows 打印机驱动程序在通过 Windows 进行打印时可能总是将打印机切换回 GDI 模式)。对于其他 GDI 打印机,还有针对标准打印机语言的扩展模块。
某些制造商为他们的打印机提供专有驱动程序。专有打印机驱动程序的缺点在于不能保证这些驱动程序可用于已安装的打印系统,也不能保证它们适合各种硬件平台。相反,支持标准打印机语言的打印机不依赖于特殊的打印系统版本或特殊的硬件平台。
与其花时间尝试使专有 Linux 驱动程序运行,购买支持标准打印机语言(最好是 PostScript)的打印机可能更经济高效。这可以一次性彻底解决驱动程序问题,您不再需要安装并配置特殊驱动程序软件,以及获取由于打印系统中开发的新功能而必须安装的驱动程序更新。
18.8.2 没有合适的 PPD 文件可用于 PostScript 打印机 #
如果 manufacturer-PPDs
或OpenPrintingPPDs-postscript
包不包含适用于 PostScript 打印机的 PPD 文件,则可以使用打印机制造商提供的驱动程序 CD 上的 PPD 文件,或从打印机制造商网页下载合适的 PPD 文件。
如果以 zip 存档 (.zip) 或自解压缩 zip 存档 (.exe
) 的形式提供 PPD 文件,则用 unzip
命令将其解包。首先,查看 PPD 文件的许可证协议条款。然后使用 cupstestppd
实用程序来确认 PPD 文件是否与“ Adobe PostScript 打印机描述文件格式规范 V4.3” 相符合,如果实用程序返回 “FAIL,”则描述 PPD 文件中的错误很严重,可能导致重大问题。应该解决 cupstestppd
报告的问题点。如果需要,询问打印机制造商是否提供合适的 PPD 文件。
18.8.3 网络打印机连接 #
- 确定网络问题
将打印机直接连接到计算机。出于测试目的,将该打印机配置为本地打印机。如果打印机可以工作,则问题与网络有关。
- 检查 TCP/IP 网络
TCP/IP 网络和名称解析必须可以正常工作。
- 检查远程
lpd
使用以下命令测试是否可以与 Host 上的
lpd
(端口515
)建立 TCP 连接:tux >
netcat -z HOST 515 && echo ok || echo failed如果不能建立与
lpd
的连接,则lpd
可能不处于活动状态或可能存在基本网络问题。如果相应的
lpd
处于活动状态并且主机接受查询,请以root
身份运行以下命令,以查询远程 HOST 上 QUEUE 的状态报告:root #
echo -e "\004queue" \ | netcat -w 2 -p 722 HOST 515如果
lpd
不响应,则它可能不处于活动状态或可能存在基本网络问题。如果lpd
响应,响应应该描述为什么在主机
的队列
上不能进行打印。如果您接收到类似例 18.1 “来自lpd
的错误消息” 中的响应,则问题是由远程lpd
引起的。例 18.1︰ 来自lpd
的错误消息 #lpd: your host does not have line printer access lpd: queue does not exist printer: spooling disabled printer: printing disabled
- 检查远程
cupsd
CUPS 网络服务器可以在 UDP 端口
631
上广播其队列,默认每 30 秒广播一次。因此,以下命令可用于测试网络中是否存在广播 CUPS 网络服务器。执行此命令之前,务必停止本地 CUPS 守护程序。tux >
netcat -u -l -p 631 & PID=$! ; sleep 40 ; kill $PID如果广播 CUPS 网络服务器存在,则输出如例 18.2 “来自 CUPS 网络服务器的广播” 所示。
例 18.2︰ 来自 CUPS 网络服务器的广播 #ipp://192.168.2.202:631/printers/queue
以下命令可用于测试是否可以与 HOST 上的
cupsd
(端口631
)建立 TCP 连接:tux >
netcat -z HOST 631 && echo ok || echo failed如果不能与
cupsd
建立连接,则可能是cupsd
未处于活动状态,或者存在基本网络问题。如果相应的cupsd
处于活动状态并且主机接受查询,lpstat -h
HOST -l -t 会返回 HOST 上所有队列的状态报告(可能非常长)。下面的命令可用于测试 HOST 上的 QUEUE 是否接受由单个回车字符组成的打印作业。不应打印任何内容。可能会弹出一页空白纸。
tux >
echo -en "\r" \ | lp -d queue -h HOST- 对网络打印机或打印服务器计算机进行查错
有时,当在打印服务器计算机中运行的假脱机程序需要处理多个打印作业时会产生问题。这是打印服务器计算机中的假脱机程序导致的,目前尚无解决此问题的方法。变通方法是,直接通过 TCP 套接字对连接到打印服务器计算机的打印机进行寻址,来绕过打印服务器计算机中的假脱机程序。请参见 第 18.4 节 “网络打印机”。
这样,打印服务器计算机仅充当各种不同数据传送方式之间(TCP/IP 网络和本地打印机连接)的转换器。要使用此方法,您需要知道打印服务器计算机上的 TCP 端口。如果打印机连接到打印服务器计算机并且已启动,则通常可以在打开打印服务器计算机电源一段时间后使用
nmap
包中的nmap
实用程序确定此 TCP 端口。例如,nmap
IP-address 可能会返回打印服务器计算机的以下输出:Port State Service 23/tcp open telnet 80/tcp open http 515/tcp open printer 631/tcp open cups 9100/tcp open jetdirect
此输出指出可以在端口
9100
上通过 TCP 套接字对连接到打印服务器计算机的打印机寻址。默认情况下,nmap
只检查在/usr/share/nmap/nmap-services
中列出的一些常见的端口。要检查所有可能的端口,请使用命令nmap -p
FROM_PORT-TO_PORT IP_ADDRESS。这可能要花一些时间。有关详细信息,请参见nmap
的手册页。输入如下命令
tux >
echo -en "\rHello\r\f" | netcat -w 1 IP-address port cat file | netcat -w 1 IP-address port将字符串或文件直接发送到相应的端口以测试是否可以在该端口上对打印机进行寻址。
18.8.4 打印件有问题但没有错误消息 #
对于打印系统,打印任务完成的标志是 CUPS 后端完成到接收方(打印机)的数据传送。如果在接收方的进一步处理失败(例如,如果打印机无法打印特定于打印机的数据),则打印系统不会对此进行通知。如果打印机无法打印特定于打印机的数据,请选择一个更适合该打印机的 PPD 文件。
18.8.5 禁用的队列 #
如果向接收方传送数据在多次尝试后都失败,则 CUPS 后端(例如 USB
或 socket
)向打印系统(向 cupsd
)报告一个错误。后端用于确定在将数据传送报告为不可行前应执行的失败尝试次数。由于继续尝试可能也是徒劳,cupsd
将禁用相应队列的打印。在消除了问题的起因后,系统管理员必须使用 cupsenable
命令重新启用打印。
18.8.6 CUPS 浏览:删除打印任务 #
如果 CUPS 网络服务器通过浏览向客户端主机广播其队列并且客户端主机上合适的本地 cupsd
处于活动状态,则客户端 cupsd
接受来自应用程序的打印任务并将它们转发到服务器上的 cupsd
。当服务器上的 cupsd
接受打印任务后,会为该任务指派一个新的任务号。因此,客户端主机上的任务号与服务器上的任务号不同。因为打印作业通常都会立即转发出去,所以不能用客户端主机上的作业号将其删除,原因是当打印作业已转发到服务器 cupsd
后,客户端 cupsd
会将打印作业视为已完成。
要删除服务器上的打印作业,请使用 lpstat -h cups.example.com -o
之类的命令来确定服务器上的作业编号。此情况假设服务器尚未完成该打印作业(即尚未完全将它发送到打印机)。按如下方式使用获得的作业编号来删除服务器上的打印作业:
tux >
cancel -h cups.example.com QUEUE-JOBNUMBER
18.8.7 有问题的打印任务和数据传送错误 #
如果在打印过程中关闭打印机或计算机,则打印任务将保留在队列中。再次打开计算机(或打印机)后,打印将继续。必须使用 cancel
从队列中删除有问题的打印任务。
如果打印作业损坏,或主机与打印机之间的通讯出现错误,打印机将无法正确处理数据,并会打印出很多张有乱码的纸。要修复该问题,请执行以下步骤:
要停止打印,请将所有纸张从喷墨打印机中取出或打开激光打印机的纸盒。高质量的打印机具有一个用于取消当前打印件的按钮。
打印任务可能仍在队列中,因为只有在将任务完全发送到打印机后才会将它们删除。使用
lpstat -o
或lpstat -h cups.example.com -o
检查哪个队列当前正在打印。使用cancel
QUEUE-JOBNUMBER 或cancel -h cups.example.com
QUEUE-JOBNUMBER 删除打印作业。即使已将打印任务从队列中删除,某些数据仍会被传送到打印机。检查 CUPS 后端进程是否仍在为相应的队列运行并将其终止。
通过关闭打印机一段时间完全重设置打印机。然后插入纸张并打开打印机。
18.8.8 调试 CUPS #
使用以下通用过程确定 CUPS 中的问题:
在
/etc/cups/cupsd.conf
中设置LogLevel debug
。停止
cupsd
。删除
/var/log/cups/error_log*
从而无需搜索非常长的日志文件。启动
cupsd
。重复导致问题的操作。
检查
/var/log/cups/error_log*
中的消息以确定问题的原因。
18.8.9 更多信息 #
有关在 SUSE Linux Enterprise Desktop 上执行打印操作的详细信息,请参见 openSUSE 支持数据库,网址为 http://en.opensuse.org/Portal:Printing。SUSE 知识库 (http://www.suse.com/support/) 中提供了对许多特定问题的解决方案。通过对 CUPS
的文本搜索找到相关文章。
19 图形用户界面。 #
SUSE Linux Enterprise Desktop 包含 X.org 服务器、Wayland 和 GNOME 桌面。本章介绍用于所有用户的图形用户界面配置。
19.1 X 窗口系统 #
X.org 服务器是实施 X11 协议的事实上的标准。X 是基于网络的,可以使在一个主机上启动的应用程序显示在通过任何类型的网络(LAN 或 Internet)连接的另一个主机上。
X Window 系统一般不需要进行任何配置。X 启动期间会动态检测硬件。因此,xorg.conf
已被弃用。如果您仍然需要指定自定义选项来更改 X 的行为方式,还是可以通过修改 /etc/X11/xorg.conf.d/
下的配置文件来实现。
SUSE Linux Enterprise Desktop 15 SP1 中包含 Wayland,作为 X.org 服务器的替代选择。安装期间可选择安装它。
您可安装 xorg-docs
包以更深入地了解 X11。man 5 xorg.conf
提供了有关手动配置(如果需要)的格式的详细信息。有关 X11 开发的更多信息,请参见该项目的主页:http://www.x.org。
驱动程序位于 xf86-video-*
包中,例如 xf86-video-ati
。相关手册页中详细说明了这些包附带的很多驱动程序。例如,如果您使用 ati
驱动程序,在 man 4 ati
中可以找到有关此驱动程序的更多信息。
有关第三方驱动程序的信息位于 /usr/share/doc/packages/<package_name>
中。例如,x11-video-nvidiaG04
的文档在安装包之后位于 /usr/share/doc/packages/x11-video-nvidiaG03
中。
19.2 安装和配置字体 #
Linux 中的字体可分为两大类:
- 轮廓或矢量字体
包含作为字形组成相关绘图指导的数学描述。因此,每个字形都可以缩放为任意大小而无损质量。在可以使用此类字体(或字形)之前,需要将数学描述转换为光栅(网格)。此过程称为字体光栅化。字体微调(嵌入在字体中)可改进和优化特定大小的渲染效果。光栅化和微调通过 FreeType 库实现。
Linux 下的常用格式为 PostScript Type 1 和 Type 2、TrueType 及 OpenType。
- 位图或光栅字体
包含一个为特定字号设计的像素阵列。位图字体渲染速度极快,而且非常简单。然而,与矢量字体相比,位图字体无法在不损质量的情况下进行缩放。因此,这些字体通常以不同的大小发布。现在,Linux 控制台中仍然使用位图字体,有时终端中也会使用这些字体。
在 Linux 下,便携式编译格式 (PCF) 或字形位图分布格式 (BDF) 是最常用的格式。
这些字体的外观主要会受两个方面的影响:
选择合适的字体系列,
采用某种算法渲染字体,达到接收者眼睛最舒服的效果。
最后一点只与矢量字体相关。虽然上面两点都需要根据个人情况而定,但仍有一些默认值需要创建。
Linux 字体渲染系统由具有不同关系的几个库组成。基本字体渲染库是 FreeType,它会将支持的格式的字体字形转换为优化的位图字形。渲染过程由算法及其参数(可能受专利问题影响)控制。
使用 FreeType 的每个程序或库都应该参考 Fontconfig 库。此库会从用户及系统那里收集字体配置。用户修改其 Fontconfig 设置后,此更改将导致发生 Fontconfig 感知的应用。
Arabic、Han 或 Phags-Pa 等脚本所需的更复杂的 OpenType 成型以及其他更高级别的文本处理使用 Harfbuzz 或 Pango 进行。
19.2.1 显示安装的字体 #
要获得系统上安装了哪些字体的概观,请运行 rpm
或 fc-list
命令。这两个命令都可为您提供不错的答案,但有可能会因系统和用户配置不同而返回不同的列表。
rpm
调用
rpm
可查看系统上安装了哪些包含字体的软件包:tux >
rpm -qa '*fonts*'每个字体包都应该满足此表达式。不过,命令可能会返回误报,例如
fonts-config
(它即不是字体,也不包含字体)。fc-list
调用
fc-list
可获得哪些字体系列可以访问、系统上或主目录中是否已安装这些字体的概观:tux >
fc-list ':' family注意:命令fc-list
命令
fc-list
是 Fontconfig 库的封装程序。从 Fontconfig(更确切地说,从它的超速缓存)可以查询许多有趣的信息。有关更多细节,请参见man 1 fc-list
。
19.2.2 查看字体 #
如果想了解已安装字体系列的外观,请使用命令 ftview
(ft2demos
包)或访问 http://fontinfo.opensuse.org/。例如,要以 14 号字显示 FreeMono 字体,请按如下所示使用 ftview
:
tux >
ftview 14 /usr/share/fonts/truetype/FreeMono.ttf
如果需要更多信息,请访问 http://fontinfo.opensuse.org/ 了解支持哪些样式(标准、粗体、斜体等)和语言。
19.2.3 查询字体 #
要查询指定了某种模式时使用哪种字体,请使用 fc-match
命令。
例如,如果您的模式包含已安装字体,fc-match
会返回文件名、字体系列和样式:
tux >
fc-match 'Liberation Serif'
LiberationSerif-Regular.ttf: "Liberation Serif" "Regular"
如果所需字体在您的系统上不存在,Fontconfig 的匹配规则将会生效,并尝试找到最接近的可用字体。这意味着用另一种字体来替代了您要求的字体。
tux >
fc-match 'Foo Family'
DejaVuSans.ttf: "DejaVu Sans" "Book"
Fontconfig 支持别名:用另一个系列名称替代某个名称。通用名称就是一个典型的例子,例如 “sans-serif”、“serif” 和 “monospace”。这些别名可由实际的系列名称,甚至是系列名称的首选设置列表替代:
tux >
for font in serif sans mono; do fc-match "$font" ; done
DejaVuSerif.ttf: "DejaVu Serif" "Book"
DejaVuSans.ttf: "DejaVu Sans" "Book"
DejaVuSansMono.ttf: "DejaVu Sans Mono" "Book"
结果可能因系统而异,具体视当前安装的字体而定。
Fontconfig 总是根据具体请求返回最相似的实际系列(如果至少安装了一个系列)。“相似度”根据 Fontconfig 的内部度量以及用户或管理员的 Fontconfig 设置而定。
19.2.4 安装字体 #
安装新字体的方法主要有以下几种:
将
*.ttf
或*.otf
等字体文件手动安装到知道的一个字体目录。如果字体要用于整个系统,请使用标准目录/usr/share/fonts
。如果要安装在主目录中,请使用~/.config/fonts
。如果不想使用标准目录,Fontconfig 允许您选择其他目录。使用
<dir>
元素告知 Fontconfig 所用目录,有关细节,请参见第 19.2.5.2 节 “深入了解 Fontconfig XML”。使用
zypper
安装字体。大量字体已通过包提供,随附在 SUSE 分发包中或包含在 M17N:fonts 储存库中。请使用以下命令将储存库添加到您的列表中。例如,要为 SLE 15 添加储存库:tux >
sudo
zypper ar http://download.opensuse.org/repositories/M17N:/fonts/SLE_15/要搜索您的 FONT_FAMILY_NAME,请使用以下命令:
tux >
zypper se 'FONT_FAMILY_NAME*fonts'
19.2.5 配置字体的外观 #
根据渲染媒体和字号的不同,结果可能并不令人满意。例如,现在的显示器分辨率一般为 100dpi,这导致像素太大,字形显得粗陋难看。
有几种算法可用来处理低分辨率,例如消除锯齿(灰度平滑)、微调(适合网格)或子像素渲染(在一个方向将分辨率增至三倍)。这些算法还可能因字体格式而异。
SUSE 发行套件中不使用子像素渲染。虽然 FreeType2 支持此算法,但有几项将于 2019 年底到期的专利涉及到了此算法。因此,除非系统中有 FreeType2 库并且该库中已编译子像素渲染,否则在 Fontconfig 中设置子像素渲染选项没有任何效果。
通过 Fontconfig,可单独为每种字体选择渲染算法,也可为一组字体选择渲染算法。
19.2.5.1 通过 sysconfig
配置字体 #
SUSE Linux Enterprise Desktop 在 Fontconfig 上提供了一个 sysconfig
层。要尝试进行字体配置,这是一个不错的着手点。要更改默认设置,请编辑配置文件 /etc/sysconfig/fonts-config
。(或使用 YaST sysconfig 模块)。编辑该文件之后,请运行 fonts-config
。
tux >
sudo
/usr/sbin/fonts-config
重启动该应用程序以显示成效。请牢记以下要点:
一些应用程序不需要重启动。例如,Firefox 会不时重新读取 Fontconfig 配置。新创建或重新装载的标签可在稍后获得新的字体配置。
每次发生包安装或去除操作之后,系统会自动调用
fonts-config
脚本(如未调用,则表示字体软件包有错误)。使用
fonts-config
命令行选项可以暂时覆盖每个 sysconfig 变量。有关细节,请参见fonts-config --help
。
有几个 sysconfig 变量可以更改。请参见 man 1 fonts-config
或 YaST sysconfig 模块的帮助页。以下是一些变量示例:
- 渲染算法的使用
考虑使用
FORCE_HINTSTYLE
、FORCE_AUTOHINT
、FORCE_BW
、FORCE_BW_MONOSPACE
、USE_EMBEDDED_BITMAPS
和EMBEDDED_BITMAP_LANGAGES
- 通用别名的首选项列表
使用
PREFER_SANS_FAMILIES
、PREFER_SERIF_FAMILIES
、PREFER_MONO_FAMILIES
和SEARCH_METRIC_COMPATIBLE
下面的列表提供了一些配置示例,按从“最清晰”字体(对比度较高)到“最漂亮”(较平滑)的顺序显示。
- 位图字体
通过
PREFER_*_FAMILIES
变量可指定首选位图字体。请按照帮助部分的示例使用这些变量。请注意,这些字体渲染为黑白色,不进行平滑处理,并且位图字体只有几种字号。考虑使用SEARCH_METRIC_COMPATIBLE="no"
来禁用基于度量兼容性的系列名称替代。
- 渲染为黑白色的可缩放字体
渲染时未消除锯齿的可缩放字体与位图字体的显示效果相似,同时又可保持字体可缩放性。请使用经过精细微调的字体,如 Liberation 系列。遗憾的是,系统中经过精细微调的字体并不充足。设置下面的变量可强制采用此方法:
FORCE_BW="yes"
- 渲染为黑白色的等宽字体
仅采用不消除锯齿的方式渲染等宽字体,否则,请使用默认设置:
FORCE_BW_MONOSPACE="yes"
- 默认设置
渲染所有字体时都消除锯齿。经过精细微调的字体将通过字节码解释器 (BCI) 渲染,其余字体将使用自动微调器 (
hintstyle=hintslight
) 渲染。让所有相关的 sysconfig 变量保持默认设置。- CFF 字体
以 CFF 格式使用字体。FreeType2 中有了当前的改进后,该字体应该也会比默认的 TrueType 字体更清晰。请按照
PREFER_*_FAMILIES
的示例尝试一下。可以使用以下选项将字体调得更黑更粗:SEARCH_METRIC_COMPATIBLE="no"
因为它们默认是通过
hintstyle=hintslight
来渲染的。还可以考虑使用:SEARCH_METRIC_COMPATIBLE="no"
- 专用自动微调器
即使对于精细微调的字体,也可以使用 FreeType2 的自动微调器。这可能会导致字形变得更粗,有时还会变得更模糊、对比度更低。设置下面的变量可激活此功能:
FORCE_AUTOHINTER="yes"
使用
FORCE_HINTSTYLE
可控制微调级别。
19.2.5.2 深入了解 Fontconfig XML #
Fontconfig 的配置格式是可扩展标记语言 (XML)。下面的几个示例不是完整参考,只是简要概述。细节及其他启示可在 man 5 fonts-conf
或 /etc/fonts/conf.d/
中找到。
中心 Fontconfig 配置文件是 /etc/fonts/fonts.conf
,它及其他作品包括整个 /etc/fonts/conf.d/
目录。要自定义 Fontconfig,可在两个位置插入您的更改:
系统范围的更改: 编辑文件
/etc/fonts/local.conf
(默认情况下,它包含空的fontconfig
元素)。用户特定的更改: 编辑文件
~/.config/fontconfig/fonts.conf
。将 Fontconfig 配置文件放在~/.config/fontconfig/conf.d/
目录中。
用户特定的更改会覆盖任何系统范围的设置。
文件 ~/.fonts.conf
标记为已弃用,不应该再使用。请改为使用 ~/.config/fontconfig/fonts.conf
。
每个配置文件都需要有一个 fontconfig
元素。因此,最精简的文件应如下所示:
<?xml version="1.0"?> <!DOCTYPE fontconfig SYSTEM "fonts.dtd"> <fontconfig> <!-- Insert your changes here --> </fontconfig>
如果默认目录不够用,请插入 dir
元素及相应的目录:
<dir>/usr/share/fonts2</dir>
Fontconfig 会以递归方式搜索字体。
使用下面的 Fontconfig 片段可以选择字体渲染算法(请参见例 19.1 “指定渲染算法”):
<match target="font"> <test name="family"> <string>FAMILY_NAME</string> </test> <edit name="antialias" mode="assign"> <bool>true</bool> </edit> <edit name="hinting" mode="assign"> <bool>true</bool> </edit> <edit name="autohint" mode="assign"> <bool>false</bool> </edit> <edit name="hintstyle" mode="assign"> <const>hintfull</const> </edit> </match>
字体的各种属性都可以测试。例如,<test>
元素可测试字体系列(如该例中所示)、字体间隔、间距、字体格式以及其他。如果完全不使用 <test>
,所有 <edit>
元素都会应用于每个字体(全局更改)。
- 规则 1
<alias> <family>Alegreya SC</family> <default> <family>serif</family> </default> </alias>
- 规则 2
<alias> <family>serif</family> <prefer> <family>Droid Serif</family> </prefer> </alias>
- 规则 3
<alias> <family>serif</family> <accept> <family>STIXGeneral</family> </accept> </alias>
例 19.2 “别名和系列名称替代”中的规则会创建一份排定了优先级的系列列表 (PFL)。根据元素的不同,执行的操作也不同:
如果将这些片段按规则 1 - 规则 2 - 规则 3 的顺序组合起来,当用户请求 “Alegreya SC” 时,系统便会如创建如表 19.1 “基于 Fontconfig 规则生成 PFL”中所述的 PFL。
在 Fontconfig 的度量中,系列名称具有最高优先级,高于样式、大小等其他模式。Fontconfig 会检查系统上当前安装了哪个系列。如果安装了 “Alegreya SC”,Fontconfig 将会返回它。如果未安装,则会查找 “Droid Serif”,依次类推。
请小心。如果 Fontconfig 片段的顺序发生变化,Fontconfig 可能会返回不同的结果,如表 19.2 “基于更改了顺序的 Fontconfig 规则生成 PFL 的结果”中所述。
将 <default>
别名视为此组的分类或内含项(如果未安装)。如该例所示,<default>
应该一律优先于该组的 <prefer>
和 <accept>
别名。
<default>
分类不限于通用别名 serif、sans-serif 和 monospace。有关复杂示例,请参见 /usr/share/fontconfig/conf.avail/30-metric-aliases.conf
。
例 19.3 “别名和系列名称替代”中的以下 Fontconfig 片段会创建一个 serif
组。如果前一种字体未安装,此组中的每个系列可替代其他系列。
<alias> <family>Alegreya SC</family> <default> <family>serif</family> </default> </alias> <alias> <family>Droid Serif</family> <default> <family>serif</family> </default> </alias> <alias> <family>STIXGeneral</family> <default> <family>serif</family> </default> </alias> <alias> <family>serif</family> <accept> <family>Droid Serif</family> <family>STIXGeneral</family> <family>Alegreya SC</family> </accept> </alias>
优先级由 <accept>
别名中的顺序指定。类似地,可以使用更强的 <prefer>
别名。
例 19.4 “别名和系列名称替代”扩展了例 19.2 “别名和系列名称替代”。
- 规则 4
<alias> <family>serif</family> <accept> <family>Liberation Serif</family> </accept> </alias>
- 规则 5
<alias> <family>serif</family> <prefer> <family>DejaVu Serif</family> </prefer> </alias>
例 19.4 “别名和系列名称替代”中的扩展配置将导致下列 PFL 变化:
如果同一个通用名称存在多个
<accept>
声明,则最后分析的声明“胜出”。如有可能,创建系统范围的配置时,不要在用户 (/etc/fonts/conf.d/*-user.conf
) 之后使用<accept>
。如果同一个通用名称存在多个
<prefer>
声明,则最后分析的声明“胜出”。如有可能,在系统范围的配置中,不要在用户之前使用
<prefer>。同一个通用名称的每个
<prefer>
声明都会覆盖<accept>
声明。如果管理员不仅希望用户可使用<accept>
,而且还想允许其使用<prefer>
,就不应该在系统范围的配置中使用<prefer>
。另一方面,因为用户通常都是使用<prefer>
,这种做法应该不会产生任何不利影响。我们还发现存在在统范围的配置中使用<prefer>
的情况。
19.3 GNOME 配置(供管理员使用) #
19.3.1 dconf
系统 #
GNOME 桌面的配置是使用 dconf
管理的。dconf 是按层次结构化的数据库或注册表,可让用户修改其个人设置,并可让系统管理员为所有用户设置默认值或强制值。dconf
取代了 GNOME 2 的 gconf
系统。
使用 dconf-editor
可通过图形用户界面查看 dconf 选项。使用
dconf
可通过命令行访问和修改配置选项。
GNOME Tweaks
工具提供易于使用的用户界面,其中包含不属于标准 GNOME 配置的其他配置选项。从 GNOME 应用程序菜单或在命令行中使用 gnome-tweak-tool
可启动该工具。
19.3.2 系统范围的配置 #
全局 dconf
配置参数在 /etc/dconf/db/
目录中设置,其中包括 GDM 的配置或针对用户锁定特定的配置选项。
我们以下面的过程举例说明如何创建系统范围的配置:
在
/etc/dconf/db/
中创建以.d
结尾的新目录。此目录可包含任意数量的配置选项文本文件。在此例中,创建含有以下内容的文件/etc/dconf/db/network/00-proxy
:# This is a comment [system/proxy/http] host='10.0.0.1' enabled=true
将新的配置指令分析为 dconf 数据库格式:
tux >
sudo
dconf update
创建
/etc/dconf/profiles/user
文件,以将新network
配置数据库添加至默认用户配置文件。然后添加以下内容:system-db:network
/etc/dconf/profiles/user
文件是将要使用的 GNOME 默认设置。其他配置文件可在环境变量DCONF_PROFILE
中定义。可选:要锁定用户的代理配置,请创建文件
/etc/dconf/db/network/locks/proxy
。然后将含有不能更改的关键字的一行添加至此文件:/system/proxy/http/host /system/proxy/http/enabled
您可以使用图形 dconf-editor
创建包含一个用户的配置文件,然后使用 dconf dump /
列出所有配置选项。之后便可将配置选项储存在全局配置文件中。
https://wiki.gnome.org/Projects/dconf/SystemAdministrators 中提供了全局配置的详细说明。
19.3.3 更多信息 #
更多信息请参见http://help.gnome.org/admin/。
20 使用 FUSE 访问文件系统 #
FUSE 是用户空间中的文件系统 (file system in user space) 的缩写。这表示您可以将文件系统作为非特权用户配置和装入。通常,只有 root
用户才能执行此任务。FUSE 自身是一个内核模块。它与插件组合,允许您扩展 FUSE 以访问几乎所有文件系统,如远程 SSH 连接、ISO 映像等。
20.1 配置 FUSE #
需要安装 fuse
包才能使用 FUSE。根据要使用的文件系统,您需要作为独立包提供的附加插件。
一般而言,您无需配置 FUSE。但是建议创建一个合并所有安装点的目录。例如,可以创建目录 ~/mounts
并在该处插入不同文件系统的子目录。
20.2 装入 NTFS 分区 #
NTFS(新技术文件系统)是 Windows 的默认文件系统。在一般情况下,由于非特权用户无法使用外部 FUSE 库装入 NTFS 块设备,因此下文所述的 Windows 分区装入过程需要 root 特权。
转换为
root
用户并安装包ntfs-3g
。创建一个要充当安装点的目录,如
~/mounts/windows
。确定所需的 Windows 分区。使用 YaST 并启动分区程序模块查看哪些分区属于 Windows,但不要修改任何内容。或者转换为
root
用户并执行/sbin/fdisk
-l
。查找分区类型为HPFS/NTFS
的分区。以读写模式装入分区。使用相应的 Windows 分区替换占位符 DEVICE:
tux >
ntfs-3g /dev/DEVICE MOUNT POINT要在只读模式下使用 Windows 分区,请追加
-o ro
:tux >
ntfs-3g /dev/DEVICE MOUNT POINT -o rontfs-3g
命令使用当前用户 (UID) 和组 (GID) 装入给定设备。如果要为其他用户设置写权限,请使用命令id
USER
获取 UID 和 GID 值的输出。设置方式:root #
id tux uid=1000(tux) gid=100(users) groups=100(users),16(dialout),33(video) ntfs-3g /dev/DEVICE MOUNT POINT -o uid=1000,gid=100在手册页中查找其他选项。
要卸载资源,请运行 fusermount -u
安装点。
20.3 更多信息 #
有关更多信息,请参见 FUSE 主页 http://fuse.sourceforge.net。
21 管理内核模块 #
虽然 Linux 属于单内核,但可通过内核模块加以扩展。这些特殊对象可以插入到内核中,并可按需去除。就实际角度而言,内核模块使添加和去除内核本身未包含的驱动程序和接口成为现实。Linux 提供了若干用于管理内核模块的命令。
21.1 使用 lsmod 和 modinfo 列出装载的模块 #
使用 lsmod
命令可查看目前装载了哪些内核模块。该命令的输出可能如下所示:
tux >
lsmod
Module Size Used by
snd_usb_audio 188416 2
snd_usbmidi_lib 36864 1 snd_usb_audio
hid_plantronics 16384 0
snd_rawmidi 36864 1 snd_usbmidi_lib
snd_seq_device 16384 1 snd_rawmidi
fuse 106496 3
nfsv3 45056 1
nfs_acl 16384 1 nfsv3
输出内容分为三列:Module
列列出所装载模块的名称,Size
列显示各模块的大小。Used by
列显示引用模块的进程数及其名称。请注意,此列表可能不完整。
要查看有关特定内核模块的详细信息,请使用 modinfo MODULE_NAME
命令。其中 MODULE_NAME 为所需内核模块的名称。请注意,modinfo
二进制文件位于用户的 PATH 环境变量中未包含的 /sbin
目录下。这意味着,当您以普通用户身份运行 modinfo
命令时,必须指定该二进制文件的完整路径:
tux >
/sbin/modinfo kvm
filename: /lib/modules/4.4.57-18.3-default/kernel/arch/x86/kvm/kvm.ko
license: GPL
author: Qumranet
srcversion: BDFD8098BEEA517CB75959B
depends: irqbypass
intree: Y
vermagic: 4.4.57-18.3-default SMP mod_unload modversions
signer: openSUSE Secure Boot Signkey
sig_key: 03:32:FA:9C:BF:0D:88:BF:21:92:4B:0D:E8:2A:09:A5:4D:5D:EF:C8
sig_hashalgo: sha256
parm: ignore_msrs:bool
parm: min_timer_period_us:uint
parm: kvmclock_periodic_sync:bool
parm: tsc_tolerance_ppm:uint
parm: lapic_timer_advance_ns:uint
parm: halt_poll_ns:uint
parm: halt_poll_ns_grow:int
parm: halt_poll_ns_shrink:int
21.2 添加和去除内核模块 #
虽然可以使用 insmod
和 rmmod
分别添加和去除内核模块,但建议使用 modprobe
工具来执行这些操作。modprobe
具有多项重要优势,包括自动解析依赖项和将内核模块列入黑名单。
如果不指定任何参数,使用 modprobe
命令会安装指定的内核模块。必须使用 root 特权来运行 modprobe
:
tux >
sudo
modprobe acpi
要去除内核模块,请使用 -r
参数:
tux >
sudo
modprobe -r acpi
21.2.1 引导时自动装载内核模块 #
您可以选择不手动装载内核模块,而是使用 system-modules-load.service
服务在引导过程中自动装载这些模块。要启用内核模块,请将 .conf
文件添加到 /etc/modules-load.d/
目录下。建议为配置文件指定与模块相同的名称,例如:
/etc/modules-load.d/rt2800usb.conf
配置文件中必须包含所需内核模块的名称(例如 rt2800usb
)。
通过上述的这个技巧,无需指定任何参数即可装载内核模块。如果您需要使用特定选项装载内核模块,请将配置文件添加到 /etc/modprobe.d/
目录下。该文件的扩展名必须为 .conf
。文件名必须符合以下命名约定:priority-modulename.conf
,例如:50-thinkfan.conf
。配置文件中必须包含内核模块名称及所需参数。您可以使用以下示例命令来创建包含内核模块名称及其参数的配置文件:
tux >
echo "options thinkpad_acpi fan_control=1" | sudo tee /etc/modprobe.d/thinkfan.conf
当检测到设备或用户空间请求特定功能时,系统会自动装载大多数内核模块。因此,很少需要手动将模块添加到 /etc/modules-load.d/
。
21.2.2 使用 modprobe 将内核模块列入黑名单 #
将某个内核模块列入黑名单后,引导期间便不再会装载该模块。当要禁用您怀疑可能导致系统出现问题的某个模块时,此功能十分有用。请注意,您仍可通过使用 insmod
或 modprobe
工具来手动装载列入黑名单的内核模块。
要将模块列入黑名单,请在 /etc/modprobe.d/50-blacklist.conf
文件中添加 blacklist MODULE_NAME
行。例如:
blacklist nouveau
以 root 身份运行 mkinitrd
命令生成新的 initrd
映像,然后重引导计算机。可使用以下命令执行上述步骤:
tux >
su
echo "blacklist nouveau" >> /etc/modprobe.d/50-blacklist.conf && mkinitrd && reboot
如果只想临时禁用内核模块,可在引导期间即时将其列入黑名单。要实现此目的,请在引导屏幕显示时按 E 键。这样,您会进入一个可供您修改引导参数的小编辑器。找到如下所示的行:
linux /boot/vmlinuz...splash= silent quiet showopts
在该行末尾添加 modprobe.blacklist=MODULE_NAME
命令。例如:
linux /boot/vmlinuz...splash= silent quiet showopts modprobe.blacklist=nouveau
按 F10 或 Ctrl–X 以按照指定配置引导。
要通过 GRUB 将某个内核模块永久列入黑名单,请打开要编辑的 /etc/default/grub
文件,在 GRUB_CMD_LINUX
命令中添加 modprobe.blacklist=MODULE_NAME
选项。然后运行 sudo grub2-mkconfig -o /boot/grub2/grub.cfg
命令使更改生效。
22 使用 udev
进行动态内核设备管理 #
内核几乎可以添加或删除运行系统中的任何设备。设备状态的更改(无论插入还是移除设备)需要传播给用户空间。插入及识别设备后需要对其进行配置。某个设备已识别状态的任何更改都需要通知给此设备的用户。udev
可提供所需的基础结构来动态维护 /dev
目录中的设备节点文件和符号链接。udev
规则提供了将外部工具插入内核设备事件处理的方式。因而,您可以通过添加在内核设备处理过程中执行的特定脚本,来自定义 udev
设备处理方式,或者可以在设备处理期间请求并导入其他数据进行评估。
22.1 /dev
目录 #
/dev
目录中的设备节点提供对相应的内核设备的访问。使用 udev
时,/dev
目录反映内核的当前状态。每个内核设备都有相应的设备文件。如果设备从系统断开,则删除此设备节点。
/dev
目录的内容保存在临时文件系统中,所有文件都是在每个系统启动时提供的。手动创建或修改的文件在重引导时是有意不保存的。无论可使用 systemd-tmpfiles 创建的相应内核设备状态如何,静态文件和目录都始终应位于 /dev
目录中。配置文件位于 /usr/lib/tmpfiles.d/
和 /etc/tmpfiles.d/
中。有关详细信息,请参见 systemd-tmpfiles(8)
手册页。
22.2 内核 uevents
和 udev
#
必需的设备信息由 sysfs
文件系统导出。对于内核检测到并已初始化的设备,将创建一个带有该设备名称的目录。它包含带有特定于设备属性的属性文件。
每次添加或删除设备时,内核都会发送 uevent 来向 udev
通知更改。一旦启动,udev
守护程序便会读取并分析 /usr/lib/udev/rules.d/*.rules
和 /etc/udev/rules.d/*.rules
文件中的所有规则,并将它们保留在内存中。如果更改、添加或去除了规则文件,守护程序可以使用 udevadm control --reload
命令重新装载这些规则在内存中的表示。有关 udev
规则及其语法的更多细节,请参见第 22.6 节 “使用 udev
规则影响内核设备事件处理”。
每个接收到的事件都根据所提供的规则集进行匹配。这些规则可以增加或更改事件环境键、为要创建的设备节点请求特定名称、添加指向该节点的符号链接或者添加设备节点创建后运行的程序。从内核 netlink 套接字接收驱动程序核心 uevent
。
22.3 驱动程序、内核模块和设备 #
设备的内核总线驱动程序探测。对于每个检测到的设备,内核都会在驱动程序核心将 uevent 发送到 udev
守护程序时创建内部设备结构。总线设备通过特殊格式的 ID 来标识自己,这可以识别设备的类型。通常,这些 ID 由供应商和产品 ID 以及其他特定于子系统的值组成。每个总线都有自己对于这些 ID 的方案,称为 MODALIAS
。内核获取设备信息,由此组成一个 MODALIAS
ID 字符串,并将该字符串与事件一起发送。对于 USB 鼠标,如下所示:
MODALIAS=usb:v046DpC03Ed2000dc00dsc00dp00ic03isc01ip02
每个设备驱动程序都带有它可以处理的设备的已知别名列表。这个列表包含在内核模块文件中。程序 depmod 读取 ID 列表并在内核的 /lib/modules
目录中为所有当前可用的模块创建文件 modules.alias
。使用这种基础结构,模块的装载就如为每个带有 MODALIAS
键的事件调用 modprobe
一样简单。如果调用 modprobe $MODALIAS
,它将组成该设备的设备别名与模块提供的别名相匹配。如果找到匹配的项,则装载该模块。所有这些操作均由 udev
自动触发。
22.4 引导和启动设备设置 #
在 udev
守护程序运行之前的引导进程中发生的所有设备事件都会丢失,因为处理这些事件的基础结构保存在 root 文件系统中,并且此时不可用。为了弥补此损失,内核提供了一个 uevent
文件,该文件位于 sysfs 文件系统每个设备的设备目录中。通过将
add
写入到该文件,内核将再次发送引导时丢失的相同事件。/sys
触发器中所有 uevent
文件的简单循环将再次触发所有事件来创建设备节点并执行设备设置。
例如,在引导期间出现的 USB 鼠标可能不会由早期引导逻辑初始化,因为驱动程序在那时不可用。此设备发现的事件丢失并且不能为该设备查找内核模块。您无需手动搜索连接的设备,udev
会在根文件系统可用后向内核请求所有设备事件,这样 USB 鼠标设备的事件就会再次运行。现在它在装入的 root 文件系统上找到内核模块,因此可以初始化 USB 鼠标。
在用户空间中,设备冷插入序列和运行时期间发现的设备之间没有明显的区别。在这两种情况下,使用相同的规则来匹配并且运行相同的配置程序。
22.5 监视正在运行的 udev
守护程序 #
程序 udevadm monitor
可以用于将驱动程序核心事件和 udev
事件处理的计时可视化。
UEVENT[1185238505.276660] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1 (usb) UDEV [1185238505.279198] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1 (usb) UEVENT[1185238505.279527] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0 (usb) UDEV [1185238505.285573] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0 (usb) UEVENT[1185238505.298878] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0/input/input10 (input) UDEV [1185238505.305026] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0/input/input10 (input) UEVENT[1185238505.305442] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0/input/input10/mouse2 (input) UEVENT[1185238505.306440] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0/input/input10/event4 (input) UDEV [1185238505.325384] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0/input/input10/event4 (input) UDEV [1185238505.342257] add /devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0/input/input10/mouse2 (input)
UEVENT
行显示内核已经通过 netlink 发送的事件。UDEV
行显示已经完成的 udev
事件处理程序。计时以微秒为单位显示。UEVENT
和 UDEV
之间的时间是 udev
用于处理此事件或者 udev
守护程序延迟执行从而同步此事件与相关以及已运行的事件的时间。例如,硬盘分区的事件总是等待主磁盘设备事件完成,因为分区事件可能依赖于主磁盘事件从硬件查询的数据。
udevadm monitor --env
显示完整的事件环境:
ACTION=add DEVPATH=/devices/pci0000:00/0000:00:1d.2/usb3/3-1/3-1:1.0/input/input10 SUBSYSTEM=input SEQNUM=1181 NAME="Logitech USB-PS/2 Optical Mouse" PHYS="usb-0000:00:1d.2-1/input0" UNIQ="" EV=7 KEY=70000 0 0 0 0 REL=103 MODALIAS=input:b0003v046DpC03Ee0110-e0,1,2,k110,111,112,r0,1,8,amlsfw
udev 也将消息发送给 syslog。
用于控制将哪些消息发送到系统日志的默认系统日志优先级在 udev
配置文件 /etc/udev/udev.conf
中指定。可以使用 udevadm control --log_priority=
LEVEL/NUMBER 更改正在运行的守护程序的日志优先级。
22.6 使用 udev
规则影响内核设备事件处理 #
udev
规则可以与内核添加到事件本身的属性或者内核导出到 sysfs
的任何信息匹配。规则还可以从外部程序请求其他信息。系统会将事件与目录 /usr/lib/udev/rules.d/
(适用于默认规则)和 /etc/udev/rules.d
(系统特定的配置)中提供的所有规则进行匹配。
规则文件中的每一行至少包含一个键值对。有两种类型的键,匹配键和指派键。如果所有匹配键与它们的值匹配,则应用此规则并将指派键指派给特定的值。匹配规则可以指定设备节点的名称、添加指向该节点的符号链接或者运行作为事件处理一部分的特定程序。如果找不到匹配的规则,则使用默认设备节点名来创建设备节点。udev
手册页中描述了有关规则语法和提供用来与数据匹配或导入数据的键的详细信息。以下示例规则提供了 udev
规则语法的基本介绍。这些示例规则全部取自 udev
默认规则集 /usr/lib/udev/rules.d/50-udev-default.rules
。
udev
规则 ## console KERNEL=="console", MODE="0600", OPTIONS="last_rule" # serial devices KERNEL=="ttyUSB*", ATTRS{product}=="[Pp]alm*Handheld*", SYMLINK+="pilot" # printer SUBSYSTEM=="usb", KERNEL=="lp*", NAME="usb/%k", SYMLINK+="usb%k", GROUP="lp" # kernel firmware loader SUBSYSTEM=="firmware", ACTION=="add", RUN+="firmware.sh"
console
规则由三个键构成:一个匹配键 (KERNEL
) 和两个赋值键(MODE
、OPTIONS
)。KERNEL
匹配规则搜索设备列表以查找类型为 console
的所有项。只有完全匹配才有效,才能触发执行此规则。在这种情况下,MODE
键为设备节点指派特殊权限,仅为此设备的拥有者指派读写权限。OPTIONS
键将该规则标记为此类型的所有设备最后采用的规则。匹配此特殊设备类型的任何后续规则都不产生任何影响。
50-udev-default.rules
中不再提供 serial devices
规则,但该规则仍然值得考虑。该规则由两个匹配键(KERNEL
和 ATTRS
)和一个赋值键 (SYMLINK
) 构成。KERNEL
键搜索类型为 ttyUSB
的所有设备。该键使用 *
通配符匹配这些设备中的几个。第二个匹配键 ATTRS
检查任何 ttyUSB
设备的 sysfs
中的 product
属性文件是否包含特定字符串。赋值键 (SYMLINK
) 将符号链接添加至该设备的 /dev/pilot
下。此键中使用的运算符 (+=
) 告知 udev 进一步执行此操作,即使前面或后面的规则添加其他符号链接。由于此规则包含两个匹配键,因此仅当两个条件都满足时,才应用。
printer
规则处理 USB 打印机,其中包含两个匹配键(SUBSYSTEM
和 KERNEL
),并且必须同时应用这两个键,才能应用整个规则。三个赋值键处理该设备类型的命名 (NAME
)、符号设备链接 (SYMLINK
) 的创建,以及此设备类型的组成员资格 (GROUP
)。在 KERNEL
键中使用通配符 *
将使其匹配若干 lp
打印机设备。NAME
和 SYMLINK
键中都使用了替换项,以便按内部设备名称扩展这些字符串。例如,指向第一个 lp
USB 打印机的符号链接为 /dev/usblp0
。
kernel firmware loader
规则用于使 udev 在运行时期间通过外部助手脚本装载其他固件。SUBSYSTEM
匹配键搜索 firmware
子系统。ACTION
键检查是否添加了属于 firmware
子系统的任何设备。RUN+=
键触发执行 firmware.sh
脚本,以便找到应装载的固件。
所有规则具有一些共同的特征:
每个规则由一个或多个以逗号分隔的键值对构成。
键的运算由运算符确定。
udev
规则支持多个运算符。每个给定值必须用引号引起来。
规则文件的每一行代表一个规则。如果某个规则超过一行,请使用
\
合并不同行,就像在外壳语法中一样。udev
规则支持与*
、?
和[]
模式匹配的外壳式模式。udev
规则支持替换。
22.6.1 在 udev
规则中使用运算符 #
创建可以从多个运算符选择的键,具体取决于要创建的键的类型。匹配键通常用于查找匹配或明显不匹配搜索值的值。匹配键包含以下运算符之一:
==
比较等于性。如果键包含搜索模式,则匹配该模式的所有结果均有效。
!=
比较不等于性。如果键包含搜索模式,则匹配该模式的所有结果均有效。
赋值键可以使用下面的任何运算符:
=
为键指派值。如果键以前由一列值构成,键将重置,并且仅指派一个值。
+=
为包含一列项的键添加一个值。
:=
指派最终值。不允许后面的规则进行任何后续更改。
22.6.2 在 udev
规则中使用替换项 #
udev
规则支持使用占位符和替换项。请按照在其他任何脚本中的相同方式使用。在 udev
规则中可使用以下替换项:
%r
、$root
设备目录
/dev
(默认)。%p
、$devpath
DEVPATH
的值。%k
、$kernel
KERNEL
的值或内部设备名称。%n
、$number
设备号。
%N
、$tempnode
设备文件的临时名称。
%M
、$major
设备的主编号。
%m
、$minor
设备的次编号。
%s{ATTRIBUTE}
,$attr{ATTRIBUTE}
sysfs
属性的值(通过 ATTRIBUTE 指定)。%E{VARIABLE}
,$env{VARIABLE}
环境变量的值(通过 VARIABLE 指定)。
%c
、$result
PROGRAM
的输出。%%
%
字符。$$
$
字符。
22.6.3 使用 udev
匹配键 #
匹配键描述应用 udev
规则之前必须满足的条件。以下匹配键可用:
ACTION
事件操作的名称,如
add
或remove
(添加或删除设备时)。DEVPATH
事件设备的设备路径,如
DEVPATH=/bus/pci/drivers/ipw3945
,用于搜索与 ipw3945 驱动程序有关的所有事件。KERNEL
事件设备的内部(内核)名称。
SUBSYSTEM
事件设备的子系统,如
SUBSYSTEM=usb
(用于与 USB 设备有关的所有事件)。ATTR{FILENAME}
事件设备的 sysfs 属性。
例如,要匹配vendor
属性文件名中包含的字符串,可以使用ATTR{vendor}=="On[sS]tream"
。KERNELS
让
udev
向上搜索设备路径,以查找匹配的设备名称。SUBSYSTEMS
让
udev
向上搜索设备路径,以查找匹配的设备子系统名称。DRIVERS
让
udev
向上搜索设备路径,以查找匹配的设备驱动程序名称。ATTRS{FILENAME}
让
udev
向上搜索设备路径,以查找与sysfs
属性值匹配的设备。ENV{KEY}
环境变量的值,如
ENV{ID_BUS}="ieee1394
,用于搜索与该 FireWire 总线 ID 有关的所有事件。PROGRAM
让
udev
执行外部程序。程序必须返回退出码零,才能成功。RESULT
键可使用程序的输出(打印到 stdout)。RESULT
匹配上次
PROGRAM
调用的输出字符串。在与PROGRAM
键相同的规则中包含该键,或在后面的一个中。
22.6.4 使用 udev
指派键 #
与上述匹配键相比,赋值键未描述必须满足的条件。它们将值、名称和操作指派给由 udev
维护的设备节点。
NAME
将创建的设备节点的名称。在一个规则设置节点名称之后,将对该节点忽略带有
NAME
键的其他所有规则。SYMLINK
与要创建的节点有关的符号链接名称。多个匹配的规则可添加要使用设备节点创建的符号链接。也可以通过使用空格字符分隔符号链接名称,在一个规则中为一个节点指定多个符号链接。
OWNER, GROUP, MODE
新设备节点的权限。此处指定的值重写已编译的任何值。
ATTR{KEY}
指定要写入事件设备的
sysfs
属性的值。如果使用==
运算符,也将使用该键匹配sysfs
属性的值。ENV{KEY}
告知
udev
将变量导出到环境。如果使用==
运算符,也将使用该键匹配环境变量。RUN
告知
udev
向程序列表添加要为该设备执行的程序。请记住,将此程序限制于很短的任务,以免妨碍此设备的后续事件。LABEL
添加
GOTO
可跳至的标签。GOTO
告知
udev
跳过若干规则,继续执行GOTO
键所引用标签对应的规则。IMPORT{TYPE}
将变量装载入外部程序输出之类的事件环境中。
udev
可导入多种类型的变量。如果未指定任何类型,udev
将尝试根据文件许可权限的可执行位来自行确定类型。program
告知udev
执行外部程序并导入其输出。file
告知udev
导入文本文件。parent
告知udev
从父设备导入储存的键。
WAIT_FOR_SYSFS
告知
udev
等待要为某个设备创建的指定sysfs
文件。例如,WAIT_FOR_SYSFS="ioerr_cnt"
通知udev
等待ioerr_cnt
文件创建完成。OPTIONS
OPTION
键可以有多个值:last_rule
告知udev
忽略后面的所有规则。ignore_device
告知udev
完全忽略此事件。ignore_remove
告知udev
忽略后面针对设备的所有删除事件。all_partitions
告知udev
为块设备上的所有可用分区创建设备节点。
22.7 永久设备命名 #
动态设备目录和 udev
规则基础架构可以为所有磁盘设备提供固定名称,而不考虑它们的识别顺序或设备使用的连接。内核创建的每个相应的块设备由工具根据有关特定总线、驱动器类型或者文件系统的特殊知识进行检查。除了动态内核提供的设备节点名,udev
还维护各种指向该设备的永久符号链接:
/dev/disk |-- by-id | |-- scsi-SATA_HTS726060M9AT00_MRH453M4HWHG7B -> ../../sda | |-- scsi-SATA_HTS726060M9AT00_MRH453M4HWHG7B-part1 -> ../../sda1 | |-- scsi-SATA_HTS726060M9AT00_MRH453M4HWHG7B-part6 -> ../../sda6 | |-- scsi-SATA_HTS726060M9AT00_MRH453M4HWHG7B-part7 -> ../../sda7 | |-- usb-Generic_STORAGE_DEVICE_02773 -> ../../sdd | `-- usb-Generic_STORAGE_DEVICE_02773-part1 -> ../../sdd1 |-- by-label | |-- Photos -> ../../sdd1 | |-- SUSE10 -> ../../sda7 | `-- devel -> ../../sda6 |-- by-path | |-- pci-0000:00:1f.2-scsi-0:0:0:0 -> ../../sda | |-- pci-0000:00:1f.2-scsi-0:0:0:0-part1 -> ../../sda1 | |-- pci-0000:00:1f.2-scsi-0:0:0:0-part6 -> ../../sda6 | |-- pci-0000:00:1f.2-scsi-0:0:0:0-part7 -> ../../sda7 | |-- pci-0000:00:1f.2-scsi-1:0:0:0 -> ../../sr0 | |-- usb-02773:0:0:2 -> ../../sdd | |-- usb-02773:0:0:2-part1 -> ../../sdd1 `-- by-uuid |-- 159a47a4-e6e6-40be-a757-a629991479ae -> ../../sda7 |-- 3e999973-00c9-4917-9442-b7633bd95b9e -> ../../sda6 `-- 4210-8F8C -> ../../sdd1
22.8 udev
使用的文件 #
/sys/*
Linux 内核提供的虚拟文件系统,用于导出所有当前已知设备。此信息由
udev
用于在/dev
中创建设备节点/dev/*
动态创建的设备节点和使用 systemd-tmpfiles 创建的静态内容。有关详细信息,请参见
systemd-tmpfiles(8)
手册页。
以下文件和目录包含 udev
基础结构的关键元素:
/etc/udev/udev.conf
主
udev
配置文件。/etc/udev/rules.d/*
系统特定的
udev
事件匹配规则。可在此处添加自定义规则,以修改或覆盖/usr/lib/udev/rules.d/*
中的默认规则。文件将以字母数字顺序进行分析。文件中优先级较高的规则将会修改或覆盖优先级较低的规则。数字越小,优先级越高。
/usr/lib/udev/rules.d/*
默认的
udev
事件匹配规则。此目录中的文件由包拥有,将在更新时重写。请勿在此处添加、去除或编辑文件,而是应使用/etc/udev/rules.d
。/usr/lib/udev/*
从
udev
规则调用的帮助程序。/usr/lib/tmpfiles.d/
和/etc/tmpfiles.d/
负责静态
/dev
内容。
22.9 更多信息 #
有关 udev
基础结构的更多信息,请参见以下手册页:
udev
有关
udev
、键、规则和其他重要配置问题的常规信息。udevadm
udevadm
可用于控制udev
的运行时行为、请求内核事件、管理事件队列,以及提供简单的调试机制。udevd
有关
udev
事件管理守护程序的信息。
23 使用 kGraft 在线增补 Linux 内核 #
本文档介绍 kGraft 在线增补技术的基本原理,并提供 SLE Live Patching 服务的使用准则。
kGraft 是一项在线增补技术,使用它可在运行时增补 Linux 内核,而无需停止内核。如此可以最大程度地确保系统运行时间,从而提高系统可用性,这对于任务关键型系统而言非常重要。该技术还允许动态增补内核,支持用户安装关键的安全性更新,不必将它们推迟到安排的停机时间。
kGraft 增补程序是一个内核模块,用于替换内核中的全部函数。kGraft 主要提供内核中基础结构,可在运行时将增补的代码与基本内核代码集成。
SLE Live Patching 是在常规 SUSE Linux Enterprise Server 维护基础之上提供的服务。通过 SLE Live Patching 分发的 kGraft 是对常规 SLES 维护更新的有益补充。可以使用常用的更新堆栈和过程来部署 SLE Live Patching。
本文档中提供的信息与 AMD64/Intel 64 和 POWER 体系结构相关。如果您使用的是其他体系结构,操作过程可能有所不同。
23.1 kGraft 的优势 #
当需要对紧急情况(已知发生了应该尽力修复的严重漏洞,或者已知的修复程序出现严重的系统稳定性问题)迅速做出响应时,使用 kGraft 进行在线内核增补特别有用。该技术不适合用于非时间关键型的已安排更新。
kGraft 的典型用例包括:配有巨量 RAM,且引导时间经常长达 15 分钟或以上的内存数据库之类的系统、需要持续数周或数月不重启动的大规模仿真,或者向众多消费者持续提供服务的基础架构构建模块。
kGraft 的主要优势是它永不要求停止内核,哪怕是短暂停止。
kGraft 增补程序是 RPM 包中的一个 .ko
内核模块。可以在安装或更新 包时,使用 insmod
命令将它插入内核。kGraft 将替换内核中的全部函数,即使这些函数正在执行。如果需要,可以使用更新的 kGraft 模块替换现有增补程序。
kGraft 也很精简 - 因为利用了其他标准 Linux 技术,它只包含少量的代码。
23.2 kGraft 的底层函数 #
kGraft 使用 ftrace 基础结构执行增补。下面介绍了在 AMD64/Intel 64 体系结构上的实施过程。
为了增补某个内核函数,kGraft 要求该函数的开头有一定的空间,以便插入指向新函数的跳跃点。此空间是在开启函数分析的情况下,在内核编译期间由 GCC 分配的。具体而言,将在内核函数的开头注入一个 5 字节调用指令。引导此类经过检测的内核时,分析调用将替换为 5 字节 NOP(无操作)指令。
增补开始之后,第一个字节将替换为 INT3(断点)指令。这可以确保 5 字节指令替换的原子性。其他四个字节将替换为新函数的地址。最后,第一个字节将替换为 JMP(长跳跃)操作代码。
在整个过程中,将使用处理器间不可屏蔽中断 (IPI NMI) 来刷新系统中其他 CPU 的推理解码队列。这样,无需停止内核(哪怕是非常短暂的停止),就能切换到新的函数。IPI NMI 产生的中断可用毫秒为单位测量,并且不被视为服务中断,因为无论在哪种情况下,这些中断都是在内核运行时发生的。
永远不会增补调用方。被调用方的 NOP 将替换为指向新函数的 JMP。JMP 指令会永久保留。这种工作方式可以处理好函数指针(包括结构中的指针),并且不需要保存任何旧数据就能取消增补。
但是,这些步骤本身并不足够完善:因为函数将以非原子方式替换,内核某个部分中新修复的函数可能仍会调用其他位置的某个旧函数,反之亦然。如果函数接口的语义在增补程序中发生更改,将会造成混乱。
因此,在替换所有函数之前,kGraft 使用基于弹簧床、类似于 RCU(读取-复制-更新)的方案,来确保每个用户空间线程、内核线程和内核中断在全局视图中都保持一致。将对每个内核入口和出口设置一个基于线程的标志。这样,一个旧函数始终会调用另一个旧函数,而一个新函数始终会调用另一个新函数。为所有进程设置“new universe”标志后,增补即告完成,此时,可以去除弹簧床函数,代码可以全速运行,且不会对性能产生影响,不过,每个增补的函数需要经历超长时间的跳转。
23.3 安装 kGraft 增补程序 #
本节介绍如何激活 SUSE Linux Enterprise Live Patching 扩展以及如何安装 kGraft 增补程序。
23.3.1 激活 SLE Live Patching #
要在您的系统上激活 SLE Live Patching,请遵循以下步骤:
如果您的 SLES 系统尚未注册,现在请注册。可以在安装系统期间完成注册,或者以后使用 YaST
模块 (yast2 registration
) 执行注册。注册后,单击 查看可用联机更新的列表。如果您的 SLES 系统已注册,但 SLE Live Patching 尚未激活,请打开 YaST
模块 (yast2 registration
),然后单击 。在可用扩展列表中选择
,然后单击 。确认许可条款并单击
。输入 SLE Live Patching 注册代码并单击
。检查
和选定的 。应该选择安装Live Patching
模式。单击
完成安装。这样就会在您的系统上安装 kGraft 基本组件以及初始在线增补程序。
23.3.2 更新系统 #
SLE Live Patching 更新通过允许使用标准 SLE 更新堆栈来应用增补程序的形式分发。可以使用
zypper patch
、YaST 联机更新或等效的方法来更新初始在线增补程序。内核将在安装包的过程中自动增补。但是,在所有休眠进程都唤醒并避开前,旧内核函数的调用并不会完全消除。这可以节省大量的时间。尽管如此,使用旧内核函数的休眠进程并不被视为安全问题。不过,在最新的 kGraft 版本中,只有当所有进程都超出了内核用户空间界限时,才可以应用另一个 kGraft 增补程序来停止使用前一增补程序已增补的功能。
要查看全局增补状态,请检查
/sys/kernel/kgraft/in_progress
中的标志。值1
表示存在仍需唤醒的休眠进程(增补仍在进行)。值0
表示所有进程都只使用了增补的函数,并且增补已经完成。或者,可以使用kgr status
命令获取相同的信息。也可以基于每个进程检查标志。针对每个进程单独检查
/proc/PROCESS_NUMBER/kgr_in_progress
中的数字。同样,值1
表示仍需唤醒的休眠进程。或者,可以使用kgr blocking
命令输出休眠进程的列表。
23.4 增补程序生命周期 #
可以使用 zypper lifecycle
来查看在线增补程序的失效日期。确保包
lifecycle-data-sle-live-patching 已安装。
当到了增补程序的失效日期时,将不再提供此内核版本的更多在线增补程序。请在在线增补程序生命周期期限结束之前规划内核更新。
有关 zypper lifecycle
的细节,请参见《管理员指南》中的“显示生命周期信息”。
23.5 去除 kGraft 增补程序 #
要去除 kGraft 增补程序,请执行以下过程:
首先,使用 Zypper 去除增补程序本身:
tux >
sudo
zypper rm kgraft-patch-3_12_32-25-default然后重引导计算机。
23.6 阻塞的内核执行线程 #
需要准备好内核线程才能处理 kGraft。第三方软件不一定能够配合 kGraft,并且其内核模块可能会衍生大量的内核执行线程。这些线程会无限期阻止增补过程。作为应急措施,kGraft 允许强行完成增补过程,而不等待所有执行线程跨越安全检查点。这可以通过在 /sys/kernel/kgraft/in_progress
中写入 0
来实现。在执行此过程之前,请先咨询 SUSE 支持人员。
23.7 kgr
工具 #
使用 kgr
工具可以简化一些 kGraft 管理任务。可用的命令为:
kgr status
显示 kGraft 增补的总体状态(
ready
或in_progress
)。kgr patches
显示已装载 kGraft 增补程序的列表。
kgr blocking
列出阻止 kGraft 完成增补的进程。默认情况下,只会列出 PID。指定
-v
会列显命令行(如果有)。再指定一个-v
还会显示堆栈跟踪。
有关详细信息,请参见 man kgr
。
23.8 kGraft 技术的应用范围 #
kGraft 的工作原理以替换函数为基础。数据结构的改动只能通过 kGraft 间接完成。因此,更改内核数据结构时需要特别小心,如果更改幅度太大,可能需要重引导。此外,kGraft 可能无法处理使用一个编译器来编译旧内核,使用另一个编译器来编译增补程序的情况。
由于 kGraft 的工作方式,对衍生大量内核线程的第三方模块的支持有限。
23.9 SLE Live Patching 的应用范围 #
SLE Live Patching 的应用范围包括 SUSE 通用漏洞评分系统(CVSS;SUSE CVSS 基于 CVSS v3.0 系统)级别 7 以上漏洞的修复,以及与系统稳定性或数据损坏相关的 Bug 修复。可能无法针对满足上述所有准则的所有修复类型生成在线增补程序。如果出于技术原因而无法生成内核在线增补程序,SUSE 有权不发布修复。有关作为 SUSE CVSS 评级基础的 CVSS 的详细信息,请参见 https://www.first.org/cvss/。
23.10 使用支持流程与我们交互 #
在与 SUSE 支持人员共同解决技术难题时,您可能会收到一个所谓的程序临时修复 (PTF)。我们可能会针对各种包(包括构成 SLE Live Patching 基础的包)发布 PTF。
您可以像平时一样安装符合上一节中所述条件的 kGraft PTF,SUSE 将确保无需重引导有问题的系统,并且将来的在线更新可以正常应用。
针对基础内核发布的 PTF 会中断在线增补过程。首先,安装 PTF 内核意味着需要重引导,因为在运行时无法替换整个内核。其次,需要再次重引导,以便将 PTF 替换为对其发布了在线增补程序的任何常规维护更新。
可将 SLE Live Patching 中其他包的 PTF 视为享有正常担保的常规 PTF。
24 特别的系统功能组件 #
本章首先提供有关各种软件包、虚拟控制台和键盘布局的信息。讨论诸如 bash
、cron
和 logrotate
等软件组件,因为在最后的发行周期中已对这些组件进行了更改或增强。即使这些组件很小或者被认为不太重要,用户也应该更改它们的默认行为,因为这些组件往往与系统密切相关。本章的最后是有关语言和国家/地区特定设置(I18N 和 L10N)的内容。
24.1 特殊软件包的相关信息 #
程序 bash
、cron
、logrotate
、locate
、ulimit
和 free
对于系统管理员和许多用户是非常重要的。手册页和信息页是命令相关信息的两个有用来源,但是它们并不是始终可用的。GNU Emacs 是一种流行的并且非常容易配置的文本编辑器。
24.1.1 bash
包和 /etc/profile
#
Bash 是默认的系统外壳。在用作登录外壳时,它将读取几个初始化文件。Bash 按照这些文件在列表中出现的顺序处理它们:
/etc/profile
~/.profile
/etc/bash.bashrc
~/.bashrc
在 ~/.profile
或 ~/.bashrc
中进行自定义设置。要确保正确处理这些文件,需要将基本设置从 /etc/skel/.profile
或 /etc/skel/.bashrc
复制到用户的主目录中。建议在更新后从 /etc/skel
复制这些设置。执行以下外壳命令可防止个人调整的损失:
tux >
mv ~/.bashrc ~/.bashrc.oldtux >
cp /etc/skel/.bashrc ~/.bashrctux >
mv ~/.profile ~/.profile.oldtux >
cp /etc/skel/.profile ~/.profile
然后从 *.old
文件将个人调整复制过来。
24.1.2 cron 包 #
使用 cron
可在预定义的时间自动在后台运行命令。cron
使用格式经过特别设置的时间表,并且该工具随附了几个默认的时间表。用户也可以根据需要指定自定义的表。
cron 表位于 /var/spool/cron/tabs
中。/etc/crontab
用作系统范围的 cron 表。输入在时间表之后且在此命令之前运行此命令的用户名。在例 24.1 “/etc/crontab 中的项” 中,输入的是 root
。位于 /etc/cron.d
中的包特定的表具有相同的格式。请参见 cron
手册页 (man cron
)。
1-59/5 * * * * root test -x /usr/sbin/atrun && /usr/sbin/atrun
不能通过调用命令 crontab -e
来编辑 /etc/crontab
。必须直接将此文件装载到编辑器中,然后对其进行修改并保存。
有些包会将外壳脚本安装到 /etc/cron.hourly
、/etc/cron.daily
、/etc/cron.weekly
和 /etc/cron.monthly
目录中,这些脚本的执行由 /usr/lib/cron/run-crons
控制。/usr/lib/cron/run-crons
每隔 15 分钟在主表 (/etc/crontab
) 中运行一次。这样可以确保在适当的时间运行可能被忽略的进程。
要运行 hourly
、daily
或在自定义时间运行其他周期性维护脚本,请删除通常使用 /etc/crontab
项的时戳文件(请参见例 24.2 “/etc/crontab:删除时戳文件”,它删除了每个整点之前的 hourly
和每天凌晨 2:14 的 daily
等)。
59 * * * * root rm -f /var/spool/cron/lastrun/cron.hourly 14 2 * * * root rm -f /var/spool/cron/lastrun/cron.daily 29 2 * * 6 root rm -f /var/spool/cron/lastrun/cron.weekly 44 2 1 * * root rm -f /var/spool/cron/lastrun/cron.monthly
或者,在 /etc/sysconfig/cron
中将 DAILY_TIME
设置为应启动 cron.daily
的时间。MAX_NOT_RUN
的设置确保即使用户很长一段时间都未在指定的 DAILY_TIME
打开计算机,日常任务仍被触发运行。MAX_NOT_RUN
的最大值为 14 天。
为了清楚起见,将日常系统维护任务分布在多个脚本中。这些脚本包含在包 aaa_base
中。例如,/etc/cron.daily
包含组件 suse.de-backup-rpmdb
、suse.de-clean-tmp
或 suse.de-cron-local
。
24.1.3 停止 Cron 状态讯息 #
要避免 cron 状态讯息导致的邮件泛滥,请将新安装产品的 /etc/sysconfig/cron
中 SEND_MAIL_ON_NO_ERROR
的默认值设为“no
”。即使将此设置设为“no
”,cron 数据输出仍然会发送到 MAILTO
地址,如 cron 手册页中所述。
在更新时,建议根据需要设置这些值。
24.1.4 日志文件:包 logrotate #
多个系统服务(守护程序)以及内核本身会定期将系统状态和特定事件记录到日志文件中。这样,管理员可以定期检查系统在某一时刻的状态,识别错误或故障功能,并精确诊断它们。这些日志文件通常储存在 FHS 指定的 /var/log
中,文件大小每天都会增长。logrotate
包可以帮助控制这些文件的增长。有关详细信息,请参见Book “System Analysis and Tuning Guide”, Chapter 3 “Analyzing and Managing System Log Files”, Section 3.3 “Managing Log Files with logrotate
”。
24.1.5 locate
命令 #
locate
是一个用于查找文件的命令,它不包括在已安装软件的标准范围内。如果需要,请安装 mlocate
包,它是 findutils-locate
包的后继者。updatedb 进程将在每天晚上或引导系统约 15 分钟后自动启动。
24.1.6 ulimit
命令 #
使用 ulimit
(用户限制)命令可以为系统资源的使用设置限制并使其显示出来。ulimit
对于限制应用程序的可用内存尤其有用。设置可用内存限制后,可以防止应用程序占用过多系统资源,而导致操作系统变慢甚至挂起。
可以对
ulimit 使用多个选项。要限制使用内存,请使用表 24.1 “ulimit
:为用户设置资源” 中列出的选项。
ulimit
:为用户设置资源 #
|
最大驻留集大小 |
|
外壳可用虚拟内存的最大量 |
|
堆栈的最大大小 |
|
创建的核心文件的最大大小 |
|
所有当前限制均已报告 |
系统范围的默认项在 /etc/profile
中设置。建议不要直接编辑此文件,因为系统升级期间会覆盖所做的更改。要自定义系统范围的配置文件设置,请使用 /etc/profile.local
。各用户的设置应该在 ~USER/.bashrc
中配置。
ulimit
:~/.bashrc
中的设置 ## Limits maximum resident set size (physical memory): ulimit -m 98304 # Limits of virtual memory: ulimit -v 98304
必须以 KB 为单位指定内存分配。有关详细信息,请参见 man bash
。
ulimit
支持
并非所有外壳都支持 ulimit
指令。PAM(例如 pam_limits
)作为替代 ulimit
的方法,提供了全面的调整功能。
24.1.7 free
命令 #
free
命令显示系统中总的可用内存、已用物理内存和交换空间,以及内核占用的缓冲区和超速缓存。可用 RAM 的概念可追溯到统一内存管理之前。可用内存不是好的内存这种说法非常适用于 Linux。 因此,Linux 一直在平衡缓存方面下功夫,不允许实际上存在可用或未使用的内存。
内核对任何应用程序或用户数据都没有直接的了解。而是在一个页缓存中管理应用程序和用户数据。如果内存不足,它的某些部分会被写入交换分区或文件中,这样,使用 mmap
命令便可一开始就从这些交换分区或文件中读取这些部分(请参见 man mmap
)。
此外,内核中还包含其他缓存,如 slab 缓存,其中储存着用于网络访问的缓存。这也许能够解释 /proc/meminfo
中计数器之间的差异。通过 /proc/slabinfo
可以访问大多数(但并非全部)上述缓存。
但是如果您的目的是找出当前所用的 RAM 量,则在 /proc/meminfo
中查找此信息。
24.1.8 手册页和信息页 #
对于某些 GNU 应用程序(如 tar),已不再保留手册页。对于这些命令,可使用 --help
选项快速查看信息页,其中提供更多深入的描述。info 是 GNU 的超文本系统。通过输入 info
info
可以看到此系统的介绍。通过输入 emacs
-f Info
可使用 Emacs 查看信息页,也可以在控制台中使用 info
直接查看信息页。还可以使用 tkinfo、xinfo 或帮助系统来查看信息页。
24.1.9 使用 man
命令选择手册页 #
要阅读手册页,请输入 man
MAN_PAGE。如果不同章节存在同名手册页,所有手册页都会带相应部分编号列出。选择要显示的一个手册页。如果在数秒内未输入部分编号,将显示第一个手册页。
要将此行为更改为默认系统行为,请在外壳初始化文件(如 ~/.bashrc
)中设置 MAN_POSIXLY_CORRECT=1
。
24.1.10 GNU Emacs 的设置 #
GNU Emacs 是一个复杂的工作环境。下面几节介绍当启动 GNU Emacs 时处理的配置文件。有关详细信息,请参见 http://www.gnu.org/software/emacs/。
启动时,Emacs 会读取包含用户、系统管理员和经销商的设置的多个文件以进行自定义或预配置。初始化文件 ~/.emacs
被安装到 /etc/skel
中各个用户的主目录中。.emacs
又会读取文件 /etc/skel/.gnu-emacs
。要自定义程序,请(通过 cp /etc/skel/.gnu-emacs ~/.gnu-emacs
)将 .gnu-emacs
复制到用户主目录并在那里进行所需的设置。
.gnu-emacs
将文件 ~/.gnu-emacs-custom
定义为 custom-file
。如果用户通过 Emacs 中的 customize
选项进行设置,则这些设置将保存到 ~/.gnu-emacs-custom
中。
使用 SUSE Linux Enterprise Desktop 时,emacs
包会在目录 /usr/share/emacs/site-lisp
中安装 site-start.el
文件。文件 site-start.el
在初始化文件 ~/.emacs
之前进行装载。除其他作用之外,site-start.el
确保自动装载通过 Emacs 扩充包分发的特殊配置文件(例如 psgml
)。此类型的配置文件也位于 /usr/share/emacs/site-lisp
中,总是以 suse-start-
开头。本地系统管理员可以在 default.el
中指定整个系统范围的设置。
初始化文件下的 EMACS 信息文件中提供了有关这些文件的更多信息:info:/emacs/InitFile
。此位置还提供了有关如何禁止装载这些文件(如果需要)的信息。
Emacs 的部件被分成多个包:
基础包
emacs
。emacs-x11
(通常已安装):支持 X11 的程序。emacs-nox
:不支持 X11 的程序。emacs-info
:info 格式的联机文档。emacs-el
:Emacs Lisp 中未编译的库文件。运行时不需要这些库文件。如果需要,可安装众多附加产品包:
emacs-auctex
(LaTeX)、psgml
(SGML 和 XML)、gnuserv
(客户端和服务器操作)等。
24.2 虚拟控制台 #
Linux 是一个多用户和多任务的系统。即使是在独立计算机系统上也可以感受到这些功能的好处。在文本方式下,提供了 6 个虚拟控制台。可以使用 Alt–F1 到 Alt–F6 在这些控制台间切换。第 7 个控制台是为 X 保留的,而第 10 个控制台显示内核消息。
要从 x 切换到控制台而不将其关闭,请使用 Ctrl–Alt–F1 到 Ctrl–Alt–F6。要返回到 X,请按 Alt–F7。
24.3 键盘映射 #
为了标准化程序的键盘映射,对以下文件进行了更改:
/etc/inputrc /etc/X11/Xmodmap /etc/skel/.emacs /etc/skel/.gnu-emacs /etc/skel/.vimrc /etc/csh.cshrc /etc/termcap /usr/share/terminfo/x/xterm /usr/share/X11/app-defaults/XTerm /usr/share/emacs/VERSION/site-lisp/term/*.el
这些更改只影响使用 terminfo
项的应用程序或其配置文件被直接更改(vi
、less
等)的应用程序。不是系统附带的应用程序应该根据这些默认设置进行调整。
在 X 下,可以如 /etc/X11/Xmodmap
中所说明的启用 Compose 键(多键)。
可以通过“X 键盘扩展”(XKB) 进行进一步的设置。桌面环境 GNOME (gswitchit) 也使用此扩展。
有关 XKB 的信息可以在 /usr/share/doc/packages/xkeyboard-config
(xkeyboard-config
包的一部分)所列的文档中找到。
24.4 语言和国家/地区特定的设置 #
该系统在很大程度上实现了国际化,可修改以满足本地需要。国际化 (I18N) 允许特定的本地化 (L10N)。I18N 和 L10N 这两个缩写词使用原单词的第一个和最后一个字母,中间的数字表示省略的字母数。
设置是通过文件 /etc/sysconfig/language
中定义的 LC_
变量进行的。这不仅指本地语言支持,还指消息(语言)、字符集、排序顺序、时间和日期、数字和货币等类别。这些类别中的每一种都可以使用自己的变量直接定义,或使用 language
文件中的主变量间接定义(请参见 locale
手册页)。
RC_LC_MESSAGES
、RC_LC_CTYPE
、RC_LC_COLLATE
、RC_LC_TIME
、RC_LC_NUMERIC
、RC_LC_MONETARY
这些变量以不带
RC_
前缀的形式传递到外壳,它们代表所列出的类别。下面列出了相关外壳配置文件。可以使用命令locale
显示当前设置。RC_LC_ALL
此变量(如果设置)将覆盖上述变量的值。
RC_LANG
如果未设置上述的任何变量,则这是后备变量。默认情况下,只设置
RC_LANG
。这便于用户输入他们自己的值。ROOT_USES_LANG
yes
或no
变量。如果将其设置为no
,则root
用户始终在 POSIX 环境中工作。
这些变量可通过 YaST sysconfig 编辑器进行设置。此类变量的值包含语言代码、国家/地区代码、编码和修饰符。各部分之间通过特殊字符连接:
LANG=<language>[[_<COUNTRY>].<Encoding>[@<Modifier>]]
24.4.1 一些示例 #
语言和国家/地区代码始终应该一起设置。语言设置遵循 ISO 639 标准(可从 http://www.evertype.com/standards/iso639/iso639-en.html 和 http://www.loc.gov/standards/iso639-2/ 上获取)。国家/地区代码在 ISO 3166(参见 http://en.wikipedia.org/wiki/ISO_3166)中列出。
只有设置可以在 /usr/lib/locale
中找到其可用描述文件的值才有意义。可以使用命令 localedef
基于 /usr/share/i18n
中的文件创建更多描述文件;描述文件是 glibc-i18ndata
包的一部分。可以使用以下命令创建 en_US.UTF-8
(用于英国英语和美国英语)的描述文件:
localedef -i en_US -f UTF-8 en_US.UTF-8
-
LANG=en_US.UTF-8
如果在安装过程中选择的是美国英语,则这是默认设置。如果选择了其他语言,则将支持该语言,但仍使用 UTF-8 作为字符编码。
-
LANG=en_US.ISO-8859-1
这会将语言设置为英语,将国家/地区设置为美国,将字符集设置为
ISO-8859-1
。此字符集不支持欧元符号,但它有时可用于尚未进行更新以支持UTF-8
的程序。随后,Emacs 等程序将对定义字符集的字符串(在本例中为ISO-8859-1
)进行求值。LANG=en_IE@euro
上例将欧元符号显式包含在语言设置中。此设置现已过时,因为 UTF-8 也可涵盖欧元符号。仅当应用程序支持 ISO-8859-15 而不是 UTF-8 时,它才有用。
对 /etc/sysconfig/language
所做的更改将通过以下过程链来激活:
对于 Bash:
/etc/profile
读取/etc/profile.d/lang.sh
,后者则分析/etc/sysconfig/language
。对于 tcsh:
/etc/csh.login
在登录时读取/etc/profile.d/lang.csh
,后者则分析/etc/sysconfig/language
。
这确保了对 /etc/sysconfig/language
所做的任何更改在下次登录到相应外壳时均可用,而无需手动将其激活。
用户可以通过相应地编译他们的 ~/.bashrc
覆盖系统默认值。例如,如果不想对程序讯息使用系统范围的 en_US
,请加入 LC_MESSAGES=es_ES
,这样讯息将以西班牙语显示。
24.4.2 ~/.i18n
中的语言环境设置 #
如果您对系统默认的区域设置不满意,请根据 Bash 脚本编写语法更改 ~/.i18n
中的设置。~/.i18n
中的项覆盖来自 /etc/sysconfig/language
中的系统默认值。使用相同的变量名而不使用 RC_
名称空间前缀。例如,使用 LANG
而不是 RC_LANG
:
LANG=cs_CZ.UTF-8 LC_COLLATE=C
24.4.3 语言支持的设置 #
消息类别中的文件通常只储存在对应的语言目录(例如 en
)中以保留后备。如果将 LANG
设置为 en_US
并且 /usr/share/locale/en_US/LC_MESSAGES
中的消息文件不存在,则它将使用 /usr/share/locale/en/LC_MESSAGES
。
还可以定义后备语言,例如,将布列塔尼语作为法语的后备语言,将加利西亚语作为葡萄牙语的后备语言。
LANGUAGE="br_FR:fr_FR"
LANGUAGE="gl_ES:es_ES:pt_PT"
如果需要,可改用挪威语变体 Nynorsk 和 Bokmal(将其他后备语言设置为 no
):
LANG="nn_NO"
LANGUAGE="nn_NO:nb_NO:no"
或
LANG="nb_NO"
LANGUAGE="nb_NO:nn_NO:no"
请注意,在挪威语中,LC_TIME
的处理方式也有所不同。
可能会出现一个问题,那就是无法正确识别用于分隔成组数位的分隔符。如果 LANG
设置为仅两个字母的语言代码(如 de
),但使用的定义文件 glibc 位于 /usr/share/lib/de_DE/LC_NUMERIC
,则将出现此问题。因此必须将 LC_NUMERIC
设置为 de_DE
以使系统能够识别出分隔符定义。
24.4.4 更多信息 #
《GNU C 库参考手册》中的“区域设置和国际化”一章”。它包含在
glibc-info
中。该包可从 SUSE Linux Enterprise SDK 中获取。SDK 是适用于 SUSE Linux Enterprise 的模块,可以通过 SUSE Customer Center 的在线通道获得,或者,请转到 http://download.suse.com/,搜索SUSE Linux Enterprise Software Development Kit
并从该处下载。有关细节,请参见Book “Deployment Guide”, Chapter 17 “Installing Modules, Extensions, and Third Party Add-On Products”Markus Kuhn 编写的 Unix/Linux 的 UTF-8 和 Unicode 常见问题解答,当前位于 http://www.cl.cam.ac.uk/~mgk25/unicode.html。
Bruno Haible 撰写的 Unicode-Howto,网址为 http://tldp.org/HOWTO/Unicode-HOWTO-1.html。
25 使用 NetworkManager #
NetworkManager 是用于便携式计算机和其他可移动计算机的理想解决方案。它支持网络连接的顶级加密类型和标准,包括 802.1x 保护的网络的连接。802.1X 是“基于端口的网络访问控制的本地和城域网 IEEE 标准”。使用 NetworkManager,您在外出时就不必顾虑网络接口的配置,以及在有线或无线网络之间切换的问题。NetworkManager 可自动连接到已知无线网络或并行管理多个网络连接 - 然后将最快的连接用作默认连接。而且,您还可手动在可用网络之间切换,并使用系统盘中的小程序管理网络连接。
不只可激活一个连接,也可同时激活多个。这样您可以将便携式计算机从以太网连接拔出后仍通过无线连接保持连接状态。
25.1 NetworkManager 的用例 #
NetworkManager 提供了完善且直观的用户界面,可使用户轻松地切换其网络环境。但是,在以下情况下,NetworkManager 解决方案不适用:
您的计算机将为网络中的其他计算机(例如,DHCP 或 DNS 服务器)提供网络服务。
您的计算机为 Xen 服务器或您的系统是 Xen 内的虚拟系统。
25.2 启用或禁用 NetworkManager #
在便携式计算机上,默认情况下 NetworkManager 处于启用状态。但是,任何时候都可以在 YaST 网络设置模块中启用或禁用它。
运行 YaST,然后转到
› 。将打开
对话框。转到 选项卡。要通过 NetworkManager 配置和管理您的网络连接,请执行以下操作:
在
字段中选择 。单击
并关闭 YaST。按照第 25.3 节 “配置网络连接”中所述通过 NetworkManager 配置您的网络连接。
停用 NetworkManager 并使用您自己的配置控制网络:
在
字段中选择 。单击
。通过 YaST 设置您的网卡,即通过 DHCP 或静态 IP 地址进行自动配置。
第 17.4 节 “使用 YaST 配置网络连接”中提供了使用 YaST 进行网络配置的详细说明。
25.3 配置网络连接 #
在 YaST 中启用 NetworkManager 后,使用 GNOME 中提供的 NetworkManager 前端配置网络连接。它会显示所有网络连接类型对应的选项卡,例如有线、无线、移动宽带、DSL 和 VPN 连接。
要在 GNOME 中打开网络配置对话框,请通过状态菜单打开设置菜单,然后单击
项。
根据您的系统设置,可能不允许您配置连接。在安全环境中,某些选项可能会被锁定或需要 root
权限。请咨询系统管理员以了解细节。
打开 NetworkManager 配置对话框。
添加连接:
单击左下角的
图标。选择首选连接类型并按照指示操作。
完成后,单击
。确认您的更改后,打开“状态菜单”,便会在显示的可用网络列表中看到新配置的网络连接。
编辑连接:
选择要编辑的项目。
单击齿轮图标打开
对话框。插入您的更改,然后单击
保存更改。要让您的连接可用作系统连接,请转到第 25.4.1 节 “用户和系统连接”。
选项卡,选中复选框 。有关用户和系统连接的详细信息,请参见
25.3.1 管理有线网络连接 #
如果您的计算机连接的是有线网络,请使用 NetworkManager 小程序管理连接。
打开“状态菜单”,然后单击
以更改连接细节或将其关闭。要更改设置,请单击
,然后单击齿轮图标。要关闭所有网络连接,请激活
设置。
25.3.2 管理无线网络连接 #
可见的无线网络在
下的 GNOME NetworkManager 小程序菜单中列出。每个网络的信号强度也会显示在菜单中。加密无线网络是用保护物图标标记的。要连接可见无线网络,请打开“状态菜单”然后单击
。单击
将其启用。单击
,选择 Wi-Fi 网络然后单击 。如果网络已加密,一个配置对话框将会打开。其中会显示网络使用的加密类型以及用于输入登录凭证的文本框。
要连接到未广播其服务集标识符(SSID 或 ESSID)因而无法自动检测到的网络,请打开“状态菜单”,然后单击
。单击
打开详细设置菜单。确保您的 Wi-Fi 处于启用状态,然后单击
。在打开的对话框中的
中输入 SSID 或 ESSID,并视需要设置加密参数。
显式选中的无线网络将尽可能始终保持连接。如果在此期间插入网线,则会连接任何设置为
的连接,而无线连接也会保持连接状态。25.3.3 启用无线强制网络门户检测 #
在连接建立之初,许多公共的无线热点会强制用户访问登录页(称为强制网络门户)。在您登录或同意条款与条件之前,所有的 HTTP 请求都会重定向到提供者的强制网络门户。
通过强制网络门户连接到无线网络后,NetworkManager 和 GNOME 会自动显示登录页面(这属于连接过程的一部分)。这样做可以确保一旦连接成功您便能知道,并帮助您在不使用浏览器登录系统的情况下,尽快完成设置。
要启用此功能,请安装 NetworkManager-branding-SLE 包,并通过以下命令重启动 NetworkManager:
tux >
sudo
systemctl restart network
一旦通过强制网络门户连接到网络,NetworkManager(或 GNOME)便会为您打开强制网络门户登录页面。使用您的身分凭证登录,以便访问因特网。
25.3.4 将 Wi-Fi/蓝牙网卡配置为接入点 #
如果您的 Wi-Fi/蓝牙网卡支持接入点模式,则可以使用 NetworkManager 进行配置。
打开“状态菜单”,然后单击
。单击
打开详细设置菜单。单击
并按照指示操作。使用随后出现的对话框中显示的身份凭证来连接远程计算机的热点。
25.3.5 NetworkManager 和 VPN #
NetworkManager 支持多种虚拟专用网 (VPN) 技术。对于每种技术,SUSE Linux Enterprise Desktop 都随附了提供 NetworkManager 常规支持的基础包。此外,还需要为您的小程序安装特定于桌面的包。
- OpenVPN
要使用此 VPN 技术,请安装:
NetworkManager-openvpn
NetworkManager-openvpn-gnome
- OpenConnect
要使用此 VPN 技术,请安装:
NetworkManager-openconnect
NetworkManager-openconnect-gnome
- PPTP(点对点隧道协议)
要使用此 VPN 技术,请安装:
NetworkManager-pptp
NetworkManager-pptp-gnome
以下过程介绍如何使用 NetworkManager 将您的计算机设置为 OpenVPN 客户端。设置其他类型 VPN 的过程与此类似。
开始之前,请确保包 NetworkManager-openvpn-gnome
已安装,并且所有依赖项均已解析。
依次单击位于面板右端的状态图标和
图标,打开应用程序 。在 窗口中,选择 。单击
图标。依次选择
和 。选择
类型。根据 OpenVPN 服务器的设置,选择 或 。将所需的值插入到相应文本框中。对于我们的示例配置,值如下所示:
VPN 服务器的远程端点
用户(仅当选择了
时才可用)用户口令(仅当选择了
时才可用)/etc/openvpn/client1.crt
/etc/openvpn/ca.crt
/etc/openvpn/client1.key
单击
完成配置。要启用连接,请在
应用程序的 面板中,单击切换按钮。也可以单击位于面板右端的状态图标,然后依次单击您的 VPN 名称和 。
25.4 NetworkManager 和安全性 #
NetworkManager 将无线连接分为可信和不可信两种类型。可信连接是您过去明确选择的任何网络。所有其他连接均为不可信连接。可信连接用接入点的名称和 MAC 地址识别。使用 MAC 地址可以确保带有可信连接名称的不同接入点不可使用。
NetworkManager 会定期扫描是否存在可用的无线网络。如果找到多个可信网络,则自动选择最近使用的可信网络。如果所有网络均不可信,NetworkManager 将等待您做出选择。
如果加密设置改变,但名称和 MAC 地址不变,则 NetworkManager 将尝试连接,但首先会要求您确认新的加密设置并提供所有更新(如新密钥)。
如果您从使用无线连接切换到脱机模式,则 NetworkManager 会将 SSID 或 ESSID 设为空白。这可以确保断开网卡连接。
25.4.1 用户和系统连接 #
NetworkManager 可识别两种类型的连接:用户
连接和系统
连接。用户连接是第一个用户登录时对 NetworkManager 可用的连接。会要求该用户提供所有必需的身份凭证,当该用户注销时,连接会断开并从 NetworkManager 中去除。定义为系统连接的连接可由所有用户共享,在有用户登录前,只要 NetworkManager 启动后即可使用。如果是系统连接,必须在创建连接时提供所有身份凭证。此类系统连接可用于自动连接到要求授权的网络。有关如何用 NetworkManager 配置用户连接或系统连接的信息,请参见第 25.3 节 “配置网络连接”。
25.4.2 储存密码和身份凭证 #
如果不想每次连接到加密网络时都要再次输入身份凭证,则可以使用 GNOME 密钥环管理器将身份凭证加密存储在磁盘上,并用主密码保护。
25.4.3 防火墙区域 #
firewalld
区域 #防火墙区域设置有关允许哪些网络连接的一般规则。要为有线连接配置 firewalld 的区域,请转至连接设置的身份选项卡。要为 WiFi 连接配置 firewalld 的区域,请转至连接设置的安全性选项卡。
如果您位于家庭网络中,请使用 home
区域。如果使用的是公共无线网络,请切换到 public
。如果您位于安全的环境中并想要允许所有连接,请使用 trusted
区域。
有关 firewalld 的细节,请参见Book “Security and Hardening Guide”, Chapter 22 “Masquerading and Firewalls”, Section 22.4 “firewalld
”。
25.5 常见问题 (FAQ) #
下面是关于使用 NetworkManager 配置特殊网络选项的一些常见问题。
- 1. 如何将连接绑定到特定设备?
默认情况下,NetworkManager 中的连接是特定于设备类型的:它们适用于同一类型的所有物理设备。如果每个连接类型有多台物理设备可用(例如您的计算机装有两块以太网卡),您可以将一个连接绑定到特定设备。
要在 GNOME 中执行此操作,请先查找设备的 MAC 地址(使用小程序中提供的
,或者使用nm-tool
或wicked show all
等命令行工具的输出)。然后启动配置网络连接的对话框,选择您要修改的连接。在 或 选项卡上,输入设备的 ,并确认更改。
- 2. 如果检测到同一 ESSID 有多个接入点,如何指定特定接入点?
当有不同无线波段 (a/b/g/n) 的多个接入点时,默认情况下会自动选择信号最强的接入点。要覆盖此值,配置无线连接时请使用
字段。基本服务集标识 (BSSID) 可唯一标识每个基本服务集。在基础结构基本服务集中,BSSID 是无线接入点的 MAC 地址。在独立(特别)基本服务集中,BSSID 是本地管理的 MAC 地址(从 46 位数字随机生成)。
如第 25.3 节 “配置网络连接” 中所述启动配置网络连接的对话框。选择要修改的无线连接,然后单击 。在 选项卡上,输入 BSSID。
- 3. 如何与其他计算机共享网络连接?
主设备(连接到因特网的设备)不需要任何特殊配置。但是,需要如下配置连接到本地集线器或计算机的设备:
如第 25.3 节 “配置网络连接” 中所述启动配置网络连接的对话框。选择要修改的连接,然后单击 。切换到 选项卡,并激活 下拉框中的 。这将启用 IP 通讯转发并运行该设备上的 DHCP 服务器。确认在 NetworkManager 中所做更改。
由于 DCHP 服务器使用端口
67
,请确保该端口没有被防火墙阻止:在共享连接的计算机上,启动 YaST 并选择 › 。切换到 类别。如果 尚未显示为 ,请从 中选择 ,然后单击 。确认在 YaST 中所做更改。
- 4. 如何对自动(DHCP、PPP、VPN)地址提供静态 DNS 信息?
如果 DHCP 服务器提供无效的 DNS 信息(和/或路由),则可以覆盖它。如第 25.3 节 “配置网络连接” 中所述启动配置网络连接的对话框。选择要修改的连接,然后单击 。切换到 选项卡,并激活 下拉框中的 。在 和 字段中输入 DNS 信息。要 ,请单击 ,然后激活相应的复选框。确认更改。
- 5. 如何在用户登录之前将 NetworkManager 连接到受口令保护的网络?
定义可以用于此类用途的
系统连接
。有关更多信息,请参考第 25.4.1 节 “用户和系统连接”。
25.6 查错 #
可能出现连接问题。与 NetworkManager 相关的一些常见问题包括小程序不启动或缺少 VPN 选项。解决方法和预防这些问题的方法随使用的工具而定。
- NetworkManager 桌面小程序没有启动
如果设置了 NetworkManager 控制的网络,小程序会自动启动。如果小程序未启动,请按照第 25.2 节 “启用或禁用 NetworkManager”中所述检查是否在 YaST 中启用了 NetworkManager。然后,请确保 NetworkManager-gnome 包也已安装。
如果该桌面小程序已安装但由于某些原因没有运行,请用命令
nm-applet
手动启动它。- NetworkManager 小程序不包括 VPN 选项
对 NetworkManager 的支持、小程序以及适用于 NetworkManager 的 VPN 已在不同的包中分发。如果 NetworkManager 小程序不包括 VPN 选项,请检查带有 NetworkManager 支持的 VPN 技术的包是否已经安装。有关详细信息,请参见第 25.3.5 节 “NetworkManager 和 VPN”。
- 没有可用的网络连接
如果您已正确配置网络连接并且网络连接的所有其他组件(路由器等等)也已启动并在正常运行,则重启动计算机上的网络接口有时可能有帮助。要实现此目的,请以
root
身份登录到命令行,然后运行systemctl restart wicked
。
25.7 更多信息 #
可在以下网站和目录中找到有关 NetworkManager 的更多信息:
- NetworkManager 项目页
- 包文档
还可以在以下目录中找到有关 NetworkManager 和 GNOME 小程序的最新信息:
/usr/share/doc/packages/NetworkManager/
,/usr/share/doc/packages/NetworkManager-gnome/
。
26 电源管理 #
电源管理对于便携式计算机特别重要,但对于其他系统也是有用的。ACPI(高级配置和电源接口)在所有通用计算机(便携式计算机、台式机和服务器)上都可用。电源管理技术需要合适的硬件和 BIOS 例程。大多数便携式计算机、许多目前的台式机和服务器都符合这些要求。还可以通过控制 CPU 频率调节以达到省电或降低噪音的目的。
26.1 省电功能 #
省电功能不仅对便携式计算机的移动使用很重要,而且对台式机系统也很重要。ACPI 中的主要功能和它们的用法为:
- 待机
不支持。
- 暂停(到内存)
此方式将整个系统状态写入 RAM。随后,除 RAM 外,整个系统都进入休眠状态。在此状态下,计算机消耗的电量非常少。此状态的优点是无需引导和重启动应用程序就可以在数秒内将工作恢复到原来的进度。此功能对应于 ACPI 状态
S3
。- 休眠(暂停到磁盘)
在此运行方式下,将整个系统状态写入硬盘并关闭系统电源。至少要有一个像 RAM 一样大的交换分区才能写入所有活动的数据。从该状态重激活大约需要 30 至 90 秒的时间。将恢复到暂停之前的状态。某些制造商提供这种方式的有用的混合变体(例如 IBM Thinkpad 中的 RediSafe)。对应的 ACPI 状态是
S4
。在 Linux 中,由独立于 ACPI 的内核例程执行暂挂到磁盘。注意:通过mkswap
进行格式化时更改了交换分区的 UUID如果可能,请不要使用
mkswap
重新设置现有交换分区的格式。使用mkswap
重新设置格式将会更改交换分区的 UUID 值。请通过 YaST 重新设置格式(如此将更新/etc/fstab
),或者手动调整/etc/fstab
。- 电池监视
ACPI 检查电池充电状态并提供相关信息。另外,当达到临界电量状态时,它将协调要执行的操作。
- 自动关闭电源
关闭后,将关闭计算机的电源。当在电池电量用完前立即执行自动关闭时,此功能特别重要。
- 处理器速度控制
在 CPU 方面,有三种方法可以节省电能:频率和电压调节(也称为 PowerNow! 或 Speedstep)、限制和使处理器进入休眠 (C-state)。根据计算机的运行方式,还可以将这三种方法结合起来使用。
26.2 高级配置和电源接口 (ACPI) #
ACPI 旨在支持操作系统设置和控制各个硬件组件。ACPI 取代即插即用电源管理 (PnP) 和高级电源管理 (APM)。它提供有关电池、AC 适配器、温度、风扇和系统事件(例如“合上机盖”或“电池电量低”)的信息。
BIOS 提供包含有关各个部件和硬件访问方法信息的表。操作系统使用这些信息执行指派中断或激活和停用部件等任务。因为操作系统执行 BIOS 中储存的命令,所以功能取决于 BIOS 实施。journald 中报告了 ACPI 能够检测并装载的表。有关查看日记日志消息的更多信息,请参见第 15 章 “journalctl
:查询 systemd
日记”。有关对 ACPI 问题进行故障诊断的详细信息,请参见第 26.2.2 节 “故障诊断”。
26.2.1 控制 CPU 性能 #
CPU 可以采用三种节能方法:
频率和电压调节
限制时钟频率 (T-state)
使处理器进入休眠 (C-state)
根据计算机的运行方式,还可以将这三种方法结合起来使用。省电还意味着系统温度不会升得过高并且激活风扇的频率会降低。
仅当处理器忙时,才需要进行频率调节和限制,这是因为当处理器处于空闲状态时总是会应用最经济的 C-state。如果 CPU 忙,则建议采用的省电方法是频率调节。处理器经常只在部分负载的状态下工作。在这种情况下,可以以较低的频率运行。通常,最佳方法是由内核按需调节器控制动态频率调节。
节流应作为最后没有办法时采用的方法,例如,虽然系统负载很高,但为延长电池工作时间而采用节流。但是,如果节流程度过高,某些系统将不会正常运行。此外,如果 CPU 处理的任务量很少,则 CPU 节流就没什么作用。
有关详细信息,请参见Book “System Analysis and Tuning Guide”, Chapter 11 “Power Management”。
26.2.2 故障诊断 #
问题有两种不同的类型。一种是内核的 ACPI 代码可能包含未及时检测出的错误。在这种情况下,可以通过下载获得解决方案。更多情况下,问题是由 BIOS 引起的。有时,会故意将一些不符合 ACPI 规范的配置集成在 BIOS 中,用于避免其他常用操作系统中 ACPI 实施的错误。在 ACPI 实施中有严重错误的硬件部件会被记录在一个黑名单中,防止 Linux 内核对这些部件使用 ACPI。
在遇到问题时,首先要做的是更新 BIOS。如果计算机未引导,使用以下引导参数之一可能会解决问题:
- pci=noacpi
不使用 ACPI 配置 PCI 设备。
- acpi=ht
只执行简单的资源配置。不要将 ACPI 用于其他目的。
- acpi=off
禁用 ACPI。
某些较新的计算机(特别是 SMP 系统和 AMD64 系统)需要 ACPI 以正确配置硬件。在这些计算机上,禁用 ACPI 可能会产生问题。
有时,计算机会对通过 USB 或 FireWire 挂接的硬件感到困惑。如果一台计算机拒绝引导,请拔下所有不需要的硬件,然后再次重试。
引导后,使用命令 dmesg -T
| grep -2i acpi
来监视系统的引导消息(或所有消息,因为问题也可能是 ACPI 以外的因素所导致)。如果在分析 ACPI 表时出错,则最重要的表 DSDT(区分系统描述表)可替换为改进的版本。在这种情况下,将忽略 BIOS 中有问题的 DSDT。第 26.4 节 “查错”中对这一过程进行了介绍。
在内核配置中,可以使用开关来激活 ACPI 调试消息。如果编译和安装的是带有 ACPI 调试功能的内核,则会显示详细信息。
如果遇到 BIOS 或硬件问题,则最好与制造商联系。特别是如果制造商不常对 Linux 提供支持,他们就应该面对这些问题。只有在制造商意识到有很多客户在使用 Linux 时,他们才会重视这一问题。
26.2.2.1 更多信息 #
http://tldp.org/HOWTO/ACPI-HOWTO/(详细的 ACPI HOWTO 文档,包含 DSDT 增补程序)
http://www.acpi.info(高级配置和电源接口规范)
http://acpi.sourceforge.net/dsdt/index.php(Bruno Ducrot 开发的 DSDT 增补程序)
26.3 硬盘的休眠 #
在 Linux 中,如果不使用硬盘,则可以使硬盘完全进入休眠状态,或者在更经济或更安静的方式下运行。在目前的便携式计算机上,您无需手动关闭硬盘,因为硬盘会在不运行时自动进入经济的运行方式。但是,如果要最大程度地节能,请使用 hdparm
命令测试以下某些方法。
它可用于修改各种磁盘设置。选项 -y
将硬盘立即切换到待机方式。-Y
会让硬盘进入休眠状态。hdparm
-S
X 会让硬盘闲置一段时间后减慢运行速度。使用以下值替换 X:0
表示禁用此机制,会使硬盘持续运行。值 1
到 240
表示的时间为所选的值乘以 5 秒。值 241
到 251
对应的时间分别是 30 分钟的 1 到 11 倍。
使用选项 -B
可以控制硬盘的内部省电选项。在 0
到 255
之间选择一个值,0 表示最大省电方式,255 表示最大吞吐量方式。结果取决于所使用的硬盘,难以估算。要让硬盘安静一些,请使用选项 -M
。在 128
到 254
之间选择一个值,128 表示最安静,254 表示速度最快。
通常,让硬盘进入休眠状态并不容易。在 Linux 中,大量的进程对硬盘执行写操作,因而会经常将其唤醒。因此,一定要了解 Linux 如何处理需要写入硬盘的数据。首先,在 RAM 中对所有数据进行缓冲。此缓冲区由 pdflush
守护程序监视。当数据达到一定的有效期限制或缓冲区已被填充到一定程度时,就会清理缓冲区,将其中的内容写入硬盘。缓冲区大小是动态的,取决于内存的大小和系统负载。默认情况下,将 pdflush 设置为较短的时间间隔可以获得最好的数据完整性。它会每 5 秒钟检查一次缓冲区并将数据写入硬盘。以下变量很有用:
/proc/sys/vm/dirty_writeback_centisecs
包含截至 pdflush 线程唤醒的延迟(以百分之一秒为单位)。
/proc/sys/vm/dirty_expire_centisecs
定义一个时间范围,最晚应在该时间之后写入未写入页。默认值是
3000
,表示 30 秒。/proc/sys/vm/dirty_background_ratio
pdflush 开始写入未写入页之前未写入页的最大百分比。默认值是
5
%。/proc/sys/vm/dirty_ratio
当未写入页超出总内存的此百分比后,将强制进程在其时间间隔期间写入未写入缓冲区,而不是继续写入。
更改为 pdflush
守护程序设置将损害数据完整性。
除了这些进程之外,Btrfs
、Ext3
、Ext4
等日记文件系统会独立于 pdflush
写入它们的元数据,这也会妨碍硬盘降速。为了避免这种情况,已为移动设备开发了特殊的内核扩展。要使用扩展,请安装 laptop-mode-tools
包;有关细节,请参见 /usr/src/linux/Documentation/laptops/laptop-mode.txt
。
另一个重要因素是活动程序的行为方式。例如,好的编辑器会定期将当前已修改文件的隐藏备份写入硬盘,而这会唤醒磁盘。可以禁用此类功能,但这会影响数据的完整性。
在此连接中,邮件守护程序 postfix 使用变量 POSTFIX_LAPTOP
。如果将此变量设为 yes
,则 postfix 访问硬盘的频率将显著降低。
在 SUSE Linux Enterprise Desktop 中,这些技术由 laptop-mode-tools
控制。
26.4 查错 #
所有错误讯息和警报都记录在系统日记中,您可使用 journalctl
命令来查询该日记(有关详细信息,请参见第 15 章 “journalctl
:查询 systemd
日记”)。以下几个部分介绍最常见的问题。
26.4.1 CPU 频率不工作 #
请参见内核源以确认是否支持您的处理器。您可能需要特殊内核模块或模块选项来激活 CPU 频率控制。如果安装了 kernel-source
包,则在 /usr/src/linux/Documentation/cpu-freq/*
中可找到此信息。
26.5 更多信息 #
http://en.opensuse.org/SDB:Suspend_to_RAM — 如何使“暂挂到 RAM”正常工作
http://old-en.opensuse.org/Pm-utils — 如何修改常规暂挂框架
27 VM Guest #
本章包含有关在虚拟机中使用 SUSE Linux Enterprise Desktop 的附加信息。
27.1 添加和去除 CPU #
某些虚拟化环境允许在运行虚拟机的同时添加或去除 CPU。
要安全去除 CPU,请先执行以下命令以停用这些 CPU
root #
echo 0 > /sys/devices/system/cpu/cpuX/online
请将 X 替换为 CPU 编号。要使 CPU 重新联机,请执行
root #
echo 1 > /sys/devices/system/cpu/cpuX/online
28 持久内存 #
本章包含有关使用配备非易失性主内存的 SUSE Linux Enterprise Desktop 的附加信息。此类内存称为持久内存,由一个或多个 NVDIMM 构成。
28.1 简介 #
持久内存是一种新型的计算机储存,其速度接近动态 RAM (DRAM),但同时具备 RAM 的按字节寻址能力以及固态硬盘 (SSD) 的性能。
与传统的 RAM 一样,持久内存直接安装在主板上的内存插槽中。因此,它的物理外形规格与 RAM 相同,以 DIMM 的形式提供。这些内存称为 NVDIMM:非易失性双列直插式内存模块。
不过,与 RAM 不同,持久内存在多个方面类似于基于闪存的 SSD。后两者采用固态内存电路的形式,但除此之外,两者都提供非易失性储存:系统断电或者重启动后,内存中的内容会得到保留。使用这两种媒体时,写入数据的速度比读取数据要慢;两者都支持有限的重新写入周期数。最后,与 SSD 一样,如果在特定的应用方案中更适合对持久内存进行扇区级别的访问,则也可以这样做。
不同的型号使用不同形式的电子储存媒体,例如 Intel 3D XPoint,或者将 NAND 闪存与 DRAM 结合使用。另外,行业正在开发新形式的非易失性 RAM。这意味着,不同的供应商和 NVDIMM 型号会提供不同的性能和持久性特征。
由于涉及的储存技术处于早期开发阶段,不同供应商的硬件可能会施加不同的限制。因此,以下叙述适用于一般性的场合。
持久内存的速度最多比 DRAM 要慢 10 倍,但比闪存要快大约 1000 倍。可在其中按字节重新写入数据,而不像在闪存中一样,需要擦除整个扇区,然后重新写入数据。最后,尽管重新写入周期数有限,但大部分形式的持久内存可以应对数百万次重新写入,相比之下,闪存只能应对数千个周期。
这会产生两种重要后果:
使用最新的技术无法运行仅包含持久内存的系统,因此无法实现完全非易失性的主内存。必须混合使用传统的 RAM 和 NVDIMM。操作系统和应用程序将在传统的 RAM 中执行,而 NVDIMM 可提供极速的补充性储存。
由于不同供应商的持久内存的性能特征不同,程序员可能需要考虑到特定服务器中 NVDIMM 的硬件规格,包括 NVDIMM 的数量,以及它们可以装入到哪些内存插槽。显然,这会对超级管理程序的使用、不同主机之间的软件迁移等造成影响。
ACPI 标准版本 6 中定义了此新型储存子系统。但是,libnvdimm
支持该标准颁布之前的 NVDIMM,可以相同的方式使用这些内存。
28.2 术语 #
- 地区
区域是持久内存中可划分为一个或多个名称空间的块。如果不事先将某个区域分配到名称空间,则您无法访问该区域的持久内存。
- 名称空间
非易失性储存的单个连续寻址范围,相当于 NVM Express SSD 的名称空间,或 SCSI 逻辑单元 (LUN)。名称空间作为单独的块设备显示在服务器的
/dev
目录中。根据所需的访问方法,名称空间可将多个 NVDIMM 中的储存合并成较大的卷,或者允许将这些储存分区成较小的卷。- 模式
每个名称空间还具有一种模式,该模式定义要为该名称空间启用哪些 NVDIMM 功能。同一父区域的同级名称空间始终具有相同的类型,但可将其配置为使用不同的模式。名称空间模式包括:
- devdax
设备 DAX 模式。创建单字符设备文件 (
/dev/daxX.Y
). 不需要创建文件系统。- fsdax
文件系统 DAX 模式。如果未指定其他模式,则使用默认值。创建块设备 (
/dev/pmemX [.Y]
),支持将 DAX 用于ext4
或XFS
。- 扇区
适用于不执行元数据校验和计算的传统文件系统。适用于小型引导卷。与其他操作系统兼容。
- raw
不包含卷标或元数据的内存磁盘。不支持 DAX。与其他操作系统兼容。
注意SUSE 不支持
raw
模式。无法在raw
名称空间中装入文件系统。
- 类型
每个名称空间和区域都有一种类型,该类型定义如何访问与该名称空间或区域关联的持久内存。名称空间的类型始终与其父区域的类型相同。有两种不同的类型:“持久内存”(可通过两种不同的方式进行配置),以及已弃用的“块模式”。
- 持久内存 (PMEM)
与 RAM 一样,PMEM 储存提供字节级别的访问。使用 PMEM 时,单个名称空间可以包含多个交错式的 NVDIMM,使这些 NVDIMM 都可用作单个设备。
可通过两种方式来配置 PMEM 名称空间。
- 将 PMEM 与 DAX 搭配使用
为 Direct Access (DAX) 配置 PMEM 名称空间后,访问内存时会绕过内核的页面超速缓存,并直接进入媒体。软件可以单独直接读取或写入该名称空间的每个字节。
- 将 PMEM 与 BTT 搭配使用
与在传统的磁盘驱动器中一样,将按扇区访问配置为以 BTT 模式运行的 PMEM 名称空间,而不是像在 RAM 中一样采用按字节寻址的模式。某个转换表机制会将访问活动批处理成扇区大小的单元。
BTT 的优点在于,储存子系统会确保将每个扇区完全写入到基础媒体,如果某项写入操作出于某种原因而失败,则会取消注册该操作。因此,无法在给定的扇区中进行部分写入。
此外,对 BTT 名称空间的访问会由内核超速缓存。
缺点在于,BTT 名称空间不支持 DAX。
- 块模式 (BLK)
块模式储存将每个 NVDIMM 作为独立的设备进行寻址。此模式已遭弃用,且不再受支持。
除
devdax
名称空间以外,其他所有类型也必须使用文件系统格式化,如同使用传统的驱动器一样。SUSE Linux Enterprise Desktop 支持将ext2
、ext4
和XFS
文件系统用于此目的。- Direct Access (DAX)
DAX 允许将持久内存直接映射成进程的地址空间(例如,使用
mmap
系统调用进行映射)。- DIMM 物理地址 (DPA)
在单个 DIMM 的内存中充当偏移量的内存地址;即,在该 DIMM 中充当最低可寻址字节的从零开始的地址。
- 标签
储存在 NVDIMM 中的元数据,例如名称空间定义。可以使用 DSM 访问这些数据。
- 设备特定的方法 (DSM)
用于访问 NVDIMM 中的固件的 ACPI 方法。
28.3 使用案例 #
28.3.1 将 PMEM 与 DAX 搭配使用 #
必须注意,这种形式的内存访问不是事务性的。如果发生断电或其他系统故障,数据可能不会完全写入到储存中。仅当应用程序可以处理部分写入数据的情况时,PMEM 储存才适用。
28.3.1.1 可受益于较大字节可寻址储存量的应用程序。 #
如果服务器托管的某个应用程序可按字节直接使用较大的快速储存量,则程序员可以使用 mmap
系统调用,将持久内存块直接放入该应用程序的地址空间,而无需使用任何附加的系统 RAM。
28.3.1.2 避免使用内核页面超速缓存 #
您可以节省用于页面超速缓存的 RAM,而不要将 RAM 分配给应用程序。例如,可以专门使用非易失性内存来保存虚拟机 (VM) 映像。由于这些映像不会超速缓存,因此可以减少主机上的超速缓存使用量,从而可在每台主机上配置更多的 VM。
28.3.2 将 PMEM 与 BTT 搭配使用 #
当您想要使用一组 NVDIMM 中的持久内存作为类似于磁盘的极速储存池时,此方法非常有用。
对于应用程序而言,此类设备仅显示为极速 SSD,并可像其他任何储存设备一样供您使用。例如,LVM 可以分布在持久内存的顶层,像平时一样正常工作。
BTT 的优点在于可以保证扇区写入的原子性,因此,即使是依赖于数据完整性的复杂应用程序也能保持正常工作。可通过标准的错误报告通道来运行媒体错误报告。
28.4 用于管理持久内存的工具 #
要管理持久内存,必须安装 ndctl
包。安装此包也会安装 libndctl
包,后者提供一组用户空间库用于配置 NVDIMM。
这些工具通过 libnvdimm
库运行。该库支持三种类型的 NVDIMM:
PMEM
BLK
同步 PMEM 和 BLK。
ndctl
实用程序提供一系列有用的手册
页。可使用以下命令访问这些页面:
ndctl help subcommand
要查看可用子命令的列表,请使用:
ndctl --list-cmds
可用的子命令包括:
- version
显示 NVDIMM 支持工具的当前版本。
- enable-namespace
使指定的名称空间可供使用。
- disable-namespace
阻止使用指定的名称空间。
- create-namespace
从指定的储存设备创建新的名称空间。
- destroy-namespace
去除指定的名称空间。
- enable-region
使指定的区域可供使用。
- disable-region
阻止使用指定的区域。
- zero-labels
擦除设备中的元数据。
- read-labels
检索指定设备的元数据。
- list
显示可用的设备。
- help
显示有关工具用法的信息。
28.5 设置持久内存 #
28.5.1 查看可用的 NVDIMM 储存 #
可以使用 ndctl
list
命令列出系统中所有可用的 NVDIMM。
在以下示例中,系统包含三个 NVDIMM,这些 NVDIMM 位于单个三通道交错集内。
root #
ndctl list --dimms
[ { "dev":"nmem2", "id":"8089-00-0000-12325476" }, { "dev":"nmem1", "id":"8089-00-0000-11325476" }, { "dev":"nmem0", "id":"8089-00-0000-10325476" } ]
如果结合不同的参数,ndctl
list
还可以列出可用的区域。
区域可能不会按数字顺序显示。
请注意,尽管只有三个 NVDIMM,但它们却显示为四个区域。
root #
ndctl list --regions
[ { "dev":"region1", "size":68182605824, "available_size":68182605824, "type":"blk" }, { "dev":"region3", "size":202937204736, "available_size":202937204736, "type":"pmem", "iset_id":5903239628671731251 }, { "dev":"region0", "size":68182605824, "available_size":68182605824, "type":"blk" }, { "dev":"region2", "size":68182605824, "available_size":68182605824, "type":"blk" } ]
空间以两种不同的形式显示:三个 BLK 类型的独立 64 GB 区域,或者一个 PMEM 类型的合并 189 GB 区域,后者将三个交错式 NVDIMM 中的所有空间表示为单个卷。
请注意,available_size
的显示值与 size
的显示值相同。这意味着尚未分配任何空间。
28.5.2 将储存配置为使用 DAX 的单个 PMEM 名称空间 #
第一个示例将三个 NVDIMM 配置成使用 Direct Access (DAX) 的单个 PMEM 名称空间。
第一个步骤是创建新的名称空间。
root #
ndctl create-namespace --type=pmem --mode=fsdax --map=memory
{ "dev":"namespace3.0", "mode":"memory", "size":199764213760, "uuid":"dc8ebb84-c564-4248-9e8d-e18543c39b69", "blockdev":"pmem3" }
这会创建支持 DAX 的块设备 /dev/pmem3
。设备名称中的 3
继承自父区域编号(在本例中为 region3
)。
--map=memory
选项从 NVDIMM 中设置出一部分 PMEM 储存空间,以便可以使用这些空间来分配称作结构页面
的内部内核数据结构。这样,便可以将新的 PMEM 名称空间与 O_DIRECT I/O
和 RDMA
等功能搭配使用。
最终 PMEM 名称空间的容量之所以小于父 PMEM 区域,是因为有一部分持久内存预留给了内核数据结构。
接下来,我们校验新的块设备是否可用于操作系统:
root #
fdisk -l /dev/pmem3
Disk /dev/pmem3: 186 GiB, 199764213760 bytes, 390164480 sectors Units: sectors of 1 * 512 = 512 bytes Sector size (logical/physical): 512 bytes / 4096 bytes I/O size (minimum/optimal): 4096 bytes / 4096 bytes
与其他任何驱动器一样,在使用该设备之前,必须先将其格式化。在本示例中,我们使用 XFS 将其格式化:
root #
mkfs.xfs /dev/pmem3
meta-data=/dev/pmem3 isize=256 agcount=4, agsize=12192640 blks = sectsz=4096 attr=2, projid32bit=1 = crc=0 finobt=0, sparse=0 data = bsize=4096 blocks=48770560, imaxpct=25 = sunit=0 swidth=0 blks naming =version 2 bsize=4096 ascii-ci=0 ftype=1 log =internal log bsize=4096 blocks=23813, version=2 = sectsz=4096 sunit=1 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0
接下来,可将新的驱动器装入到某个目录:
root #
mount -o dax /dev/pmem3 /mnt/pmem3
然后,可以校验是否获得了一个支持 DAX 的设备:
root #
mount | grep dax
/dev/pmem3 on /mnt/pmem3 type xfs (rw,relatime,attr2,dax,inode64,noquota)
结果是,我们已获得一个使用 XFS 文件系统格式化的,且装有 DAX 的 PMEM 名称空间。
对该文件系统中的文件进行任何 mmap()
调用都会返回直接映射到 NVDIMM 上的持久内存的虚拟地址,并且会完全绕过页面超速缓存。
对该文件系统中的文件进行任何 fsync
或·msync
调用仍可确保将修改后的数据完全写入到 NVDIMM。这些调用会刷新通过 mmap
映射在用户空间中修改的任何页面的关联处理器超速缓存行。
28.5.2.1 去除名称空间 #
在创建使用相同储存的其他任何类型的卷之前,我们必须卸载此 PMEM 卷,然后将其去除。
首先卸载该卷:
root #
umount /mnt/pmem3
然后禁用名称空间:
root #
ndctl disable-namespace namespace3.0
disabled 1 namespace
然后删除该卷:
root #
ndctl destroy-namespace namespace3.0
destroyed 1 namespace
28.5.3 创建使用 BTT 的 PMEM 名称空间 #
在下一个示例中,我们将创建使用 BTT 的 PMEM 名称空间。
root #
ndctl create-namespace --type=pmem --mode=sector
{ "dev":"namespace3.0", "mode":"sector", "uuid":"51ab652d-7f20-44ea-b51d-5670454f8b9b", "sector_size":4096, "blockdev":"pmem3s" }
接下来,校验新设备是否存在:
root #
fdisk -l /dev/pmem3s
Disk /dev/pmem3s: 188.8 GiB, 202738135040 bytes, 49496615 sectors Units: sectors of 1 * 4096 = 4096 bytes Sector size (logical/physical): 4096 bytes / 4096 bytes I/O size (minimum/optimal): 4096 bytes / 4096 bytes
与前面配置的支持 DAX 的 PMEM 名称空间一样,这个支持 BTT 的 PMEM 名称空间也会占用 NVDIMM 中的所有可用储存。
设备名称 (/dev/pmem3s
) 中的尾部 s
表示扇区
(sector),可用于轻松辨别配置为使用 BTT 的名称空间。
可按前一示例中所述格式化和装入卷。
此处显示的 PMEM 名称空间不能使用 DAX。它会使用 BTT 来提供扇区写入原子性。每次通过 PMEM 块驱动程序进行扇区写入时,BTT 都会分配一个新的扇区来接收新数据。完全写入新数据后,BTT 将以原子方式更新其内部映射结构,使新写入的数据可供应用程序使用。如果在此过程中的任意时间点发生电源故障,则写入内容将会完全丢失,在这种情况下,应用程序可以访问其旧数据,而这些数据仍旧保持不变。这可以防止出现所谓“扇区撕裂”的情况。
与其他任何标准块设备一样,可以使用某个文件系统格式化这个支持 BTT 的 PMEM 名称空间,并在该文件系统中使用它。无法将该名称空间与 DAX 搭配使用。但是,此块设备中的文件的 mmap
映射将使用页面超速缓存。
28.6 更多信息 #
可以在以下列表中找到关于此主题的更多信息:
包含有关配置 NVDIMM 系统的指导、有关测试的信息,以及有关启用 NVDIMM 的规范的链接。随着 Linux 中 NVDIMM 支持功能的不断发展,此站点的内容也会不断扩充。
有关在 Linux 和其他操作系统中配置、使用非易失性内存,以及为使用此类内存的系统编程的信息。其中介绍了 NVM 库 (NVML)。该库旨在提供有用的 API 用于在用户空间中进行持久内存编程。
此文档面向内核开发人员,包含在当前 Linux 内核树的“文档”文件夹中。其中探讨了涉及启用 NVDIMM 的不同内核模块,列出了有关内核实现的一些技术细节,并介绍了
ndctl
工具使用的sysfs
内核接口。用于管理 Linux 内核中的
libnvdimm
子系统的实用程序库。另外还包含用户空间库,以及单元测试和文档。
第 IV 部分 服务 #
- 29 使用 NTP 同步时间
NTP(网络时间协议)机制是用于同步网络上的系统时间的协议。首先,计算机从作为可靠时间源的服务器获得时间。然后将此计算机用作网络中其他计算机的时间源。这样做有双重目的,既可维护绝对时间,又可保持网络中所有计算机系统时间的同步。
- 30 通过 NFS 共享文件系统
网络文件系统 (NFS) 是允许访问服务器上的文件的协议,访问方式与访问本地文件非常相似。
- 31 Samba
使用 Samba 可以将 Unix 计算机配置为 macOS、Windows 和 OS/2 计算机的文件和打印服务器。Samba 已经发展成为一个功能完备且相当复杂的产品。使用 YaST 或手动编辑配置文件来配置 Samba。
- 32 使用 Autofs 按需装入
autofs
是一个可根据需要自动装入指定目录的程序。它基于一个内核模块运行以实现高效率,并且可以同时管理本地目录和网络共享。这些自动安装点仅会在被访问时装入,一定时间内不活动后即会被卸载。这种按需行为可节省带宽,并实现比/etc/fstab
管理的静态装入更高的性能。虽然autofs
是控制脚本,但automount
才是实际执行自动装入的命令(守护程序)。
29 使用 NTP 同步时间 #
NTP(网络时间协议)机制是用于同步网络上的系统时间的协议。首先,计算机从作为可靠时间源的服务器获得时间。然后将此计算机用作网络中其他计算机的时间源。这样做有双重目的,既可维护绝对时间,又可保持网络中所有计算机系统时间的同步。
维护确切的系统时间在许多情况下都非常重要。内置硬件时钟往往不能满足数据库或群集这样的应用程序的要求。手动更正系统时间可能会导致许多严重问题,例如向后调整时间将使关键应用程序出现故障。在网络中,通常需要同步所有计算机上的系统时间,但是手动调整时间是一种不好的方法。NTP 提供了解决这些问题的机制。NTP 服务通过网络中的可靠时间服务器持续调整系统时间。它还支持对本地参考时钟(如无线电控制的时钟)进行管理。
自 SUSE Linux Enterprise Desktop 15 起,采用 chrony
作为 NTP 的默认实施。chrony
包含两个部分:chronyd
守护程序可在引导时启动,chronyc
命令行界面程序用于监视 chronyd
的性能,以及在运行时更改各种操作参数。
要通过 Active Directory 启用时间同步,请遵循Book “Security and Hardening Guide”, Chapter 7 “Active Directory Support”, Section 7.3.3 “Joining Active Directory Using 中的描述。 ”, Joining an Active Directory Domain Using
29.1 使用 YaST 配置 NTP 客户端 #
chrony
包中附带的 NTP 守护程序 (chronyd
) 预先设置为使用本地计算机硬件时钟作为时间参考。硬件时钟的精确度极大程度上取决于它的时间源。例如,原子时钟或 GPS 接收器是非常精确的时间源,而一般 RTC 芯片则不是可靠的时间源。YaST 简化了 NTP 客户端的配置。
在 YaST NTP 客户端配置(
› )窗口中,您可以指定启动 NTP 守护程序的时间、配置源的类型,以及添加自定义的时间服务器。29.1.1 NTP 守护程序启动 #
您可以从下面三个选项中选择启动 NTP 守护程序的时间:
如果您想手动启动
chrony
守护程序,请选择 。选择
可定期设置系统时间,而不用永久运行chrony
。您可以设置 。选择
可在引导系统时自动启动chronyd
。建议使用此设置。
29.1.2 配置源的类型 #
在
下拉框中,选择 或 。如果服务器只使用固定的一组(公共)NTP 服务器,请设置 ;如果您的内部网络通过 DHCP 提供 NTP 服务器,则使用 更合适。29.1.3 配置时间服务器 #
供客户端查询的时间服务器列在
窗口的下半部分。使用 、 和 可按需修改此列表。单击
可添加新的时间服务器:在
字段中,键入要与计算机时间同步的时间服务器或时间服务器池的 URL。填写好 URL 后,单击 以校验该 URL 是否指向有效的时间源。激活
,以便在chronyd
守护程序启动时通过发送更多请求来加速时间同步。激活
,以使自动启动chronyd
守护程序且引导时可能没有因特网连接的系统加快引导速度。例如,对于网络连接受 NetworkManager 管理的笔记本电脑,此选项非常实用。单击
进行确认。
29.2 手动配置网络中的 NTP #
chrony
从 /etc/chrony.conf
文件读取其配置。要让计算机时钟保持同步,您需要告诉 chrony
使用什么时间服务器。您可以使用特定的服务器名称或 IP 地址,例如:
server 0.europe.pool.ntp.org server 1.europe.pool.ntp.org server 2.europe.pool.ntp.org
还可以指定池名称。池名称会解析为若干个 IP 地址:
pool pool.ntp.org
要同步同一网络中的多台计算机的时间,建议不要通过一台外部服务器同步所有计算机。比较好的做法是将其中一台计算机作为时间服务器(它与外部时间服务器同步),其他计算机作为它的客户端。将 local
指令添加至服务器的 /etc/chrony.conf
,以将其与权威时间服务器区分开:
local stratum 10
要启动 chrony
,请运行:
systemctl start chronyd.service
初始化 chronyd
后,系统需要花费一些时间来稳定时间,以及创建用于纠正本地计算机时钟的偏移文件。利用偏移文件,当计算机启动时,可以计算出硬件时钟的系统误差。可以立即使用更正功能,使系统时间保持较高的稳定性。
要启用 chrony
以便该服务在引导时自动启动,请运行:
systemctl enable chronyd.service
29.3 在运行时使用 chronyc
配置 chronyd
#
在运行时,您可以使用 chronyc
来更改 chronyd
的行为。它会生成有关 chronyd
的操作的状态报告。
您可以采用交互模式或非交互模式运行 chronyc
。要采用交互模式运行 chronyc
,请在命令行上输入 chronyc
。如此会显示提示符并等待您输入命令。例如,要检查有多少个 NTP 源联机或脱机,请运行:
root #
chronyc
chronyc> activity 200 OK 4 sources online 2 sources offline 1 sources doing burst (return to online) 1 sources doing burst (return to offline) 0 sources with unknown address
要退出 chronyc
的提示符,请输入 quit
或 exit
。
如果您不需要使用交互提示符,请直接输入命令:
root #
chronyc
activity
使用 chronyc
进行的更改不是永久性的。当 chronyd
下次重启动时,它们将会丢失。要进行永久更改,请修改 /etc/chrony.conf
。
有关 chronyc
命令的完整列表,请参见它的手册页 (man 1 chronyc
)。
29.4 运行时动态时间同步 #
如果在无网络连接的情况下引导系统,chronyd
会启动,但它无法解析配置文件中所设置的时间服务器的 DNS 名称。在加密的 Wi-Fi 中使用 NetworkManager 时,可能会发生这种情况。
chronyd
会按递增的时间间隔不断尝试解析由 server
、pool
和 peer
指令指定的时间服务器名称,直到成功为止。
如果启动 chronyd
时将无法访问时间服务器,您可以指定 offline
选项:
server server_address offline
如此,chronyd
将不会尝试轮询服务器,除非使用以下命令启用它:
root #
chronyc online server_address
如果设置了 auto_offline
选项,在向时间服务器发送了两个请求,但未接收到任何响应时,chronyd
会假设时间服务器已脱机。此选项使 chronyc
在网络链路断开时,无需运行“脱机”命令。
29.5 设置本地参考时钟 #
软件包 chrony
依赖于其他程序(例如 gpsd
)来通过 SHM 或 SOCK 驱动程序访问计时数据。在 /etc/chrony.conf
中使用 refclock
指令可指定要用作时间源的硬件参考时钟。它有两个必填参数:驱动程序名称和驱动程序特定的参数。这两个参数后面跟着零个或多个 refclock
选项。chronyd
包含以下驱动程序:
PPS:内核“pulse per second”API 的驱动程序。例如:
refclock PPS /dev/pps0 lock NMEA refid GPS
SHM:NTP 共享内存驱动程序。例如:
refclock SHM 0 poll 3 refid GPS1 refclock SHM 1:perm=0644 refid GPS2
SOCK:Unix 域套接字驱动程序。例如:
refclock SOCK /var/run/chrony.ttyS0.sock
PHC:PTP 硬件时钟驱动程序。例如:
refclock PHC /dev/ptp0 poll 0 dpoll -2 offset -37 refclock PHC /dev/ptp1:nocrossts poll 3 pps
有关各个驱动程序的选项的详细信息,请参见 man 8 chrony.conf
。
29.6 与外部时间参考 (ETR) 的时钟同步 #
支持与外部时间参考 (ETR) 时钟同步。外部时间参照每 2**20(2 的 20 次幂)微秒发出一次振荡器信号和同步信号,以将连接的所有服务器的 TOD 时钟保持同步。
两个 ETR 计算机可以连接到一台计算机。如果时钟偏差超过同步检查容差,将会对所有 CPU 执行一次计算机检查,这表示时钟未同步。如果发生这种情况,在该时钟再次同步前,所有与支持 XRC 的设备进行的 DASD I/O 都将停止。
可通过两个 sysfs
属性激活 ETR 支持;请以 root
身份运行以下命令:
echo 1 > /sys/devices/system/etr/etr0/online echo 1 > /sys/devices/system/etr/etr1/online
30 通过 NFS 共享文件系统 #
网络文件系统 (NFS) 是允许访问服务器上的文件的协议,访问方式与访问本地文件非常相似。
30.1 概述 #
网络文件系统 (NFS) 是久经考验且广泛支持的标准化网络协议,它允许在单独的主机之间共享文件。
网络信息服务 (NIS) 可用于在网络中进行集中式用户管理。将 NFS 和 NIS 结合使用可通过文件和目录权限在网络中进行访问控制。NFS 与 NIS 一起使用时网络面向用户是透明的。
在默认配置中,NFS 完全信任网络,因此会信任连接到可信网络的任何计算机。在可通过物理方式访问 NFS 服务器所信任的任何网络的任何计算机上,任何具有管理员特权的用户都可以访问该服务器提供的所有文件。
一般而言,此安全性级别非常适于以下情形:所信任的网络是真正的专用网络,通常局限于单个计算机机柜或机房,并且无法进行未经授权的访问。将整个子网作为一个整体信任的其他情形限制较多,需要更精密的信任机制。为了满足这些情形的需要,NFS 使用 Kerberos 基础架构来支持各种安全性级别。Kerberos 需要 NFSv4(默认使用该协议)。有关细节,请参见Book “Security and Hardening Guide”, Chapter 6 “Network Authentication with Kerberos”。
下面是 YaST 模块中使用的术语。
- 导出
由 NFS 服务器导出的目录,客户端可将其集成到系统中。
- NFS 客户端
NFS 客户端是通过网络文件系统协议使用来自 NFS 服务器的 NFS 服务的系统。TCP/IP 协议已集成到 Linux 内核中;无需再安装任何其他软件。
- NFS 服务器
NFS 服务器向客户端提供 NFS 服务。运行中的服务器依赖于以下守护程序:
nfsd
(worker)、idmapd
(用于 NFSv4 的 ID 到名称映射,仅在某些场景下需要)、statd
(文件锁定)和mountd
(装入请求)。- NFSv3
NFSv3 是版本 3 实施,支持客户端身份验证的“旧版”无状态 NFS。
- NFSv4
NFSv4 是新的版本 4 实施,支持通过 kerberos 进行安全用户身份验证。NFSv4 只需要一个端口,因此,它比 NFSv3 更适合用于防火墙后的环境。
- pNFS
并行 NFS,属于 NFSv4 的一种协议扩展。任何 pNFS 客户端都可以直接访问 NFS 服务器上的数据。
30.2 安装 NFS 服务器 #
要安装和配置 NFS 服务器,请参见相应的 SUSE Linux Enterprise Server 文档。
30.3 配置客户端 #
要将主机配置为 NFS 客户端,无需安装其他软件。将默认安装所有需要的包。
30.3.1 使用 Yast 导入文件系统 #
授权用户可以用 YaST NFS 客户端模块从 NFS 服务器将 NFS 目录装入本地文件树。按如下所示继续:
启动 YaST NFS 客户端模块。
单击
选项卡中的 。输入 NFS 服务器的主机名、要导入的目录以及要在本地的哪个装入点装入此目录。使用 NFSv4 时,在
选项卡中选择 。另外, 必须包含 NFSv4 服务器所用的相同值。默认域为localdomain
。要对 NFS 使用 Kerberos 身份验证,必须启用 GSS 安全性。选择
。若要使用防火墙并允许从远程计算机访问服务,请启用
选项卡中的 。防火墙状态将显示在复选框旁边。单击
保存更改。
配置写入/etc/fstab
,并将装入指定的文件系统。当您稍后启动 YaST 配置客户端时,它还将读取此文件中的现有配置。
在通过网络以 NFS 共享形式装入根分区的(无磁盘)系统中,配置可用来访问 NFS 共享的网络设备时需特别小心。
关闭或重引导系统时,默认的处理顺序是关闭网络连接,然后卸载根分区。对于 NFS 根分区,这种顺序会产生问题,因为在尚未激活与 NFS 共享的网络连接的情况下,根分区无法完全卸载。为防止系统停用相关的网络设备,请按第 17.4.1.2.5 节 “激活网络设备”中所述打开网络设备配置选项卡,然后在 窗格中选择 。
30.3.2 手动导入文件系统 #
手动从 NFS 服务器导入文件系统的先决条件是运行 RPC 端口映射器。nfs
服务负责正确启动该程序;因此,请以 root
身份输入 systemctl start nfs
来启动该服务。然后就可以使用 mount
将远程文件系统像本地分区那样装入文件系统中:
tux >
sudo
mount HOST:REMOTE-PATHLOCAL-PATH
例如,要从 nfs.example.com
计算机导入用户目录,请使用:
tux >
sudo
mount nfs.example.com:/home /home
30.3.2.1 使用自动装入服务 #
autofs 守护程序可用于自动装入远程文件系统。请在 /etc/auto.master
文件中添加以下条目:
/nfsmounts /etc/auto.nfs
如果 auto.nfs
文件正确填充,/nfsmounts
目录将作为客户端上所有 NFS 装入的 root 目录。选择 auto.nfs
这个名称是为了方便起见,您可以选择任何名称。在 auto.nfs
中为所有 NFS 装入添加条目,如下所示:
localdata -fstype=nfs server1:/data nfs4mount -fstype=nfs4 server2:/
以 root
身份运行 systemctl start autofs
来激活该设置。对于此示例,/nfsmounts/localdata
,server1
的 /data
目录将通过 NFS 装入,server2
的 /nfsmounts/nfs4mount
将通过 NFSv4 装入。
如果在 autofs 服务正在运行时编辑了 /etc/auto.master
文件,则必须使用 systemctl restart autofs
重启动自动装载器才能使更改生效。
30.3.2.2 手动编辑 /etc/fstab
#
通常,/etc/fstab
中的 NFSv3 装入项如下:
nfs.example.com:/data /local/path nfs rw,noauto 0 0
对于 NFSv4 装入,请在第三列中使用 nfs4
而不是 nfs
:
nfs.example.com:/data /local/pathv4 nfs4 rw,noauto 0 0
noauto
选项可禁止在启动时自动装入文件系统。如果您要手动安装各文件系统,可以缩短只指定安装点的安装命令:
tux >
sudo
mount /local/path
如果您没有输入 noauto
选项,系统的 init 脚本将在启动时处理这些文件系统的装入。
30.3.3 并行 NFS (pNFS) #
NFS 是最老的协议之一,开发于上世纪八十年代。因此,如果您要共享小文件,NFS 通常能够满足需求。但是,当您要传送大文件或有大量的客户端要访问数据时,NFS 服务器会成为瓶颈,严重影响系统性能。这是因为文件迅速变大,而以太网的相对速度没有完全跟上这一变化。
当您向普通 NFS 服务器请求文件时,服务器会查找文件元数据、收集所有数据并通过网络将数据传送到您的客户端。但是,无论文件的大小如何,性能瓶颈都会凸显出来:
如果是小文件,则大部分时间都花在收集元数据上。
如果是大文件,则大部分时间花在将数据从服务器传送到客户端上。
pNFS 或并行 NFS 则突破了此种限制,因为它将文件系统元数据从数据位置分离出来。因此,pNFS 需要两类服务器:
一个元数据或控制服务器,用于处理所有非数据通讯
一个或多个储存服务器,用于存放数据
元数据和储存服务器组成单独一个逻辑 NFS 服务器。当客户端要读取或写入时,元数据服务器会告诉 NFSv4 客户端使用哪个储存服务器访问文件块。客户端可以直接访问该服务器上的数据。
SUSE Linux Enterprise Desktop 仅在客户端上支持 pNFS。
30.3.3.1 使用 YaST 配置 pNFS 客户端 #
请执行过程 30.1 “导入 NFS 目录”中所述的步骤,但选中 复选框以及可选的 。YaST 会执行所有必需的步骤,并且会在文件 /etc/exports
中写入所有必要选项。
30.3.3.2 手动配置 pNFS 客户端 #
请参阅第 30.3.2 节 “手动导入文件系统”着手配置。大多数配置通过 NFSv4 服务器完成。对于 pNFS,唯一的区别是将 minorversion
选项和元数据服务器 MDS_服务器添加到您的 mount
命令:
tux >
sudo
mount -t nfs4 -o minorversion=1 MDS_SERVER MOUNTPOINT
为方便调试,请更改 /proc
文件系统中的值:
tux >
sudo
echo 32767 > /proc/sys/sunrpc/nfsd_debugtux >
sudo
echo 32767 > /proc/sys/sunrpc/nfs_debug
30.4 更多信息 #
除了 exports
、nfs
和 mount
的手册页外,还可在 /usr/share/doc/packages/nfsidmap/README
中找到关于配置 NFS 服务器和客户端的信息。有关更多联机文档,请参见以下网站:
在 SourceForge 上联机查找详细的技术文档。
关于设置采用 Kerberos 的 NFS 的描述,请参见 NFS Version 4 Open Source Reference Implementation。
如果您对 NFSv4 有疑问,请参考 Linux NFSv4 FAQ(Linux NFSv4 常见问题)。
31 Samba #
使用 Samba 可以将 Unix 计算机配置为 macOS、Windows 和 OS/2 计算机的文件和打印服务器。Samba 已经发展成为一个功能完备且相当复杂的产品。使用 YaST 或手动编辑配置文件来配置 Samba。
31.1 术语 #
以下是 Samba 文档和 YaST 模块中使用的一些术语。
- SMB 协议
Samba 使用基于 NetBIOS 服务的 SMB(服务器讯息块)协议。Microsoft 发布该协议以便其他软件制造商能够与 Microsoft 域网络建立连接。使用 Samba 时,SMB 协议在 TCP/IP 协议之上工作,所以必须在所有客户端上安装 TCP/IP 协议。
- CIFS 协议
CIFS(常用因特网文件系统)协议是 Samba 支持的另一种协议。CIFS 定义网络中使用的标准远程文件系统访问协议,使用户组能够一起工作并在网络中共享文档。
- NetBIOS
NetBIOS 是为用于提供名称服务的计算机之间进行通讯而设计的软件接口 (API)。它使连接到网络的计算机能够为自己保留名称。之后便可以根据名称对这些计算机进行寻址。没有任何中心进程来检查这些名称。网络上的任何计算机均可以保留所需数量的名称,前提是这些名称均未使用。可以为不同的网络体系结构实施 NetBIOS 接口。NetBEUI 是与网络硬件结合相对密切的一种实施,但它常被称为 NetBIOS。使用 NetBIOS 实施的网络协议包括 Novell 的 IPX(通过 TCP/IP 的 NetBIOS)和 TCP/IP。
通过 TCP/IP 发送的 NetBIOS 名称与
/etc/hosts
中使用的名称或 DNS 定义的名称没有相同之处。NetBIOS 使用它自己的、完全独立的命名约定。但为了方便管理,建议您使用与 DNS 主机名对应的名称,或本机使用 DNS。Samba 默认采用这种方式。- Samba 服务器
Samba 服务器向客户端提供 SMB/CIFS 服务和 NetBIOS over IP 命名服务。对于 Linux,Samba 服务器有三个守护程序:smbd 用于 SMB/CIFS 服务,nmbd 用于命名服务,winbind 用于身份验证。
- Samba 客户端
Samba 客户端是一种能够通过 SMB 协议从 Samba 服务器使用 Samba 服务的系统。常见操作系统(例如 Windows 和 macOS)都支持 SMB 协议。必须在所有计算机上安装 TCP/IP 协议。Samba 提供适用于多种不同类型 UNIX 的客户端。对于 Linux,有一个用于 SMB 的内核模块,它允许在 Linux 系统级别上集成 SMB 资源。不需要对 Samba 客户端运行任何守护程序。
- 共享
SMB 服务器通过共享为其客户端提供资源。共享就是服务器上的打印机和目录及其子目录。可以通过名称来导出并访问共享。可以将共享名称设置为任何名称 — 不一定是导出目录的名称。也可以为打印机指派一个名称。客户端可通过打印机的名称访问打印机。
- DC
域控制器 (DC) 是处理域中帐户的服务器。为了复制数据,一个域中可有更多域控制器可用。
31.2 安装 Samba 服务器 #
在 SUSE Linux Enterprise Desktop 上无法安装 Samba 服务器。有关安装和配置 Samba 服务器的信息,请参见《SUSE Linux Enterprise Server 管理指南》。
31.3 配置客户端 #
客户端只能通过 TCP/IP 访问 Samba 服务器。NetBEUI 和通过 IPX 的 NetBIOS 不能与 Samba 共用。
31.3.1 使用 YaST 配置 Samba 客户端 #
配置 Samba 客户端来访问 Samba 或 Windows 服务器上的资源(文件或打印机)。在
› 对话框中输入 NT 或 Active Directory 域或工作组。如果激活 ,则用户身份验证将在 Samba、NT 或 Kerberos 服务器上运行。
单击pam_mount
手册页。
完成所有设置后,请确认对话框以完成配置。
31.3.2 在客户端上装入 SMB1 共享 #
第一个 SMB 网络协议版本 SMB1 是一个不安全的早期协议,现已由其创始者 Microsoft 弃用。出于安全原因,SUSE Linux Enterprise Desktop
上的 mount 命令默认只会使用较新的协议版本(即 SMB 2.1、SMB 3.0 或 SMB 3.02)装入 SMB 共享。
但是,此项更改只会影响通过 /etc/fstab
执行的 mount
命令和装入操作。使用以下工具时,默认情况下 SMB1 仍然可用:
smbclient
工具。SUSE Linux Enterprise Server 随附的 Samba 服务器软件。
在以下设置中,由于只能使用 SMB1,此项默认设置会导致连接失败:
使用不支持较新 SMB 协议版本的 SMB 服务器的设置。自 Windows 7 和 Windows Server 2008 开始,Windows 已推出 SMB 2.1 支持。
依赖于 SMB1/CIFS 的 Unix 扩展的设置。这些扩展尚未移植到更高的协议版本。
遵循以下指导可以解决安全问题。有关这些问题的详细信息,请参见 https://blogs.technet.microsoft.com/filecab/2016/09/16/stop-using-smb1/。
尽快升级服务器以使用更安全的 SMB 版本。
如果您需要在当前的 SUSE Linux Enterprise Desktop 内核中启用 SMB1 共享,请将选项 vers=1.0
添加到所用的 mount
命令行中:
root #
mount –t smbfs IP_ADDRESS:/SHARE /MOUNT_POINT –o username=USER_ID,workgroup=WORKGROUP_NAME,vers=1.0
31.4 将 Samba 用作登录服务器 #
在企业设置中,组织通常希望只允许已在中心实例上注册的用户进行访问。在基于 Windows 的网络中,此任务由主域控制器 (PDC) 来处理。您可以使用配置为 PDC 的 Windows NT 服务器,但是此任务也可以借助 Samba 服务器来完成。例 31.1 “smb.conf 中的 global 部分”中显示了必须在 smb.conf
的 [global]
部分设置的项。
[global] workgroup = WORKGROUP domain logons = Yes domain master = Yes
需要准备适合 Windows 加密格式的用户帐户和口令。使用命令 smbpasswd
-a name
可完成此任务。使用以下命令为计算机创建 Windows 域概念要求的域帐户:
useradd hostname smbpasswd -a -m hostname
使用 useradd
命令可添加一个美元符号。命令 smbpasswd
在使用参数 -m
时自动插入此符号。带注释的配置示例 (/usr/share/doc/packages/samba/examples/smb.conf.SUSE
) 包含自动执行此任务的设置。
add machine script = /usr/sbin/useradd -g nogroup -c "NT Machine Account" \ -s /bin/false %m
要确保 Samba 能够正确执行此脚本,请选择具有必需的管理员权限的 Samba 用户,并将其添加到 ntadmin
组中。然后可以使用以下命令为属于此 Linux 组的所有用户指派 Domain Admin
状态:
net groupmap add ntgroup="Domain Admins" unixgroup=ntadmin
31.5 高级主题 #
本节介绍用于管理 Samba 套件中客户端部分与服务器部分的高级方法。
31.5.1 Btrfs 上的透明文件压缩 #
Samba 允许客户端针对 Btrfs 文件系统中的共享远程操作文件与目录压缩标志。Windows 资源管理器可让用户通过
› › 对话框来标记要进行透明压缩的文件/目录:带有压缩标志的文件将以透明方式进行压缩,当用户访问或修改这些文件时,底层文件系统会将其解压缩。这通常可以节省储存容量,不过,在访问文件时会造成额外的 CPU 开销。除非新文件和目录是使用 FILE_NO_COMPRESSION 选项创建的,否则,它们将继承父目录的压缩标志。
Windows 资源管理器以不同的显示方式区分压缩文件和未压缩文件:
要启用 Samba 共享压缩,您可以将以下内容
vfs objects = btrfs
手动添加到 /etc/samba/smb.conf
中的共享配置,或者使用 YaST: › › ,然后选中 。
31.5.2 快照 #
快照也称为阴影副本,是指某个文件系统子卷在特定时间点的状态副本。在 Linux 中,可以使用 Snapper 工具来管理这些快照。Btrfs 文件系统或精简配置的 LVM 卷支持快照。Samba 套件支持通过服务器端和客户端的 FSRVP 协议管理远程快照。
31.5.2.1 先前版本 #
Samba 服务器上的快照可以作为文件或目录的先前版本公开给远程 Windows 客户端。
要在 Samba 服务器上启用快照,必须符合以下条件:
SMB 网络共享位于 Btrfs 子卷上。
SMB 网络共享路径中包含相关的 snapper 配置文件。可以使用以下命令创建 snapper 文件
tux >
sudo
snapper -c <cfg_name> create-config/path/to/share
有关 snapper 的更多信息,请参见第 7 章 “通过 Snapper 进行系统恢复和快照管理”。
必须允许相关用户访问快照目录树。有关更多信息,请参见 vfs_snapper 手册页 (
man 8 vfs_snapper
) 的 PERMISSIONS(权限)部分。
要支持远程快照,需要修改 /etc/samba/smb.conf
文件。要完成此操作,您可以选择 › › ,或者使用以下命令手动增强相关的共享部分
vfs objects = snapper
请注意,只有在重启动 Samba 服务后,对 smb.conf
所做的手动更改才能生效:
tux >
sudo
systemctl restart nmb smb
经过配置后,可以通过 Windows 资源管理器中某个文件或目录的
选项卡访问 snapper 为 Samba 共享路径创建的快照。31.5.2.2 远程共享快照 #
默认情况下,只能在 Samba 服务器本地通过 snapper 命令行实用程序或者使用 snapper 时间轴功能来创建和删除快照。
可将 Samba 配置为使用文件服务器远程 VSS 协议 (FSRVP) 处理远程主机发出的共享快照创建和删除请求。
除了第 31.5.2.1 节 “先前版本”中所述的配置和先决条件以外,还需要在 /etc/samba/smb.conf
中指定以下全局配置:
[global] rpc_daemon:fssd = fork registry shares = yes include = registry
然后,FSRVP 客户端(包括 Samba 的 rpcclient
以及 Windows Server 2012 DiskShadow.exe
)便可以指示 Samba 为指定的共享创建或删除快照,并将该快照公开为新共享。
31.5.2.3 使用 rpcclient
从 Linux 远程管理快照 #
samba-client
包中有一个 FSRVP 客户端,它可以远程请求 Windows/Samba 服务器创建并公开指定共享的快照。然后,您可以使用 SUSE Linux Enterprise Desktop 中的现有工具装入公开的共享并备份其文件。向服务器发出的请求将使用 rpcclient
二进制文件发送。
rpcclient
请求 Windows Server 2012 共享快照 #
以 EXAMPLE
域中管理员的身份连接到 win-server.example.com
服务器:
root #
rpcclient -U 'EXAMPLE\Administrator' ncacn_np:win-server.example.com[ndr64,sign]
Enter EXAMPLE/Administrator's password:
检查 SMB 共享是否对于 rpcclient
可见:
root #
rpcclient $> netshareenum
netname: windows_server_2012_share
remark:
path: C:\Shares\windows_server_2012_share
password: (null)
检查 SMB 共享是否支持创建快照:
root #
rpcclient $> fss_is_path_sup windows_server_2012_share \
UNC \\WIN-SERVER\windows_server_2012_share\ supports shadow copy requests
请求创建共享快照:
root #
rpcclient $> fss_create_expose backup ro windows_server_2012_share
13fe880e-e232-493d-87e9-402f21019fb6: shadow-copy set created
13fe880e-e232-493d-87e9-402f21019fb6(1c26544e-8251-445f-be89-d1e0a3938777): \
\\WIN-SERVER\windows_server_2012_share\ shadow-copy added to set
13fe880e-e232-493d-87e9-402f21019fb6: prepare completed in 0 secs
13fe880e-e232-493d-87e9-402f21019fb6: commit completed in 1 secs
13fe880e-e232-493d-87e9-402f21019fb6(1c26544e-8251-445f-be89-d1e0a3938777): \
share windows_server_2012_share@{1C26544E-8251-445F-BE89-D1E0A3938777} \
exposed as a snapshot of \\WIN-SERVER\windows_server_2012_share\
确认服务器是否已公开快照共享:
root #
rpcclient $> netshareenum
netname: windows_server_2012_share
remark:
path: C:\Shares\windows_server_2012_share
password: (null)
netname: windows_server_2012_share@{1C26544E-8251-445F-BE89-D1E0A3938777}
remark: (null)
path: \\?\GLOBALROOT\Device\HarddiskVolumeShadowCopy{F6E6507E-F537-11E3-9404-B8AC6F927453}\Shares\windows_server_2012_share\
password: (null)
尝试删除快照共享:
root #
rpcclient $> fss_delete windows_server_2012_share \
13fe880e-e232-493d-87e9-402f21019fb6 1c26544e-8251-445f-be89-d1e0a3938777
13fe880e-e232-493d-87e9-402f21019fb6(1c26544e-8251-445f-be89-d1e0a3938777): \
\\WIN-SERVER\windows_server_2012_share\ shadow-copy deleted
确认服务器是否已去除快照共享:
root #
rpcclient $> netshareenum
netname: windows_server_2012_share
remark:
path: C:\Shares\windows_server_2012_share
password: (null)
31.5.2.4 使用 DiskShadow.exe
从 Windows 远程管理快照 #
您也可以在充当客户端的 Windows 环境中,管理 Linux Samba 服务器上的 SMB 共享的快照。Windows Server 2012 提供了 DiskShadow.exe
实用程序,该程序可以像第 31.5.2.3 节 “使用 rpcclient
从 Linux 远程管理快照”中所述的 rpcclient
那样管理远程共享。请注意,首先您需要妥善设置 Samba 服务器。
以下示例步骤描述了如何设置 Samba 服务器,使 Windows Server 客户端能够管理其共享的快照。请注意,EXAMPLE 是在测试环境中使用的 Active Directory 域,
fsrvp-server.example.com
是 Samba 服务器的主机名,/srv/smb
是 SMB 共享的路径。
通过 YaST 加入到 Active Directory 域。
确保“活动域 DNS”项正确:
fsrvp-server:~ # net -U 'Administrator' ads dns register \ fsrvp-server.example.com <IP address> Successfully registered hostname with DNS
在
/srv/smb
位置创建 Btrfs 子卷fsrvp-server:~ # btrfs subvolume create /srv/smb
为路径
/srv/smb
创建 snapper 配置文件fsrvp-server:~ # snapper -c <snapper_config> create-config /srv/smb
创建路径为
/srv/smb
的新共享,并启用 YaST 复选框。确保将以下代码片段添加到/etc/samba/smb.conf
的 global 部分,如第 31.5.2.2 节 “远程共享快照”中所述:[global] rpc_daemon:fssd = fork registry shares = yes include = registry
使用
systemctl restart nmb smb
重启动 Samba配置 snapper 权限:
fsrvp-server:~ # snapper -c <snapper_config> set-config \ ALLOW_USERS="EXAMPLE\\\\Administrator EXAMPLE\\\\win-client$"
确保也允许任何 ALLOW_USERS 浏览
.snapshots
子目录。fsrvp-server:~ # snapper -c <snapper_config> set-config SYNC_ACL=yes
重要:路径转义请小心使用“\”转义!请转义两次,以确保
/etc/snapper/configs/<snapper_config>
中储存的值转义一次。"EXAMPLE\win-client$" 对应于 Windows 客户端计算机帐户。对此帐户进行验证后,Windows 将发出初始 FSRVP 请求。
授予 Windows 客户端帐户必要的特权:
fsrvp-server:~ # net -U 'Administrator' rpc rights grant \ "EXAMPLE\\win-client$" SeBackupPrivilege Successfully granted rights.
不需要对 "EXAMPLE\Administrator" 用户执行上一条命令,因为已授予该用户特权。
DiskShadow.exe
#引导 Windows Server 2012(示例主机名为 WIN-CLIENT)。
就像在 SUSE Linux Enterprise Desktop 上那样,加入到同一个 Active Directory 域 EXAMPLE。
重引导。
打开 Powershell。
启动
DiskShadow.exe
,然后开始执行备份过程:PS C:\Users\Administrator.EXAMPLE> diskshadow.exe Microsoft DiskShadow version 1.0 Copyright (C) 2012 Microsoft Corporation On computer: WIN-CLIENT, 6/17/2014 3:53:54 PM DISKSHADOW> begin backup
指定每次程序退出、重设置或重引导时要保留的阴影副本:
DISKSHADOW> set context PERSISTENT
检查指定的共享是否支持快照,然后创建一个快照:
DISKSHADOW> add volume \\fsrvp-server\sles_snapper DISKSHADOW> create Alias VSS_SHADOW_1 for shadow ID {de4ddca4-4978-4805-8776-cdf82d190a4a} set as \ environment variable. Alias VSS_SHADOW_SET for shadow set ID {c58e1452-c554-400e-a266-d11d5c837cb1} \ set as environment variable. Querying all shadow copies with the shadow copy set ID \ {c58e1452-c554-400e-a266-d11d5c837cb1} * Shadow copy ID = {de4ddca4-4978-4805-8776-cdf82d190a4a} %VSS_SHADOW_1% - Shadow copy set: {c58e1452-c554-400e-a266-d11d5c837cb1} %VSS_SHADOW_SET% - Original count of shadow copies = 1 - Original volume name: \\FSRVP-SERVER\SLES_SNAPPER\ \ [volume not on this machine] - Creation time: 6/17/2014 3:54:43 PM - Shadow copy device name: \\FSRVP-SERVER\SLES_SNAPPER@{31afd84a-44a7-41be-b9b0-751898756faa} - Originating machine: FSRVP-SERVER - Service machine: win-client.example.com - Not exposed - Provider ID: {89300202-3cec-4981-9171-19f59559e0f2} - Attributes: No_Auto_Release Persistent FileShare Number of shadow copies listed: 1
完成备份过程:
DISKSHADOW> end backup
创建快照后,尝试将它删除,并确认删除结果:
DISKSHADOW> delete shadows volume \\FSRVP-SERVER\SLES_SNAPPER\ Deleting shadow copy {de4ddca4-4978-4805-8776-cdf82d190a4a} on volume \ \\FSRVP-SERVER\SLES_SNAPPER\ from provider \ {89300202-3cec-4981-9171-19f59559e0f2} [Attributes: 0x04000009]... Number of shadow copies deleted: 1 DISKSHADOW> list shadows all Querying all shadow copies on the computer ... No shadow copies found in system.
31.6 更多信息 #
手册页:: 要查看连同包 samba一起安装的所有手册页的列表,请运行
apropos samba
。使用man 手册页名称
打开任一手册页。SUSE 特定的 README 文件:: 包 samba-client 包含文件
/usr/share/doc/packages/samba/README.SUSE
。其他打包的文档:: 使用
zypper install samba-doc
安装samba-doc
包。此文档将安装到
/usr/share/doc/packages/samba
中。其中包含手册页的 HTML 版本以及示例配置的库(例如smb.conf.SUSE
)。联机文档:: https://wiki.samba.org/index.php/User_Documentation 上的 Samba Wiki 包含丰富的用户文档。
32 使用 Autofs 按需装入 #
autofs
是一个可根据需要自动装入指定目录的程序。它基于一个内核模块运行以实现高效率,并且可以同时管理本地目录和网络共享。这些自动安装点仅会在被访问时装入,一定时间内不活动后即会被卸载。这种按需行为可节省带宽,并实现比 /etc/fstab
管理的静态装入更高的性能。虽然 autofs
是控制脚本,但 automount
才是实际执行自动装入的命令(守护程序)。
32.1 安装 #
SUSE Linux Enterprise Desktop 上默认未安装 autofs。要使用它的自动装载功能,请先使用下面的命令安装该程序
tux >
sudo
zypper install autofs
32.2 配置 #
您需要使用 vim
等文本编辑器编辑 autofs
的配置文件来手动配置它。配置 autofs
有两个基本步骤 — master 映射文件和特定映射文件。
32.2.1 Master 映射文件 #
autofs
的默认 master 配置文件是 /etc/auto.master
。可通过在 /etc/sysconfig/autofs
文件中更改 DEFAULT_MASTER_MAP_NAME
选项的值来更改其位置。以下是 SUSE Linux Enterprise Desktop 中默认 master 映射文件的内容:
# # Sample auto.master file # This is an automounter map and it has the following format # key [ -mount-options-separated-by-comma ] location # For details of the format look at autofs(5).1 # #/misc /etc/auto.misc2 #/net -hosts # # Include /etc/auto.master.d/*.autofs3 # #+dir:/etc/auto.master.d # # Include central master map if it can be found using # nsswitch sources. # # Note that if there are entries for /net or /misc (as # above) in the included master map any keys that are the # same will not be seen as the first read key seen takes # precedence. # +auto.master4
| |
虽然这些内容默认会被注释掉 (#),但它依然是简单的自动装入器映射语法示例。 | |
如果您需要将 master 映射分割成几个文件,请将该行取消注释,并将映射(后缀为 | |
|
auto.master
中的项有三个字段,语法如下:
mount point map name options
- mount point
要在其中装入
autofs
文件系统的基本位置,例如/home
。- map name
装入时所用映射源的名称。有关映射文件的语法,请参见第 32.2.2 节 “映射文件”。
- options
这些选项(如指定)将作为默认值应用于给定映射中的所有项。
有关选用 map-type
、format
和 options
的特定值的更多详细信息,请参见 手册页 (man 5 auto.master
)。
auto.master
中下面的项指示 autofs
查看 /etc/auto.smb
,并在 /smb
目录中创建安装点。
/smb /etc/auto.smb
32.2.1.1 直接装入 #
直接装入会在相关映射文件内的指定路径创建安装点。这种方式不是在 auto.master
中指定安装点,而是用 /-
替换安装点字段。例如,下行指示 autofs
在 auto.smb
中的指定位置创建安装点:
/- /etc/auto.smb
如果指定映射文件时未包含其完整本地或网络路径,系统会使用名称服务转换 (NSS) 配置寻找该映射文件。
/- auto.smb
32.2.2 映射文件 #
虽然文件是使用 autofs
自动装入的最常见的映射类型,但是还有其他一些类型。映射规范可以是命令的输出,也可以是 LDAP 或数据库中查询的结果。有关映射类型的更多详细信息,请参见 man 5 auto.master
手册页。
映射文件指定(本地或网络)来源位置,以及在本地装入来源的安装点。映射的一般格式与 master 映射相似。区别在于 options 位于 mount point 与 location 之间,而不是该项的末尾:
mount point options location
确保映射文件未标记为可执行文件。可通过执行 chmod -x MAP_FILE
去除可执行文件位。
- mount point
指定将来源位置装入到何处。这可以是要添加到 auto.master 中所指定基础安装点的单个目录名称(所谓的
间接
装入),也可以是安装点的完整路径(直接装入,请参见第 32.2.1.1 节 “直接装入”)。- options
指定相关项的安装点逗号分隔列表(可选)。如果
auto.master
还包含此映射文件的选项,这些选项会附加在后面。- location
指定要装入的文件系统来自何处。通常是 NFS 或 SMB 卷,常用表示法是
主机名:路径名称
。如果要装入的文件系统以“/”开头(例如本地/dev
项或 smbfs 共享),需要在前面加一个冒号“:”,例如:/dev/sda1
。
32.3 操作和调试 #
本节介绍如何控制 autofs
服务操作,以及如何在调整该自动装入器操作时查看更多调试信息。
32.3.1 控制 autofs
服务 #
autofs
服务的操作由 systemd
控制。autofs
的 systemctl
命令的一般语法为
tux >
sudo
systemctl SUB_COMMAND autofs
其中,SUB_COMMAND 是下列项目之一:
- enable
在引导时启动该自动装入器守护程序。
- start
启动该自动装入器守护程序。
- stop
停止该自动装入器守护程序。自动安装点将不再可访问。
- status
打印
autofs
服务的当前状态以及相关日志文件的部分内容。- restart
停止然后启动该自动装入器,以便终止所有正在运行的守护程序,然后再启动新的守护程序。
- reload
检查当前的
auto.master
映射,重启动项已更改的守护程序,并为新项启动新守护程序。
32.3.2 调试自动装入器问题 #
如果您在使用 autofs
装入目录时遇到问题,手动运行 automount
守护程序并查看其输出讯息将非常有用:
停止
autofs
。tux >
sudo
systemctl stop autofs从一个终端的前台手动运行
automount
,生成详细输出。tux >
sudo
automount -f -v从另一个终端上尝试通过访问安装点(例如,通过
cd
或ls
)装入自动装入文件系统。从第一个终端上检查
automount
的输出以了解更多信息,例如装入为何失败,或者为何甚至未尝试执行装入。
32.4 自动装入 NFS 共享 #
下面的过程说明了如何配置 autofs
以自动装入网络上可用的 NFS 共享。该过程要用到前面提到的信息,并假设您熟悉 NFS 导出。有关 NFS 的更多信息,请参见第 30 章 “通过 NFS 共享文件系统”。
编辑 master 映射文件
/etc/auto.master
:tux >
sudo
vim /etc/auto.master在
/etc/auto.master
末尾为新的 NFS 装入添加一条新项:/nfs /etc/auto.nfs --timeout=10
它告诉
autofs
基本安装点是/nfs
,NFS 共享在/etc/auto.nfs
映射中指定,并且此映射中的所有共享将在 10 秒不活动后自动卸载。为 NFS 共享创建新的映射文件:
tux >
sudo
vim /etc/auto.nfs对每个 NFS 共享,
/etc/auto.nfs
通常都会包含单独的一行。有关其格式,请参见第 32.2.2 节 “映射文件”。添加下行,指出安装点及 NFS 共享网络地址:export jupiter.com:/home/geeko/doc/export
上面的行表示当收到请求时,系统会将
jupiter.com
主机上的/home/geeko/doc/export
目录自动装入到本地主机上的/nfs/export
目录(/nfs
取自auto.master
映射)。/nfs/export
目录将由autofs
自动创建。(选择性)如果您先前以静态方式装入了该 NFS 共享,请将
/etc/fstab
中的相关行注释掉。该行应类似于:#jupiter.com:/home/geeko/doc/export /nfs/export nfs defaults 0 0
重新装载
autofs
并检查它是否正常工作:tux >
sudo
systemctl restart autofs# ls -l /nfs/export total 20 drwxr-xr-x 5 1001 users 4096 Jan 14 2017 .images/ drwxr-xr-x 10 1001 users 4096 Aug 16 2017 .profiled/ drwxr-xr-x 3 1001 users 4096 Aug 30 2017 .tmp/ drwxr-xr-x 4 1001 users 4096 Apr 25 08:56 manual/
如果您能看到远程共享上的文件列表,则表示
autofs
工作正常。
32.5 高级主题 #
本节讨论的主题超出了 autofs
基本介绍的范畴 — 自动装入网络上可用的 NFS 共享、在映射文件中使用通配符,以及特定于 CIFS 文件系统的信息。
32.5.1 /net
安装点 #
如果您使用了许多 NFS 共享,这个助手安装点将非常有用。/net
会根据需要自动装入本地网络上的所有 NFS 共享。该项在 auto.master
文件中已经存在,因此,您只需将其取消注释,然后重启动 autofs
即可:
/net -hosts
tux >
sudo
systemctl restart autofs
例如,如果您有名为 jupiter
的服务器以及名为 /export
的 NFS 共享,您可以在命令行上键入
tux >
sudo
cd /net/jupiter/export
来装入它。
32.5.2 使用通配符自动装入子目录 #
如果您的某个目录含有多个子目录,并且您需要将这些子目录单个自动装入(一般情况下,该目录是包含各个用户主目录的 /home
目录),autofs
提供了便捷的解决方案。
如果这些子目录是主目录,则在 auto.master
中添加下行:
/home /etc/auto.home
现在,您需要在 /etc/auto.home
文件中添加正确的映射,以便自动装入用户的主目录。一种方法是为每个目录创建单独的项:
wilber jupiter.com:/home/wilber penguin jupiter.com:/home/penguin tux jupiter.com:/home/tux [...]
这种方法非常麻烦,因为您需要在 auto.home
中管理用户列表。您可以使用星号“*”取代安装点,使用符号“&”取代要装入的目录。
* jupiter:/home/&
32.5.3 自动装入 CIFS 文件系统 #
如果想自动装入 SMB/CIFS 共享(有关 SMB/CIFS 协议的更多信息,请参见第 31 章 “Samba”了解),需要修改映射文件的语法。在 option 字段中添加 -fstype=cifs
,并在共享位置前面加上一个冒号“:”。
mount point -fstype=cifs ://jupiter.com/export
第 V 部分 查错 #
- 33 帮助和文档
SUSE® Linux Enterprise Desktop 提供了各种来源的信息和文档,其中有许多已经集成在您安装好的系统中。
- 34 收集用于支持的系统信息
为了让用户快速概览计算机的所有系统相关信息,SUSE Linux Enterprise Desktop 提供了
hostinfo
包。该包还可以帮助系统管理员检查污染的(不支持的)内核,或者计算机上安装的任何第三方包。出现问题时,可以使用
supportconfig
命令行工具或 YaST 模块创建详细的系统报告。这两种方法都会收集系统的相关信息,包括当前内核版本、硬件、已安装包、分区设置及其他信息。最后会生成一个包含多个文件的 TAR 存档。在建立服务请求 (SR) 后,您可以将该 TAR 存档上载至全球技术支持。该存档有助于跟踪您所报告的问题,并可以帮助您解决问题。此外,您可以分析
supportconfig
输出来发现已知问题,以帮助快速解决问题。为此,SUSE Linux Enterprise Desktop 提供了一个设备和一个命令行工具用于进行Supportconfig 分析
(SCA)。- 35 常见问题及其解决方案
本章将描述一系列可能发生的问题及其解决方法。即使您的情况并未精确地列在这里,也可能有足够相似的情况可提供解决您的问题的方法提示。
33 帮助和文档 #
SUSE® Linux Enterprise Desktop 提供了各种来源的信息和文档,其中有许多已经集成在您安装好的系统中。
/usr/share/doc
中的文档这一传统帮助目录包含各种文档文件以及系统的发行说明。它还包含子目录
packages
中的已安装包的信息。有关详细信息可以在第 33.1 节 “文档目录” 中找到。- 外壳命令的手册页和信息页
使用外壳时,您不需要了解命令选项。外壳往往是通过手册页和信息页来提供集成帮助的。有关详细信息,请参见第 33.2 节 “手册页”和第 33.3 节 “信息页”。
- 桌面帮助中心
GNOME 桌面的帮助中心(帮助)按可搜索的形式提供了对系统上最重要的文档资源的集中访问途径。这些资源包括已安装应用程序、手册页、信息页以及随产品提供的 SUSE 手册的联机帮助。
- 某些应用程序的独立帮助包
当用 YaST 安装新软件时,系统通常会自动安装软件文档,并且这些文档会出现在您桌面的帮助中心中。但是,某些应用程序(如 GIMP)可能具有不同的联机帮助包,可与 YaST 分开安装,并且不集成到帮助中心。
33.1 文档目录 #
在安装的 Linux 系统上用来查找文档的目录一直以来都是 /usr/share/doc
。目录通常包含有关您的系统上已安装的包和发行说明、手册等等的信息。
在 Linux 系统中,许多手册和其他种类的文档都可以像软件一样以包的形式获取。/usr/share/docs
中的信息量和信息内容还取决于安装的(文档)包。如果您找不到这里提到的子目录,请检查相应的包是否已安装到您的系统上,并根据需要使用 YaST 添加它们。
33.1.1 SUSE 手册 #
我们以不同的语言提供了这些手册的 HTML 和 PDF 版本。在 manual
子目录下有您的产品适用的大多数 HTML 版 SUSE 手册。有关对您的产品可用的所有文档的概述,请参见这些手册的前言。
如果安装了多种语言,/usr/share/doc/manual
可能包含这些手册的不同语言版本。两个桌面的帮助中心内也提供 HTML 版本的 SUSE 手册。有关在安装媒体的何处能找到这些手册的 PDF 和 HTML 版本的信息,请参见 SUSE Linux Enterprise Desktop 发行说明。它们位于所安装系统的 /usr/share/doc/release-notes/
下,或者也可以联机访问您的产品专属网站:https://www.suse.com/releasenotes//。
33.1.2 包文档 #
在 packages
下可找到系统上安装的软件包中包含的文档。对每个包,都会创建子目录 /usr/share/doc/packages/PACKAGENAME
。它经常包含该包的自述文件,有时还包含示例、配置文件或其他脚本。下表列出了 /usr/share/doc/packages
下常见的文件。以下每项不一定都存在,许多包中可能只包含其中的一部分。
AUTHORS
主要开发者列表。
BUGS
已知 bug 或故障。还可能包含到 Bugzilla 网页的链接,您可以在该页面上搜索所有 bug。
CHANGES
,ChangeLog
每个版本的更改摘要。通常开发人员会对此感兴趣,因为它非常详细。
COPYING
,LICENSE
许可信息。
FAQ
从邮件列表或新闻组收集的问题和回答。
INSTALL
如何在系统上安装此包。因为您读到该文件前该包已安装,您可以放心地忽略该文件的内容。
README
、README.*
软件的常规信息。例如用途和用法。
TODO
尚未实施但是将来可能要实施的操作。
MANIFEST
带有简述的文件列表。
NEWS
描述此版本中的新增内容。
33.2 手册页 #
手册页是任何 Linux 系统的基本组成部分。它们介绍命令的用法以及所有可用的选项和参数。许多页面都可以用 man
后面跟命令名来访问,例如 man ls
。
手册页直接显示在外壳中。可以用 Page ↑ 和 Page ↓ 上下移动来浏览它们。用Home 和 End 可以切换显示文档的开头和结尾。按 Q 可以结束这种查看模式。使用 man man
可以了解有关 man
命令本身的更多信息。手册页如表 33.1 “手册页—类别和说明” 所示按类别进行排序(取自 man 命令本身的手册页)。
号码 |
描述 |
---|---|
1 |
可执行程序或外壳命令 |
2 |
系统调用(内核提供的函数) |
3 |
库调用(程序库内的函数) |
4 |
特殊文件(通常位于 |
5 |
文件格式和约定 ( |
6 |
游戏 |
7 |
其他(包括宏包和约定),如 man(7)、groff(7) |
8 |
系统管理命令(通常仅供 |
9 |
内核例程(非标准) |
每个手册页包括标为 NAME、SYNOPSIS、DESCRIPTION、SEE ALSO、LICENSING 和 AUTHOR 的几个部分。根据具体的命令类型,可能还有其他部分。
33.3 信息页 #
信息页是系统上另一个重要的信息来源。它们通常比手册页更为详细。它们包含多个命令行选项,有时还包含完整的教学课程或参考文档。要查看特定命令的信息页,请输入 info
后面跟命令名,例如 info ls
。您可以在外壳中直接用查看器浏览信息页,并显示名为“节点”的各个部分。使用 Space 可前移,使用 <— 可后移。在节点内,您也可以用 Page ↑ 和 Page ↓ 浏览,但只有 Space 和 <— 仍会带您到上个或下个节点。按 Q 结束查看模式。并非每个命令都有对应的信息页,反之亦然。
33.4 联机资源 #
除了安装在 /usr/share/doc
下的联机版 SUSE 手册之外,您还可以访问网上的产品特定手册和文档。有关 SUSE Linux Enterprise Desktop 所有适用文档的概述,请查看产品特定的文档网页,网址为:http://www.suse.com/doc/。
如果要搜索更多产品相关信息,您也可以参见以下网站:
- SUSE 技术支持
如果您有技术方面的疑问或需要相应的解决方案,可在 http://www.suse.com/support/ 上找到 SUSE 技术支持。
- SUSE 论坛
SUSE 有多个论坛,您可以进入其中讨论有关该产品的话题。如需获取一份列表,请参见 http://forums.suse.com/。
- SUSE 交流园地
联机社区提供文章、提示、问答和可供免费下载的工具:http://www.suse.com/communities/conversations/
- GNOME 文档
适用于 GNOME 用户、管理员和开发人员的文档可在 http://library.gnome.org/ 上找到。
- Linux 文档计划
Linux 文档计划(Linux Documentation Project,TLDP)由编写 Linux 相关文档的志愿者团队负责管理(请参见 http://www.tldp.org)。它可能是 Linux 相关的最全面的文档资源。这套文档包括初学者教程,但主要侧重于有经验的用户和职业系统管理员。TLDP 以免费许可的形式发布 HOWTO、常见问题和指南(手册)。SUSE Linux Enterprise Desktop 上也有来自 TLDP 的部分文档。
您还可以尝试通用搜索引擎。例如,如果在刻录 CD 或转换 LibreOffice 文件时遇到问题,可以使用搜索词“Linux CD-RW 帮助
”或“OpenOffice 文件转换问题
”。
34 收集用于支持的系统信息 #
为了让用户快速概览计算机的所有系统相关信息,SUSE Linux Enterprise Desktop 提供了 hostinfo
包。该包还可以帮助系统管理员检查污染的(不支持的)内核,或者计算机上安装的任何第三方包。
出现问题时,可以使用 supportconfig
命令行工具或 YaST 模块创建详细的系统报告。这两种方法都会收集系统的相关信息,包括当前内核版本、硬件、已安装包、分区设置及其他信息。最后会生成一个包含多个文件的 TAR 存档。在建立服务请求 (SR) 后,您可以将该 TAR 存档上载至全球技术支持。该存档有助于跟踪您所报告的问题,并可以帮助您解决问题。
此外,您可以分析 supportconfig
输出来发现已知问题,以帮助快速解决问题。为此,SUSE Linux Enterprise Desktop 提供了一个设备和一个命令行工具用于进行 Supportconfig 分析
(SCA)。
34.1 显示当前系统信息 #
在登录到服务器时,要想快速方便地概览所有相关系统信息,请使用包 hostinfo
。在计算机上安装该包后,控制台将会向登录到该计算机的任何 root
用户显示以下信息:
root
身份登录时的 hostinfo
输出 #Hostname: earth Current As Of: Wed 12 Mar 2014 03:57:05 PM CET Distribution: SUSE Linux Enterprise Server 12 -Service Pack: 0 Architecture: x86_64 Kernel Version: 3.12.12-3-default -Installed: Mon 10 Mar 2014 03:15:05 PM CET -Status: Not Tainted Last Updated Package: Wed 12 Mar 2014 03:56:43 PM CET -Patches Needed: 0 -Security: 0 -3rd Party Packages: 0 IPv4 Address: ens3 192.168.1.1 Total/Free/+Cache Memory: 983/95/383 MB (38% Free) Hard Disk: /dev/sda 10 GB
如果输出显示 tainted
内核状态,请参见第 34.6 节 “内核模块支持”以了解更多细节。
34.2 使用 Supportconfig 收集系统信息 #
要创建包含详细系统信息的 TAR 存档,以提交给全球技术支持,请使用:
supportconfig
命令,或者YaST
模块。
该命令行工具由默认安装的包 supportutils
提供。YaST 模块也基于该命令行工具。
系统上的有些包集成了 Supportconfig 插件,具体视系统上安装的包而定。执行 Supportconfig 时,还会执行所有插件,并创建该存档的一个或多个结果文件。这样做的好处是只检查包含特定插件的主题。Supportconfig 插件储存在 /usr/lib/supportconfig/plugins/
目录中。
34.2.1 创建服务请求编号 #
系统随时都可以生成 Supportconfig 存档。但是,要将 Supportconfig 数据提交给全球技术支持,首先需要生成一个服务请求编号。上载存档以获取支持时,您需要使用此编号。
要创建服务请求,请访问 https://scc.suse.com/support/requests 并遵照屏幕上的说明操作。写下您的 12 位服务请求编号。
SUSE 和 Micro Focus 将系统报告视为机密数据。有关我们在隐私方面所做承诺的详细信息,请参见 https://www.suse.com/company/policies/privacy/。
34.2.2 上载目标 #
在创建服务请求编号后,可以根据过程 34.1 “使用 YaST 向支持部门提交信息”或过程 34.2 “从命令行向支持部门提交信息”中所述将 Supportconfig 存档上载到全球技术支持站点。使用下列上载目标之一:
EMEA(欧洲、中东和非洲):ftp://support-ftp.suse.com/in
或者,可以使用以下服务请求 URL 手动将该 TAR 存档附加到您的服务请求:https://scc.suse.com/support/requests。
34.2.3 使用 YaST 创建 Supportconfig 存档 #
要使用 YaST 收集系统信息,请按如下所述操作:
启动 YaST 并打开
模块。单击
。在随后出现的窗口中,从单选按钮列表中选择一个 Supportconfig 选项。系统默认会预先选择
。如果要先测试报告功能,请使用 。有关其他选项的某些背景信息,请参考supportconfig
手册页。单击
继续。输入您的联系信息。该信息将写入名为
basic-environment.txt
的文件,并包含在要创建的存档中。如果要在结束信息收集过程时将存档提交到全球技术支持,则需要指定第 34.2.2 节 “上载目标”,以详细了解可以使用哪些上载服务器。
。YaST 会自动推荐一个上载服务器。如果要修改该服务器,请参考如果希望稍后提交存档,则可以暂时将
留空。单击
继续。开始收集信息。
该过程完成后,单击
继续。检查数据收集:选择日志文件的
可以在 YaST 中查看其内容。在将 TAR 存档提交到支持部门之前,如果要去除您不希望包含在该存档中的文件,请使用 。按 继续。保存该 TAR 存档。如果您以
root
用户身份启动了 YaST 模块,则默认情况下,YaST 会建议将该存档保存到/var/log
(否则将保存到您的主目录)。文件名格式为nts_主机_日期_时间.tbz
。如果要直接将该存档上载到支持部门,请确保步骤 5 中 YaST 建议的上载目标。如果要修改上载目标,请在 第 34.2.2 节 “上载目标” 中查找有关哪些上载服务器可用的详细信息。
已激活。此处显示的 是如果要跳过上载步骤,请停用
。确认更改以关闭 YaST 模块。
34.2.4 从命令行创建 Supportconfig 存档 #
下面的过程显示了如何创建 Supportconfig 存档,但不将它直接提交给支持人员。要上载该存档,需要根据过程 34.2 “从命令行向支持部门提交信息”中所述,结合某些选项运行命令。
打开外壳并转换为
root
用户。运行
supportconfig
。一般而言,不带任何选项运行此工具就足以满足需要。下面的列表中显示了一些十分常用的选项:-E MAIL
,-N NAME
,-O COMPANY
,-P PHONE
设置您的联系数据:电子邮件地址 (
-E
)、公司名称 (-O
)、您的姓名 (-N
) 和电话号码 (-P
)。-i KEYWORDS
,-F
限制检查的功能。KEYWORDS 占位符是区分大小写的关键字的逗号分隔列表。使用
supportconfig -F
可获得所有关键字列表。-r SRNUMBER
定义上载生成的 TAR 存档时所用的服务请求编号。
等待工具完成操作。
默认的存档位置为
/var/log
,文件名格式为nts_主机_日期_时间.tbz
34.2.5 了解 supportconfig
的输出 #
不管您是通过 YaST 还是直接运行 supportconfig
,该脚本都会显示其已执行操作的摘要。
Support Utilities - Supportconfig Script Version: 3.0-98 Script Date: 2017 06 01 [...] Gathering system information Data Directory: /var/log/nts_d251_180201_1525 1 Basic Server Health Check... Done 2 RPM Database... Done 2 Basic Environment... Done 2 System Modules... Done 2 [...] File System List... Skipped 3 [...] Command History... Excluded 4 [...] Supportconfig Plugins: 1 5 Plugin: pstree... Done [...] Creating Tar Ball ==[ DONE ]=================================================================== Log file tar ball: /var/log/nts_d251_180201_1525.tbz 6 Log file size: 732K Log file md5sum: bf23e0e15e9382c49f92cbce46000d8b =============================================================================
34.2.6 常用的 supportconfig 选项 #
supportconfig
实用程序在调用时通常不带任何选项。使用 supportconfig
-h
显示所有选项的列表或参见手册页。下面的列表提供了某些常见用例的简述:
- 减少所收集信息的大小
使用最少量选项 (
-m
):tux >
sudo
supportconfig -m- 将信息限制为特定的主题
如果已确定问题所在,并发现该问题只与特定的区域或功能集相关,则您在下次运行
supportconfig
时,应限制针对特定的区域收集信息。例如,如果您检测到 LVM 出现问题,想要测试最近对 LVM 配置所做的更改。在这种情况下,合适的做法是只收集有关 LVM 的最少量 Supportconfig 信息:tux >
sudo
supportconfig -i LVM可通过逗号分隔额外的关键字。例如,额外的磁盘测试:
tux >
sudo
supportconfig -i LVM,DISK要查看可用于将所收集信息限制为特定区域的功能关键字的完整列表,请运行:
tux >
sudo
supportconfig -F- 在输出中包含其他联系信息:
tux >
sudo
supportconfig -E tux@example.org -N "Tux Penguin" -O "Penguin Inc." ...(在一行中输入所有命令)
- 收集已经过轮换的日志文件
tux >
sudo
supportconfig -l这对日志记录量较大的环境,或重引导后 syslog 轮换日志文件时发生内核崩溃的情况尤为有用。
34.2.7 存档内容概述 #
TAR 存档包含各功能的所有结果。根据所选的内容(所有功能或只有一小部分功能),存档包含的文件可能有多有少。您可通过 -i
选项来限制功能集(请参见第 34.2.6 节 “常用的 supportconfig 选项”)。
要列出存档的内容,请使用以下 tar
命令:
root #
tar
xf /var/log/nts_earth_180131_1545.tbz
TAR 存档中始终包含以下文件名:
basic-environment.txt
包含执行此脚本的日期和系统信息(如发行套件版本)、超级管理程序信息等。
basic-health-check.txt
包含一些基本的运行状态检查,如运行时间、虚拟内存统计数字、可用内存和硬盘、僵尸进程检查等。
hardware.txt
包含基本硬件检查(如有关 CPU 体系结构的信息)、所有已连接硬件的列表、中断、I/O 端口、内核引导讯息等。
messages.txt
包含系统日记中的日志讯息。
rpm.txt
包含所有已安装的 RPM 包、名称、来源及其版本的列表。
summary.xml
包含 XML 格式的一些信息,如发行套件、版本和产品特定的分段。
supportconfig.txt
包含有关
supportconfig
脚本本身的信息。y2log.txt
包含 YaST 特定的信息,如特定的包、配置文件和日志文件。
表 34.1 “TAR 存档中的功能和文件名对照”列出了所有可用的功能及其文件名。后续的服务包或插件将会补充到列表中。
特性 | 文件名 |
---|---|
AFP | novell-afp.txt |
APPARMOR | security-apparmor.txt |
AUDIT | security-audit.txt |
AUTOFS | fs-autofs.txt |
BOOT | boot.txt |
BTRFS | fs-btrfs.txt |
DAEMONS | chkconfig.txt |
CIFS | novell-cifs.txt |
CIMOM | cimom.txt |
CRASH | crash.txt |
CRON | cron.txt |
DFS | novell-dfs.txt |
DHCP | dhcp.txt |
DISK | fs-diskio.txt |
DNS | dns.txt |
DOCKER | cocker.txt |
DRBD | drbd.txt |
DSFW | novell-dsfw.txt |
EDIR | novell-edir.txt |
ENV | env.txt |
ETC | etc.txt |
EVMS | evms.txt |
HA | ha.txt |
HAPROXY | haproxy.txt |
HISTORY | shell_history.txt |
IB | ib.txt |
IMAN | novell-iman.txt |
ISCSI | fs-iscsi.txt |
KVM | kvm.txt |
LDAP | ldap.txt |
LUM | novell-lum.txt |
LVM | lvm.txt |
LXC | lxc.txt |
MEM | memory.txt |
MOD | modules.txt |
MPIO | mpio.txt |
NCP | novell-ncp.txt |
NCS | novell-ncs.txt |
NET | network-*.txt |
NFS | nfs.txt |
NIT | novell-nit.txt |
NSS | novell-nss.txt |
NTP | ntp.txt |
OCFS2 | ocfs2.txt |
OES | 无 |
OFILES | open-files.txt |
PAM | pam.txt |
print.txt | |
PROC | proc.txt |
PROXY | novell-proxymgmt.txt |
SAM | sam.txt |
SAR | sar.txt |
SLERT | slert.txt |
SLP | slp.txt |
SMT | smt.txt |
SMART | fs-smartmon.txt |
SMB | samba.txt |
SMS | novell-sms.txt |
SRAID | fs-softraid.txt |
SSH | ssh.txt |
SSSD | sssd.txt |
SYSCONFIG | sysconfig.txt |
SYSFS | sysfs.txt |
UDEV | udev.txt |
UFILES | fs-files-additional.txt |
UP | updates.txt |
UPD | updates-daemon.txt |
WEB | web.txt |
X | x.txt |
XEN | xen.txt |
34.3 将信息提交到全球技术支持 #
可以使用 YaST supportconfig
命令行实用程序向全球技术支持提交系统信息。如果您遇到服务器问题并想要获得支持人员的帮助,则首先需要建立一个服务请求。有关细节,请参见第 34.2.1 节 “创建服务请求编号”。
以下示例使用 12345678901 作为服务请求编号的占位符。请将 12345678901 替换为您在第 34.2.1 节 “创建服务请求编号”中创建的服务请求编号。
下面的过程假设您已创建某个 Supportconfig 存档,但尚未将其上载。请确保已按第 34.2.3 节 “使用 YaST 创建 Supportconfig 存档”中的步骤 4 所述在存档中包含了您的联系信息。有关如何一步生成并提交 Supportconfig 存档的说明,请参见第 34.2.3 节 “使用 YaST 创建 Supportconfig 存档”。
启动 YaST 并打开
模块。单击
。在
中,指定现有 Supportconfig 存档的路径,或者单击 找到该存档。YaST 会自动推荐一个上载服务器。如果要修改该服务器,请参考第 34.2.2 节 “上载目标”,以详细了解可以使用哪些上载服务器。
单击
继续。单击
。
下面的过程假设您已创建某个 Supportconfig 存档,但尚未将其上载。有关如何一步生成并提交 Supportconfig 存档的说明,请参见第 34.2.3 节 “使用 YaST 创建 Supportconfig 存档”。
具有因特网连接的服务器:
要使用默认上载目标,请运行:
tux >
sudo
supportconfig -ur 12345678901对于安全上载目标,请使用以下命令:
tux >
sudo
supportconfig -ar 12345678901
不具有因特网连接的服务器:
运行以下命令:
tux >
sudo
supportconfig -r 12345678901将
/var/log/nts_SR12345678901*tbz
存档手动上载到我们的 FTP 服务器之一。要使用哪个服务器取决于您所在的位置。有关概览,请参见第 34.2.2 节 “上载目标”。
将 TAR 存档上载到我们 FTP 服务器的接收目录后,它会自动附加到您的服务请求中。
34.4 分析系统信息 #
您可以分析使用 supportconfig
创建的系统报告来发现已知问题,以帮助快速解决问题。为此,SUSE Linux Enterprise Desktop 提供了一个设备和一个命令行工具用于进行 Supportconfig 分析
(SCA)。SCA 设备是一个非交互式服务器端工具。SCA 工具 (scatool
) 由包
sca-server-report提供,它在客户端中运行,并通过命令行执行。这两个工具都能分析来自受影响服务器的 Supportconfig 存档。初始服务器分析在 SCA 设备或运行 scatool
的工作站上进行。生产服务器上不发生任何分析周期。
此外,该设备和命令行工具还需要产品特定的模式,这样它们才能分析关联产品的 Supportconfig 输出。每个模式就是一个脚本,用于针对某个已知问题分析和评估 Supportconfig 存档。模式以 RPM 包的形式提供。
您也可以根据第 34.4.3 节 “开发自定义分析模式”中的简述开发自己的模式。
34.4.1 SCA 命令行工具 #
SCA 命令行工具可让您既可使用 supportconfig
又可使用本地计算机上安装的特定产品的分析模式来分析该本地计算机。该工具将创建一份 HTML 报告来显示分析结果。有关示例,请参见图 34.1 “SCA 工具生成的 HTML 报告”。
scatool
命令由
sca-server-report package. 默认情况下不会安装该包。此外,您还需要
sca-patterns-base 包和任何产品特定的
sca-patterns-* 包,它们需与要运行 scatool
命令的计算机上安装的产品匹配。
以 root
用户身份或者结合 sudo
执行 scatool
命令。在调用 SCA 工具时,可以分析现有的 supportconfig
TAR 存档,或者一步即让该工具生成并分析新的存档。该工具还提供具有 Tab 补全功能的交互控制台。您可以在外部计算机上运行 supportconfig
,在本地计算机上执行后续分析。
下面提供了一些示例命令:
sudo scatool
-s
调用
supportconfig
,并在本地计算机上生成新的 Supportconfig 存档。通过应用与所安装产品匹配的 SCA 分析模式来分析存档以发现已知问题。显示基于分析结果生成的 HTML 报告的路径。通常,该报告将写入到 Supportconfig 存档所在的同一目录中。sudo scatool
-s
-o
/opt/sca/reports/与
sudo scatool
-s
类似,唯一的差别在于,HTML 报告将写入到-o
指定的路径。sudo scatool
-a
PATH_TO_TARBALL_OR_DIR分析指定的 Supportconfig 存档文件(或者指定用于存放解压缩的 Supportconfig 存档的目录)。生成的 HTML 报告保存在 Supportconfig 存档或目录所在的位置。
sudo scatool
-a
SLES_SERVER.COMPANY.COM与外部服务器 SLES_SERVER.COMPANY.COM 建立 SSH 连接,并在该服务器上运行
supportconfig
。Supportconfig 存档随后将复制回本地计算机,并在该处进行分析。生成的 HTML 报告保存在默认的/var/log
目录中。(SLES_SERVER.COMPANY.COM 上只创建 Supportconfig 存档)。sudo scatool
-c
启动
scatool
的交互式控制台。按 →| 两次可查看可用命令。
有关其他选项和信息,请运行 sudo scatool -h
或参见 scatool
手册页。
34.4.2 SCA 设备 #
如果您决定使用 SCA 设备来分析 Supportconfig 存档,请配置一台服务器(或虚拟机)作为专用的 SCA 设备服务器。然后,可以使用该 SCA 设备服务器,对企业中运行 SUSE Linux Enterprise Server 或 SUSE Linux Enterprise Desktop 的所有计算机上的 Supportconfig 存档进行分析。您只需要将 Supportconfig 存档上载到设备服务器,等待它执行分析。此过程无需任何交互。在 MariaDB 数据库中,SCA 设备将会跟踪已分析的所有 Supportconfig 存档。您可以直接从设备 Web 界面阅读 SCA 报告。或者,可以让设备通过电子邮件将 HTML 报告发送给任何管理用户。有关细节,请参见第 34.4.2.5.4 节 “通过电子邮件发送 SCA 报告”。
34.4.2.1 安装快速入门 #
要通过命令行快速安装和设置 SCA 设备,请遵照此处的说明操作。该过程适用于专家用户,主要通过单纯的安装与设置命令来完成。有关更多信息,请参考第 34.4.2.2 节 “先决条件”到第 34.4.2.3 节 “安装和基本设置”中的详细说明。
Web 和 LAMP 模式
Web 和脚本编写模块(您必须注册计算机才能选择此模块)。
root
特权
下面过程中的所有命令必须以 root
身份来运行。
设置并运行设备后,无需任何人工交互。因此,对于使用 cron 作业创建和上载 Supportconfig 存档的情形,非常适合使用这种方法来设置设备。
在安装设备的计算机上,登录到控制台并执行以下命令:
tux >
sudo
zypper install sca-appliance-* sca-patterns-* vsftpd systemctl enable apache2 systemctl start apache2 systemctl enable vsftpd systemctl start vsftpd yast ftp-server在 YaST FTP 服务器中,选择
› › › › ,以 。执行以下命令:
tux >
sudo
systemctl enable mysql systemctl start mysql mysql_secure_installation setup-sca -fmysql_secure_installation 将创建 MariaDB
root
口令。
这种设置设备的方法需要在键入 SSH 口令时进行人工交互。
在安装设备的计算机上,登录到控制台。
执行以下命令:
tux >
sudo
zypper install sca-appliance-* sca-patterns-* systemctl enable apache2 systemctl start apache2 sudo systemctl enable mysql systemctl start mysql mysql_secure_installation setup-sca
34.4.2.2 先决条件 #
要运行 SCA 设备服务器,需要满足以下先决条件:
安装所有
sca-appliance-*
包。安装
sca-patterns-base
包。此外,需要针对您要使用该设备分析的 Supportconfig 存档类型安装产品特定的sca-patterns-*
。Apache
PHP
MariaDB
匿名 FTP 服务器(可选)
34.4.2.3 安装和基本设置 #
如第 34.4.2.2 节 “先决条件”中所列,SCA 设备与其他包存在若干依赖项。因此,在安装和设置 SCA 设备服务器之前,需要做一些准备工作:
对于 Apache 和 MariaDB,请安装
Web
和LAMP
安装模式。设置 Apache 和 MariaDB,并有选择性地设置一个匿名 FTP 服务器。
将 Apache 和 MariaDB 配置为在引导时启动:
tux >
sudo
systemctl enable apache2 mysql启动这两个服务:
tux >
sudo
systemctl start apache2 mysql
现在,您便可以根据过程 34.5 “安装和配置 SCA 设备”中所述安装和设置 SCA 设备。
安装这些包后,可以使用 setup-sca
脚本来对 SCA 设备使用的 MariaDB 管理与报告数据库进行基本的配置。
使用该脚本可以配置以下选项,以便将 Supportconfig 存档从您的计算机上载到 SCA 设备:
scp
匿名 FTP 服务器
安装设备和 SCA 基本模式库:
tux >
sudo
zypper install sca-appliance-* sca-patterns-base此外,请针对您要分析的 Supportconfig 存档类型安装模式包。例如,如果您的环境中安装了 SUSE Linux Enterprise Server 12 和 SUSE Linux Enterprise Server 15 服务器,请安装
sca-patterns-sle12
和sca-patterns-sle15
这两个包。安装所有可用模式:
tux >
sudo
zypper install sca-patterns-*要对 SCA 设备进行基本的设置,请使用
setup-sca
脚本。如何调用该命令取决于您要如何将 Supportconfig 存档上载到 SCA 设备服务器:如果您配置了使用
/srv/ftp/upload
目录的匿名 FTP 服务器,请结合-f
选项执行设置脚本,并遵照屏幕上的说明操作:tux >
sudo
setup-sca -f注意:使用其他目录的 FTP 服务器如果 FTP 服务器使用的目录不是
/srv/ftp/upload
,请先调整以下配置文件,使其指向正确的目录:/etc/sca/sdagent.conf
和/etc/sca/sdbroker.conf
。如果您想通过
scp
将 Supportconfig 文件上载到 SCA 设备服务器的/tmp
目录,请不带任何参数来调用该设置脚本,并遵照屏幕上的说明操作:tux >
sudo
setup-sca
该设置脚本将会根据它的要求运行一些检查,并配置所需的组件。它会提示您输入两个口令:您设置的 MariaDB 的 MySQL
root
口令,以及用于登录 SCA 设备 Web 界面的 Web 用户口令。输入现有的 MariaDB
root
口令。SCA 设备将使用该口令连接到 MariaDB。定义 Web 用户的口令。该口令将写入
/srv/www/htdocs/sca/web-config.php
,并设置为用户scdiag
的口令。以后,您可随时更改用户名和口令,请参见第 34.4.2.5.1 节 “Web 界面的口令”。
在成功完成安装和设置后,便可以开始使用 SCA 设备,请参见第 34.4.2.4 节 “使用 SCA 设备”。但是,您应该修改某些选项,例如,更改 Web 界面的口令,更改 SCA 模式更新源,启用存档模式,或者配置电子邮件通知。有关细节,请参见第 34.4.2.5 节 “自定义 SCA 设备”。
由于 SCA 设备服务器上的报告包含安全相关信息,因此,必须保护好 SCA 设备服务器上的数据,以防未经授权的人员访问。
34.4.2.4 使用 SCA 设备 #
您可以将现有的 Supportconfig 存档手动上载到 SCA 设备,也可以一步即完成创建新 Supportconfig 存档并上载到 SCA 设备的操作。可以通过 FTP 或 SCP 来上载存档。对于这两种上载方式,您需要知道可用来访问 SCA 设备的 URL。要通过 FTP 上载,需要为 SCA 设备配置一台 FTP 服务器,请参见过程 34.5 “安装和配置 SCA 设备”。
34.4.2.4.1 将 Supportconfig 存档上载到 SCA 设备 #
要创建 Supportconfig 存档并通过(匿名)FTP 上载:
tux >
sudo
supportconfig -U “ftp://SCA-APPLIANCE.COMPANY.COM/upload”要创建 Supportconfig 存档并通过 SCP 上载:
tux >
sudo
supportconfig -U “scp://SCA-APPLIANCE.COMPANY.COM/tmp”系统将提示您输入运行 SCA 设备的服务器的
root
用户口令。如果要手动上载一个或多个存档,请将现有的存档文件(通常位于
/var/log/nts_*.tbz
)复制到 SCA 设备中。对于目标,请使用设备服务器的/tmp
目录,或使用/srv/ftp/upload
目录(如果为 SCA 设备服务器配置了 FTP)。
34.4.2.4.2 查看 SCA 报告 #
可以在装有浏览器并可以访问 SCA 设备报告索引页的任何计算机上查看 SCA 报告。
启动 Web 浏览器并确保 JavaScript 和 Cookie 已启用。
输入 SCA 设备的报告索引页作为 URL。
https://sca-appliance.company.com/sca
如果有任何疑问,请咨询系统管理员。
系统将提示您输入用于登录的用户名和口令。
图 34.2︰ SCA 设备生成的 HTML 报告 #登录后,单击您想要阅读的报告的日期。
首先单击
类别将其展开。在
列中单击某一个项。SUSE 知识库中的相应文章即会打开。阅读建议的解决方案,并遵循所述的说明。如果
的 列显示了其他项,请单击这些项。阅读建议的解决方案,并遵循所述的说明。请查看 SUSE 知识库 (http://www.suse.com/support/kb/),以了解与 SCA 发现的问题直接相关的结果。设法解决这些问题。
查看可前瞻性处理的结果,以免将来发生问题。
34.4.2.5 自定义 SCA 设备 #
以下几节显示了如何更改 Web 界面的口令、更改 SCA 模式更新源、启用存档模式以及配置电子邮件通知。
34.4.2.5.1 Web 界面的口令 #
SCA 设备 Web 界面要求使用用户名和口令登录。默认的用户名为 scdiag
,默认的口令为 linux
(如果未做其他的指定,请参见过程 34.5 “安装和配置 SCA 设备”)。请尽早将默认口令更改为较为安全的口令。您也可以修改用户名。
在 SCA 设备服务器的系统控制台上以
root
用户身份登录。在编辑器中打开
/srv/www/htdocs/sca/web-config.php
。根据需要更改
$username
和$password
的值。保存文件并退出。
34.4.2.5.2 SCA 模式的更新 #
默认情况下,所有 sca-patterns-*
包将由一个 root
cron 作业来定期更新,该作业将在夜间执行 sdagent-patterns
脚本,而该脚本又会运行 zypper update sca-patterns-*
。定期的系统更新将会更新所有 SCA 设备包和模式包。要手动更新 SCA 设备和模式,请运行:
tux >
sudo
zypper update sca-*
默认情况下,将从 SUSE Linux Enterprise 15 SP1 更新储存库安装更新。如果需要,您可以将更新源更改为某台 RMT 服务器。当 sdagent-patterns
运行 zypper update sca-patterns-*
时,将从当前配置的更新通道获取更新。如果该通道在 RMT 服务器上,将从该服务器提取包。
在 SCA 设备服务器的系统控制台上以
root
用户身份登录。在编辑器中打开
/etc/sca/sdagent-patterns.conf
。将项
UPDATE_FROM_PATTERN_REPO=1
更改为
UPDATE_FROM_PATTERN_REPO=0
保存文件并退出。计算机无需重启动就能应用更改。
34.4.2.5.3 存档模式 #
系统在分析了 Supportconfig 存档并将其结果储存在 MariaDB 数据库中后,会从 SCA 设备中删除所有这些存档。但是,如果要进行查错,在计算机中保留 Supportconfig 存档的副本可能会比较实用。默认情况下,存档模式处于禁用状态。
在 SCA 设备服务器的系统控制台上以
root
用户身份登录。在编辑器中打开
/etc/sca/sdagent.conf
。将项
ARCHIVE_MODE=0
更改为
ARCHIVE_MODE=1
保存文件并退出。计算机无需重启动就能应用更改。
启用存档模式后,SCA 设备会将 Supportconfig 文件保存到 /var/log/archives/saved
目录,而不会将其删除。
34.4.2.5.4 通过电子邮件发送 SCA 报告 #
SCA 设备可通过电子邮件发送所分析的每个 Supportconfig 的 HTML 报告文件。在默认情况下禁用该功能。启用该功能后,您可以定义要将报告发送到的电子邮件地址列表。定义会触发报告发送动作的状态讯息级别 (STATUS_NOTIFY_LEVEL
)。
STATUS_NOTIFY_LEVEL
的可能值 #- $STATUS_OFF
停用发送 HTML 报告功能。
- $STATUS_CRITICAL
仅发送包含“关键”状态的 SCA 报告。
- $STATUS_WARNING
仅发送包含“警告”或“关键”状态的 SCA 报告。
- $STATUS_RECOMMEND
仅发送包含“建议”、“警告”或“关键”状态的 SCA 报告。
- $STATUS_SUCCESS
发送包含“成功”、“建议”、“警告”或“关键”状态的 SCA 报告。
在 SCA 设备服务器的系统控制台上以
root
用户身份登录。在编辑器中打开
/etc/sca/sdagent.conf
。搜索
STATUS_NOTIFY_LEVEL
项。该项默认设置为$STATUS_OFF
(禁用电子邮件通知)。要启用电子邮件通知,请将
$STATUS_OFF
更改为要针对其生成电子邮件报告的状态讯息级别,例如:STATUS_NOTIFY_LEVEL=$STATUS_SUCCESS
有关细节,请参见
STATUS_NOTIFY_LEVEL
的可能值。定义要将报告发送到的收件人列表:
搜索
EMAIL_REPORT='root'
项。将
root
替换为要向其发送 SCA 报告的电子邮件地址列表。各电子邮件地址必须以空格分隔。例如:EMAIL_REPORT='tux@my.company.com wilber@your.company.com'
保存文件并退出。计算机无需重启动就能应用更改。以后生成的所有 SCA 报告都将通过电子邮件发送到指定的地址。
34.4.2.6 备份和恢复数据库 #
要备份和恢复储存 SCA 报告的 MariaDB 数据库,请按如下所述使用 scadb
命令。scadb
由以下包提供:
sca-appliance-broker.
在运行 SCA 设备的服务器的系统控制台上以
root
用户身份登录。通过执行以下命令将设备置于维护模式:
root #
scadb maint使用以下命令启动备份进程:
root #
scadb backup数据将保存到 TAR 存档
sca-backup-*sql.gz
中。如果您正在使用模式创建数据库开发自己的模式(参见第 34.4.3 节 “开发自定义分析模式”),则还要备份以下数据:
root #
sdpdb backup数据将保存到 TAR 存档
sdp-backup-*sql.gz
中。将以下数据复制到另一台计算机或外部储存媒体:
sca-backup-*sql.gz
sdp-backup-*sql.gz
/usr/lib/sca/patterns/local
(仅当您已创建自定义模式时才需要复制该数据)
使用以下命令重新激活 SCA 设备:
root #
scadb reset agents
要基于备份恢复数据库,请按如下所述操作:
在运行 SCA 设备的服务器的系统控制台上以
root
用户身份登录。将最新的
sca-backup-*sql.gz
和sdp-backup-*sql.gz
TAR 存档复制到 SCA 设备服务器。要解压缩文件,请运行:
root #
gzip -d *-backup-*sql.gz要将数据导入数据库,请执行:
root #
scadb import sca-backup-*sql如果您正在使用模式创建数据库创建自己的模式,则还要通过以下命令导入以下数据:
root #
sdpdb import sdp-backup-*sql如果您正在使用自定义模式,则还要基于备份数据恢复
/usr/lib/sca/patterns/local
。使用以下命令重新激活 SCA 设备:
root #
scadb reset agents使用以下命令更新数据库中的模式模块:
root #
sdagent-patterns -u
34.4.3 开发自定义分析模式 #
SCA 设备随附了一个完整的模式开发环境(SCA 模式数据库),可让您开发自己的自定义模式。模式可用任何编程语言编写。要使这些模式可用于 Supportconfig 分析过程,需要将其保存到 /usr/lib/sca/patterns/local
,并使其可执行。然后,SCA 设备和 SCA 工具将会针对作为分析报告一部分的新 Supportconfig 存档运行这些自定义模式。有关如何创建(和测试)自己的模式的详细说明,请参见http://www.suse.com/communities/conversations/sca-pattern-development/。
34.5 在安装过程中收集信息 #
在安装过程中,supportconfig
不可用。不过,您可以使用 save_y2logs
从 YaST 收集日志文件。该命令会在 /tmp
目录下创建一个 .tar.xz
存档。
如果在安装过程中很早就出现问题,您或许可以从 linuxrc
创建的日志文件中收集信息。Linuxrc
是一个在 YaST 启动之前运行的小命令。该日志文件位于 /var/log/linuxrc.log
。
日志文件在安装过程中可用,但在已安装好的系统中却不可用。当安装程序仍在运行时,请正确保存安装日志文件。
34.6 内核模块支持 #
对于任何企业操作系统,一个重要的要求就是您获得的环境方面的支持级别。内核模块是硬件(“控制器”)与操作系统之间关联最密切的连接器。SUSE Linux Enterprise 中的每个内核模块都有一个 supported
标志,该标志可使用以下三个值:
“yes”,相当于
supported
“external”,相当于
supported
“”(空白,未设置),相当于
unsupported
可以使用下列规则:
默认情况下,经过自我重新编译的内核的所有模块都会标记为 unsupported。
SUSE 合作伙伴支持的内核模块以及使用
SUSE SolidDriver 程序
提供的内核模块会标记为 “external”。如果未设置
supported
标志,装载此模块便会污染该内核。系统不支持污染的内核。不支持的内核模块放在额外的 RPM 包 (kernel-FLAVOR-extra
) 中。该包仅可用于 SUSE Linux Enterprise Desktop 和 SUSE Linux Enterprise Workstation Extension。默认情况 (FLAVOR=default
|xen
|...) 下,不会装载这些内核。此外,安装程序中不会提供这些不支持的模块,并且kernel-FLAVOR-extra
包也不会包含在 SUSE Linux Enterprise 媒体中。不是根据与 Linux 内核许可证兼容的许可证提供的内核模块也会污染内核。有关细节,请参见
/usr/src/linux/Documentation/sysctl/kernel.txt
及/proc/sys/kernel/tainted
的状态。
34.6.1 技术背景 #
Linux 内核:在 SUSE Linux Enterprise
15 SP1
上,/proc/sys/kernel/unsupported
的值默认设为 2(装载不支持的模块时,syslog 中不发出警告
)。在安装程序和已安装好的系统中,均会使用此默认值。有关更多信息,请参见/usr/src/linux/Documentation/sysctl/kernel.txt
。modprobe
:用于检查模块依赖项和装载模块的modprobe
实用程序会相应地检查supported
标志的值。如果该值为 “yes” 或 “external”,则会装载该模块,否则不会。有关如何覆盖此行为的信息,请参见第 34.6.2 节 “使用不支持的模块”。注意:支持SUSE 一般不支持通过
modprobe -r
去除储存模块。
34.6.2 使用不支持的模块 #
尽管广泛可支持性非常重要,但有时会发生需要装载不支持模块的情况。例如,要进行测试或调试,或者硬件供应商提供了热修复时,就需要如此。
要覆盖默认行为,请编辑
/etc/modprobe.d/10-unsupported-modules.conf
,将变量allow_unsupported_modules
的值更改为1
。如果 initrd 中需要一个不支持的模块,请记得运行dracut
-f
来更新 initrd。如果只想尝试装载模块一次,可将
--allow-unsupported-modules
选项与modprobe
结合使用。有关更多信息,请参见modprobe
手册页。在安装期间,可通过驱动程序更新磁盘添加不支持的模块,这样便会装载这些模块。要在引导过程中及引导之后强制装载不支持的模块,请使用内核命令行选项
oem-modules
。安装和初始化suse-module-tools
包时,系统将评估内核标志TAINT_NO_SUPPORT
(/proc/sys/kernel/tainted
)。如果内核已污染,将启用allow_unsupported_modules
。这可以防止不支持的模块在安装的系统中装载失败。如果安装期间没有任何不支持的模块,并且未使用其他特殊的内核命令行选项 (oem-modules=1
),则默认行为仍是禁止不支持的模块。
请记住,装载和运行不支持的模块会导致 SUSE 不支持该内核和整个系统。
34.7 更多信息 #
man supportconfig
—supportconfig
手册页。man supportconfig.conf
— Supportconfig 配置文件的手册页。man scatool
—scatool
手册页。man scadb
—scadb
手册页。man setup-sca
—setup-sca
手册页。https://mariadb.com/kb/en/ — MariaDB 文档。
http://www.suse.com/communities/conversations/sca-pattern-development/ — 有关如何创建(和测试)您自己的 SCA 模式的说明。
http://www.suse.com/communities/conversations/basic-server-health-check-supportconfig/ — 使用 Supportconfig 的基本服务器状态检查。
https://www.novell.com/communities/coolsolutions/cool_tools/create-your-own-supportconfig-plugin/ — 创建自己的 Supportconfig 插件。
http://www.suse.com/communities/conversations/creating-a-central-supportconfig-repository/ — 创建中心 Supportconfig 储存库。
35 常见问题及其解决方案 #
本章将描述一系列可能发生的问题及其解决方法。即使您的情况并未精确地列在这里,也可能有足够相似的情况可提供解决您的问题的方法提示。
35.1 查找和收集信息 #
Linux 报告情况时是很详细的。当您的系统发生问题时,可以从几个位置查看,通常大多数是 Linux 系统的标准日志,有一些是与 SUSE Linux Enterprise Desktop 系统相关的日志。多数日志文件可以用 YaST( › )查看。
使用 YaST 可以收集支持团队所需的所有系统信息。使用
› ,然后选择问题类别。当所有信息都被集合后,将其附加在您的支持请求。
将出现最常检查的日志文件的列表,并附有其典型用途说明。包含 ~
的路径是指当前用户的用户主目录。
日志文件 |
描述 |
---|---|
|
来自当前运行的桌面应用程序的消息。 |
|
来自 AppArmor 的日志文件,详细信息请参见Book “Security and Hardening Guide”。 |
|
来自审计的日志文件,用来跟踪对系统的文件、目录或资源的任何访问,并跟踪系统调用。有关详细信息,请参见Book “Security and Hardening Guide”。 |
|
来自邮件系统的消息。 |
|
来自 NetworkManager 的日志文件通过网络连接收集问题 |
|
包含 Samba 服务器及客户端日志消息的目录。 |
|
所有来自内核与系统日志守护程序的消息为“警告”或更高级别。 |
|
包含当前计算机会话的用户登录记录的二进制文件。可使用 |
|
来自 X Window 系统的各种启动和运行时日志文件。在调试失败的 X 启动时,该日志很有用。 |
|
包含 YaST 操作及其结果的目录。 |
|
Zypper 的日志文件。 |
除了日志文件外,您的计算机还可提供关于运行中的系统的信息。请参见表 35.2: /proc
文件系统的系统信息
/proc
文件系统的系统信息 #
文件 |
描述 |
---|---|
|
包含处理器信息,包括处理器类型、制造商、型号和性能。 |
|
显示当前使用的 DMA 通道。 |
|
显示正在使用的中断和已使用的中断数量。 |
|
显示 I/O(输入/输出)内存的状态。 |
|
显示当时正在使用的 I/O 端口。 |
|
显示内存状态。 |
|
显示各个模块。 |
|
显示当前装入的设备。 |
|
显示所有硬盘的分区。 |
|
显示当前的 Linux 版本。 |
除了 /proc
文件系统外,Linux 内核还可通过 sysfs
模块(一个内存内的文件系统)导出信息。该模块表示了内核对象及其属性以及关系。有关 sysfs
的更多信息,请参见第 22 章 “使用 udev
进行动态内核设备管理” 中 udev 的环境。表 35.3 包含 /sys
下最常见目录的概述。
/sys
文件系统的系统信息 #
文件 |
描述 |
---|---|
|
包含系统中发现的每个块设备的子目录。通常多数是磁盘类设备。 |
|
包含每个物理总线类型的子目录。 |
|
包含按设备功能类型分组的子目录(如图形、网络、打印机等) |
|
包含全局设备层次结构。 |
Linux 自带了几个用于系统分析和监视的工具。请参见Book “System Analysis and Tuning Guide”, Chapter 2 “System Monitoring Utilities”以选择在系统诊断中使用的最重要的工具。
以下包含的每个情景都以一个描述问题的标题开头,后跟一两段内容,提供建议的解决方案、解决方案详细信息的参考,以及对其他可能相关的情景的交叉引用。
35.2 引导问题 #
引导问题是指系统不能正确引导时出现的情况(不能引导到预期的目标和登录屏幕)。
35.2.1 GRUB 2 引导加载程序无法装载 #
如果硬件运行正常,则可能是由于引导加载程序已损坏而使 Linux 无法在计算机上启动。在这种情况下,需要修复引导加载程序。为此,您需要按第 35.5.2 节 “使用救援系统”中所述启动救援系统,然后根据第 35.5.2.4 节 “修改和重新安装引导加载程序”中的说明操作。
另外,您可以按以下方式使用救援系统来修复引导加载程序。从安装媒体引导计算机。在引导屏幕中,选择
› 。使用默认内核选项选择包含已安装的系统和内核的磁盘。系统引导后,启动 YaST 并切换到
› 。确保启用了 选项,然后单击 。如此会通过重写来修复损坏的引导加载程序,或者安装缺失的引导加载程序。其他导致计算机无法引导的原因可能与 BIOS 相关:
- BIOS 设置
检查与硬盘相关的 BIOS 设置。如果在当前的 BIOS 设置中找不到硬盘本身,GRUB 2 可能就不能启动。
- BIOS 引导顺序
请检查您的系统引导顺序中是否包含硬盘。如果未启用硬盘选项,即使系统正确安装,在访问所需的硬盘时仍可能无法引导。
35.2.2 不出现登录或提示 #
这种情况通常在内核更新失败后发生,称为 kernel panic,原因是该过程中最后阶段有时可以在系统控制台上的错误类型。如果实际上计算机刚刚在软件更新后重引导,则当前目标是使用旧的经过验证的 Linux 版本内核和关联文件重引导。引导过程中,可以在 GRUB 引导加载程序屏幕中通过以下方式来实现此目的:
用重设置按钮重引导计算机,或关闭它之后再打开。
当 GRUB 2 引导屏幕显示时,选择
这一项,然后从菜单中选择之前的内核。计算机将使用内核的前一个版本及其关联文件引导。在引导过程完成后,使用 YaST 的第 12.3 节 “使用 YaST 配置引导加载程序”。不过,这可能并不是必须要进行的操作,因为回滚过程中自动更新工具通常会为您修改它。
模块去除新安装的内核,并根据需要将默认引导项设置为原先的内核。有关详细信息,请参见重引导.
如果这样不能修复问题,请使用安装媒体引导计算机。计算机引导之后,继续至步骤 3。
35.2.3 无图形登录 #
如果计算机能够启动,但是无法引导进入图形登录管理器,则问题可能出在默认的 systemd 目标选项或 X Window 系统的配置上。要检查当前的 systemd 默认目标,请运行命令 sudo systemctl get-default
。如果返回的值为 not
graphical.target
,请运行命令 sudo systemctl isolate graphical.target
。如果图形登录屏幕已启动,请登录并启动 › › ,然后将 设置为 。此后,系统应该能够引导进入图形登录屏幕。
如果即使已引导或者切换到图形目标,图形登录屏幕也不启动,则原因可能是您的桌面或 X Window 软件设置错误或者已损坏。请检验 /var/log/Xorg.*.log
中的日志文件,查找它尝试启动的 X 服务器发出的详细消息。如果桌面在启动期间发生错误,可能会在系统日记中记录错误讯息,您可以使用命令 journalctl
查询该日记(有关详细信息,请参见第 15 章 “journalctl
:查询 systemd
日记”)。如果这些错误消息指出问题出在 X 服务器中的配置上,请尝试修正这些问题。如果图形系统仍无法启动,请考虑重安装图形桌面。
35.2.4 无法装入 Btrfs 根分区 #
如果 btrfs
根分区已损坏,请尝试以下选项:
使用
-o recovery
选项装入该分区。如果不起使用,请在您的根分区上运行
btrfs-zero-log
。
35.2.5 强制检查根分区 #
如果根分区损坏,请在引导提示符处使用参数
forcefsck 。这样会将选项 -f
(force) 传递给 fsck
命令。
35.3 登录问题 #
登录问题是指计算机虽然引导到预期的欢迎屏幕或登录提示界面,却拒绝接受用户名和口令,或者虽然接受了用户名和口令,但是行为异常(无法启动图形桌面、发生错误或转到了命令行等)。
35.3.1 有效的用户名和口令组合失败 #
如果系统配置为使用网络身份验证或目录服务,但出于某些原因无法从为其配置的服务器上检索到结果,通常就会发生此问题。只有作为唯一本地用户的 root
用户仍能登录到这些计算机。以下是计算机看似能够运行但无法正确处理登录的常见原因:
网络出现故障。有关此问题的进一步说明,请转到第 35.4 节 “网络问题”。
DNS 在当时不起作用(这使得 GNOME 不起作用,并使系统无法向安全服务器发出经验证的请求)。如果是这种情况,则表现为计算机对任何操作的响应都需要极其长的时间。有关该主题的详细信息,请参见第 35.4 节 “网络问题”。
如果将系统配置为使用 Kerberos,则系统的本地时间与 Kerberos 服务器时间之间的差异可能超过了可接受的值(通常为 300 秒)。如果 NTP(网络时间协议)未正确地起作用,或者本地 NTP 服务器不起作用,则 Kerberos 身份验证将不再工作,因为该身份验证依赖于整个网络的通用时钟同步。
系统的身份验证配置不正确。请对相关的 PAM 配置文件进行检查以确定是否存在指令输入错误或排序错误。有关 PAM 的其他背景信息及相关配置文件的语法,请参见Book “Security and Hardening Guide”, Chapter 2 “Authentication with PAM”。
主分区是加密的。有关该主题的详细信息,请参见第 35.3.3 节 “登录至加密的主分区失败”。
在不涉及外部网络问题的所有情况下,解决方法是将系统重引导到单用户方式并修复配置,然后再次引导到操作方式并重试登录。要引导到单用户方式,请执行以下操作:
重引导系统。此时将出现引导屏幕,其中显示一个提示。
按 Esc 退出启动屏幕,并转到 GRUB 2 基于文本的菜单。
按 B 进入 GRUB 2 编辑器。
在包含内核参数的行中添加以下参数:
systemd.unit=rescue.target
按 F10。
输入
root
的用户名与口令。进行必要的一切更改。
在命令行中输入
systemctl isolate graphical.target
,以引导进入完全的多用户和网络模式。
35.3.2 有效的用户名和口令不被接受 #
这是到目前为止用户最常遇到的问题,因为有许多原因可能引起该问题。登录失败可由多种原因造成,取决于您是使用本地用户管理和身份验证,还是使用网络身份验证。
本地用户管理失败可由以下原因造成:
用户可能输入了错误的口令。
用户包含桌面配置文件的主目录已损坏或被写保护。
验证该特定用户的 X Window 系统可能存在问题,尤其是在安装当前版本之前,该用户的主目录已被其他 Linux 分发版使用时。
要找到本地登录失败的原因,请执行如下操作:
在尝试调试整个身份验证机制之前,请检查用户所记的口令是否正确。如果用户记错了口令,请使用“YaST 用户管理”模块更改其口令。注意 Caps Lock 键,如果需要请解锁。
以
root
身份登录,并使用journalctl -e
检查系统日记,找出登录过程和 PAM 的错误讯息。尝试从控制台登录(使用 Ctrl–Alt–F1)。如果成功了,则问题不在 PAM 上,因为可以在该计算机上身份验证此用户。尝试找出与 X Window 系统或 GNOME 桌面相关的任何问题。有关更多信息,请参考第 35.3.4 节 “登录成功但 GNOME 桌面发生故障”。
如果用户的主目录被其他 Linux 产品所使用,请将该用户主目录中的
Xauthority
文件删除。使用控制台登录(通过 Ctrl–Alt–F1),然后以该用户的身份运行rm .Xauthority
。这样应该可以消除该用户的 X 身份验证问题。然后再次尝试图形登录。如果桌面由于配置文件损坏而无法启动,请参见第 35.3.4 节 “登录成功但 GNOME 桌面发生故障”。
下面列出了在特定的计算机上对特定用户进行的网络身份验证可能失败的常见原因:
用户可能输入了错误的口令。
用户名存在于计算机的本地身份验证文件中,但同时网络身份验证系统也提供了该用户名,从而引起冲突。
主目录存在,但已损坏或不可用。该目录可能处于写保护状态或位于此刻无法访问的服务器上。
用户无权登录到身份验证系统中的该特定主机。
计算机出于某种原因更改了主机名,而用户无权登录到该主机。
计算机无法访问包含该用户信息的身份验证服务器或目录服务器。
验证该特定用户的 X Window 系统可能存在问题,尤其是在安装当前办法之前,该用户的主目录已被其他 Linux 分发版使用时。
要通过网络身份验证找到登录问题的原因,请执行以下步骤:
在尝试调试整个身份验证机制之前,请检查用户所记的口令是否正确。
确定计算机在身份验证时要依赖的目录服务器,并确保计算机在正常运行且与其他计算机正常通讯。
确定该用户的用户名和口令在其他计算机上是否有效,以确保存在该用户的身份验证数据且已正确分发。
确定其他用户是否可以登录到该故障计算机。如果其他用户可以正常登录,或
root
可以登录的话,请登录并使用journalctl -e
> 文件检查系统日记。找到与登录尝试相对应的时间戳记,然后确定 PAM 是否生成了任何错误消息。尝试从控制台登录(使用 Ctrl–Alt–F1)。如果成功,则问题不在用户主目录中的 PAM 或目录服务器上,因为可以在该计算机上验证此用户。尝试找出与 X Window 系统或 GNOME 桌面相关的任何问题。有关更多信息,请参考第 35.3.4 节 “登录成功但 GNOME 桌面发生故障”。
如果用户的主目录被其他 Linux 产品所使用,请将该用户主目录中的
Xauthority
文件删除。使用控制台登录(通过 Ctrl–Alt–F1),然后以该用户的身份运行rm .Xauthority
。这样应该可以消除该用户的 X 身份验证问题。然后再次尝试图形登录。如果桌面由于配置文件损坏而无法启动,请参见第 35.3.4 节 “登录成功但 GNOME 桌面发生故障”。
35.3.3 登录至加密的主分区失败 #
对于便携式计算机建议使用加密的主分区。如果无法登录到您的便携式计算机,原因通常很简单:您的分区无法解锁。
在引导时,需要输入通行口令来解锁加密的分区。如果不输入它,引导进程继续,但保持分区锁定。
要解锁您的加密分区,请如下操作:
按 Ctrl–Alt–F1 切换到文本控制台。
成为
root
用户。用以下步骤重启动解锁进程:
root #
systemctl restart home.mount输入您的通行口令以解锁加密的分区。
用 Alt–F7 退出文本控制台并切换回登录屏幕。
如常登录。
35.3.4 登录成功但 GNOME 桌面发生故障 #
如果是这种情况,可能您的 GNOME 配置文件已损坏。可能出现的症状包括键盘不起作用、屏幕几何图形变形,甚至整个屏幕变成灰色。而最重要的差别在于其他用户登录时,该计算机能正常运行。那么可能只需将用户的 GNOME 配置目录移到某个新位置,以便使 GNOME 初始化一个新的桌面,这样就能很快地解决此问题。虽然用户不得不重配置 GNOME,但不会丢失任何数据。
按Ctrl–Alt– F1 切换到文本控制台。
用您的用户名登录。
将用户的 GNOME 配置目录移到某个临时位置:
tux >
mv .gconf .gconf-ORIG-RECOVERtux >
mv .gnome2 .gnome2-ORIG-RECOVER注销。
再次登录,但别运行任何应用程序。
通过以下命令将
~/.gconf-ORIG-RECOVER/apps/
目录复制回新的~/.gconf
目录,这样就能恢复您的个人应用程序配置数据(包括 Evolution 电子邮件客户端数据):tux >
cp -a .gconf-ORIG-RECOVER/apps .gconf/如果这引起登录问题,则尝试只恢复重要的应用程序数据并重配置其他的应用程序。
35.4 网络问题 #
系统的许多问题可能都与网络相关,即使初看起来不是这样。例如,系统不允许用户登录可能是某种网络问题造成的。本节介绍一个简单的核对表,您可以使用它来确定任何所遇到的网络问题的原因。
在检查计算机的网络连接时,请执行如下操作:
如果使用的是以太网连接,请首先检查硬件。确保您的网络电缆已正确插入计算机和路由器(或集线器等)。以太网连接器旁边的控制灯通常应全部激活。
如果连接失败,请检查网线在别的计算机上是否正常。如果正常,则可能是网卡引起了该问题。如果您的网络设置中有集线器或交换机,它们也可能有故障。
如果使用的是无线连接,请检查是否可与其他计算机建立此无线链接。如果没有,请联系无线网络的管理员。
完成对基本网络连通性的检查后,请尝试找出没有响应的服务。收集设置中所需的所有网络服务器的地址信息。在相应的 YaST 模块中查找这些信息,或者询问您的系统管理员。下面列出了设置中涉及的一些典型网络服务器以及服务中断的症状。
- DNS(名称服务)
名称服务中断或发生故障会在许多方面影响网络运行。如果本地计算机依赖于任一网络服务器进行身份验证,而这些服务器由于名称解析问题而无法找到,则用户甚至还不能登录。网络中由中断的名称服务管理的计算机将无法“看到”彼此且不能通信。
- NTP(时间服务)
NTP 服务发生故障或完全中断可能会影响 Kerberos 身份验证和 X 服务器功能。
- NFS(文件服务)
如果任何应用程序所需的数据储存在 NFS 装入目录中,则一旦此服务停止或配置错误,应用程序便无法启动或正常运行。最坏的情况是,如果由于 NFS 服务器发生故障而无法找到包含
.gconf
子目录的用户主目录,则该用户主目录所属的用户的个人桌面配置将无法启动。- Samba(文件服务)
如果任何应用程序需要的数据储存在有故障的 Samba 服务器上的某个目录中,它便无法启动或正常运行。
- NIS(用户管理)
如果您的 SUSE Linux Enterprise Desktop 系统依赖有故障的 NIS 服务器提供用户数据,用户将无法登录此计算机。
- LDAP(用户管理)
如果您的 SUSE Linux Enterprise Desktop 系统依赖有故障的 LDAP 服务器提供用户数据,用户将无法登录此计算机。
- Kerberos(身份验证)
身份验证无法进行,登录至任何计算机都会失败。
- CUPS(网络打印)
用户无法打印。
请检查网络服务器是否正在运行并且您的网络设置是否允许您建立连接:
重要:限制下面介绍的调试步骤只适用于简单的网络服务器/客户端设置,不涉及任何内部路由。假设服务器和客户端都是同一子网的成员,不需要额外的路由。
使用
ping
IP_ADDRESS/HOSTNAME(用服务器的主机名或 IP 地址替换)来检查各台服务器是否正在运行,且能够对网络作出响应。如果此命令成功,表示您所查找的主机在正常运行,并且网络的名称服务配置正确。如果 ping 命令失败,同时显示消息
目标主机不可访问
,则表明您的系统或期望的服务器未正确配置或已宕机。从另一台计算机运行ping
IP address 或 YOUR_HOSTNAME 命令,来检查是否可连接您的系统。如果可以从其他计算机访问您的计算机,则表明该服务器未运行或未正确配置。如果 ping 命令失败且返回
unknown host
,则表示名称服务未正确配置或使用的主机名不正确。要对该问题进行进一步的检查,请参见步骤 4.b。如果 ping 命令仍然失败,则可能网卡未正确配置或网络硬件存在故障。请使用
host
HOSTNAME 来检查您尝试连接的服务器的主机名是否正确地转译为 IP 地址,反之亦然。如果此命令返回了该主机的 IP 地址,则名称服务已在正常运行。如果host
命令失败,请检查您主机上所有与名称和地址解析相关的网络配置文件:/var/run/netconfig/resolv.conf
此文件用于对当前使用的名称服务器和域进行跟踪。它是
/run/netconfig/resolv.conf
的符号链接,YaST 或 DHCP 通常会自动对其进行调整。请确保此文件采用以下结构,并且所有的网络地址和域名都正确无误:search FULLY_QUALIFIED_DOMAIN_NAME nameserver IPADDRESS_OF_NAMESERVER
此文件中可以包含多个名称服务器地址,但是其中必须至少有一个能够对您的主机提供正确的名称解析。如果需要,请使用 YaST 的“网络设置”模块(“主机名/DNS”选项卡)调整此文件。
如果您的网络连接是通过 DHCP 处理的,请在 YaST 的“网络设置”模块(“主机名/DNS”选项卡)中选择
(可针对所有接口全局设置,也可以逐个接口设置)和 ,以允许 DHCP 更改主机名和名称服务信息。/etc/nsswitch.conf
此文件告诉 Linux 到何处查找名称服务信息。它应显示为:
... hosts: files dns networks: files dns ...
dns
条目是必需的。它告诉 Linux 要使用外部名称服务器。通常这些项是 YaST 自动管理的,但最好谨慎地检查。如果主机上的所有相关条目均正确,请让系统管理员检查 DNS 服务器配置,以确定时区信息是否正确。如果确信主机和 DNS 服务器的 DNS 配置正确,请检查网络和网络设备的配置。
如果系统无法与网络服务器建立连接,并且已排除了名称服务出现问题的可能,则请检查网卡的配置。
使用
ip addr show
NETWORK_DEVICE 命令来检查此设备是否已正确配置。确保已正确设置带网络掩码 (/MASK
) 的inet address
。如果 IP 地址中出现错误或网络掩码中缺少一位,将使您的网络配置无法使用。如有必要,也在服务器上执行该检查。如果名称服务和网络硬件已正确配置且正在运行,但有些外部网络连接仍然长时间超时或完全失败,请使用
traceroute
FULLY_QUALIFIED_DOMAIN_NAME 命令(以root
用户的身份执行)来跟踪这些请求所经过的网络路由。此命令将列出某一请求从您的计算机传递到其目标所经过的所有网关(跳跃)。其中列出了每个跃点的响应时间以及此跃点是否可访问。请将 traceroute 和 ping 结合使用以确定故障原因并通知管理员。
确定了网络故障的原因后,就可以自行解决(如果问题出在您自己的机器上),或告诉网络系统管理员您的发现,以便其重新配置服务或修复必要的系统。
35.4.1 NetworkManager 问题 #
如果网络连接有问题,请按过程 35.1 “如何识别网络故障” 中所述缩小范围。如果 NetworkManager 看上去有问题,请执行以下步骤,以获取相关的日志来找出 NetworkManager 失败原因的线索:
以
root
用户身份打开外壳并登录。重启动 NetworkManager:
tux >
sudo
systemctl restart NetworkManager以普通用户身份打开一个网页,例如 http://www.opensuse.org,看看是否可以连接。
收集
/var/log/NetworkManager
中有关 NetworkManager 状态的任何信息。
有关 NetworkManager 的更多信息,请参考第 25 章 “使用 NetworkManager”。
35.5 数据问题 #
数据问题是指无论计算机是否能够正确引导,有一点是明确的,即系统上的数据损坏并且系统需要恢复。这些情况下需要对关键数据进行备份,以便您能够在系统出现故障时恢复故障前的状态。
35.5.1 管理分区映像 #
有时您需要从整个分区甚至硬盘来执行备份。Linux 附带了 dd
工具,该工具可用于创建磁盘的精确副本。与 gzip
一起使用可节约一些空间。
以
root
用户身份启动外壳。选择源设备。通常形如
/dev/sda
(标记为 SOURCE)。确定要把您的映像储存在何处(标记为 BACKUP_PATH)。它不能与您的源设备相同。换句话说:如果从
/dev/sda
备份,则映像文件不得储存在/dev/sda
下。运行以下命令创建压缩映像文件:
root #
dd if=/dev/SOURCE | gzip > /BACKUP_PATH/image.gz用以下命令恢复硬盘:
root #
gzip -dc /BACKUP_PATH/image.gz | dd of=/dev/SOURCE
如果只需备份某个分区,请将 SOURCE 占位符替换为相应的分区。在这种情况下,映像文件可以位于同一硬盘上不同的分区中。
35.5.2 使用救援系统 #
有多种原因会造成系统无法正常启动和运行。系统崩溃后造成文件系统损坏、配置文件损坏或引导加载程序配置损坏是最常见的原因。
为了帮助您解决这些状况,SUSE Linux Enterprise Desktop 提供了一套您可以引导的救援系统。该救援系统是一个小型 Linux 系统,可以装载到一个 RAM 磁盘并以 root 文件系统的形式装入,使您可以从外部访问 Linux 分区。使用该救援系统,可以恢复或修改系统中任何一个重要的方面:
操作任意类型的配置文件。
检查文件系统中的缺陷和启动自动修复进程。
访问“更改 root”环境下的已安装系统。
检查、修改和重新安装引导加载程序配置。
从安装有误的设备驱动程序或不可用内核恢复。
使用 parted 命令调整分区大小。在 GNU Parted 网站 http://www.gnu.org/software/parted/parted.html 上可以找到有关该工具的更多信息。
该救援系统可以从各种来源和位置进行装载。最简单的选择是从原始安装媒体上引导该救援系统。
将安装媒体插入 DVD 驱动器中。
重引导系统。
在引导屏幕上按 F4 并选择 。然后从主屏幕选择 。
在
Rescue:
提示符处输入root
。无需口令。
如果硬件设置不包含 DVD 驱动器,可以从网络源引导该救援系统。以下示例适用于远程引导的情形,如果使用另一引导媒体(例如 DVD),则要相应地修改 info
文件,并像正常安装一样进行引导。
进入 PXE 引导设置的配置界面,添加下面的行:
install=PROTOCOL://INSTSOURCE
和rescue=1
。但如果需要启动修复系统,请使用repair=1
。如同正常的安装一样,PROTOCOL 代表任何支持的网络协议(NFS、HTTP、FTP 等),INSTSOURCE 代表网络安装源的路径。如Book “Deployment Guide”, Chapter 13 “Preparing Network Boot Environment”, Section 13.5 “Using Wake-on-LAN for Remote Wakeups”中所述,使用“网络唤醒”引导系统。
在
Rescue:
提示符处输入root
。无需口令。
进入该救援系统后,可通过 Alt–F1 到 Alt–F6 键来访问虚拟控制台。
/bin
目录中提供了一个外壳和其他有用的实用程序,如 mount 程序。/sbin
目录包含重要的用于查看和修复文件系统的文件和网络实用程序。此目录还包含用于系统维护的最重要的二进制文件,如 fdisk
、mkfs
、mkswap
、mount
和 shutdown
,以及用于维护网络的 ip
和 ss
。目录 /usr/bin
包含 vi 编辑器、find、less 和 SSH。
要查看系统讯息,请使用命令 dmesg
,或使用 journalctl
查看系统日志。
35.5.2.1 检查和操作配置文件 #
举一个可以通过该救援系统修复配置的例子,假设有一个被损坏的配置文件,使该系统无法正常引导。您可以通过救援系统修复该配置文件。
要操作配置文件,请执行以下步骤:
用上述方法之一启动救援系统。
要在救援系统中装入位于
/dev/sda6
下的 root 文件系统,请使用如下命令:tux >
sudo
mount /dev/sda6 /mnt系统所有目录现在均位于
/mnt
之下将目录切换为所装入的 root 文件系统:
tux >
sudo
cd /mnt在 vi 编辑器中打开有问题的配置文件。调整并保存配置。
从救援系统中卸载 root 文件系统:
tux >
sudo
umount /mnt重引导计算机。
35.5.2.2 修复和检查文件系统 #
通常,不能在正在运行的系统上修复文件系统。如果遇到严重问题,您甚至都无法装入 root 文件系统,系统引导可能以显示 “kernel panic” 结束。在这种情况下,唯一的方法是从外部修复系统。该系统包含的实用程序可检查并修复 btrfs
、ext2
、ext3
、ext4
、xfs
、dosfs
和 vfat
文件系统。您可以试试命令 fsck.FILESYSTEM
。例如,如果需要对 btrfs
进行文件系统检查,请使用 fsck.btrfs
。
35.5.2.3 访问已安装系统 #
如果需要从救援系统访问已安装系统,需要在更改 root 环境中执行此操作。例如,修改引导加载程序配置或执行硬件配置实用程序。
要设置基于已安装系统的更改 root 环境,请执行以下步骤:
- 提示:导入 LVM 卷组
如果您使用的是 LVM 设置(有关更多一般性细节,请参见Book “Deployment Guide”, Chapter 6 “Expert Partitioner”, Section 6.2 “LVM Configuration”),请导入所有现有的卷组,以便能够查找和装入设备:
root
vgimport -a运行
lsblk
以检查哪个节点对应于根分区。在本例中,该节点为/dev/sda2
:tux >
lsblk NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT sda 8:0 0 149,1G 0 disk ├─sda1 8:1 0 2G 0 part [SWAP] ├─sda2 8:2 0 20G 0 part / └─sda3 8:3 0 127G 0 part └─cr_home 254:0 0 127G 0 crypt /home 从安装的系统装入根分区:
tux >
sudo
mount /dev/sda2 /mnt装入
/proc
、/dev
和/sys
分区:tux >
sudo
mount -t proc none /mnt/proctux >
sudo
mount --rbind /dev /mnt/devtux >
sudo
mount --rbind /sys /mnt/sys现在可以“更改根分区”为新的环境,并保留
bash
外壳:tux >
chroot /mnt /bin/bash最后,装入已安装系统的剩余分区:
tux >
mount -a现在可以访问已安装系统了。在重引导系统之前,请用
umount
-a
卸载分区并用 “exit” 退出更改 root
环境。
尽管对已安装系统的文件和应用程序有完全访问权,但仍有一些限制。运行的内核是用救援系统引导的那个,不是用更改 root 环境引导的那个。它仅支持关键硬件,如果内核版本不完全相同,则无法从已安装系统中添加内核模块。始终用 uname -r
检查当前正在运行的(救援)内核版本,然后查明更改 root 环境中 /lib/modules
目录下是否有匹配的子目录。如果是,可以使用已安装模块;否则,需要在其他媒体(例如闪盘)上提供模块的正确版本。很多时候,救援内核版本与已安装模块不同,这样您完全无法访问声卡等。也不可能启动图形用户界面。
还应注意,在使用 “F1” 到 Alt–F6 键切换控制台时,要退出Alt–更改 root环境。
35.5.2.4 修改和重新安装引导加载程序 #
有时,系统无法引导是因为引导加载程序配置已损坏。例如,如果没有正常工作的引导加载程序,启动例程将无法将物理驱动器转化为 Linux 文件系统中的实际位置。
要检查引导加载程序配置并重新安装引导加载程序,请执行以下步骤:
如第 35.5.2.3 节 “访问已安装系统” 中所述执行必要的步骤以访问已安装系统。
检查系统上是否已安装 GRUB 2 引导加载程序。如果未安装,请安装
grub2
包并运行tux >
sudo
grub2-install /dev/sda根据第 12 章 “引导加载程序 GRUB 2”中所述的 GRUB 2 配置原则,检查下列文件是否正确配置,并根据需要应用修复。
/etc/default/grub
/boot/grub2/device.map
(选用文件,手动创建后才存在)/boot/grub2/grub.cfg
(此文件是系统生成的,不要编辑)/etc/sysconfig/bootloader
使用以下命令序列重新安装引导加载程序:
tux >
sudo
grub2-mkconfig -o /boot/grub2/grub.cfg卸载分区,从“更改 root”环境中注销并重引导该系统:
tux >
umount -a exit reboot
35.5.2.5 修复内核安装 #
内核更新会产生新的 bug,这样会影响系统运行。例如,系统某个硬件的驱动程序有故障,您就无法访问和使用该硬件。在这种情况下,需还原到上一个工作内核(如果在系统上可用),或从安装媒体安装原始内核。
为了防止内核更新出现故障后无法进行引导,请使用内核多版本功能,并告知 libzypp
在更新后保留哪些内核。
例如,要始终保留最后两个内核和当前正在运行的内核,请将
multiversion.kernels = latest,latest-1,running
添加到 /etc/zypp/zypp.conf
文件。有关详细信息,请参见Book “Deployment Guide”, Chapter 18 “Installing Multiple Kernel Versions”。
类似的情况是,当您需要重新安装或更新已损坏而不受 SUSE Linux Enterprise Desktop 支持的设备驱动程序时。例如,当硬件供应商使用特定设备时,比如硬件 RAID 控制器,它需要一个二进制驱动程序才能被操作系统识别。供应商通常会发布含有固定版或更新版必要驱动程序的驱动程序更新磁盘 (DUD)。
这两种情况下,您都需要以救援模式访问已安装系统,并修复内核相关问题,否则系统可能无法正确引导:
从 SUSE Linux Enterprise Desktop 安装媒体引导。
如果您正在从内核更新故障中恢复,请跳过此步骤。如果需要使用驱动程序更新磁盘 (DUD),请在出现引导菜单后按 F6 装载驱动程序更新,并选择驱动程序更新的路径或 URL,然后确认 。
从引导菜单中选择Enter。如果选择使用 DUD,将要求您指定储存驱动程序更新的位置。
,并按在
Rescue:
提示符处输入root
。无需口令。手动将目标系统和“更改 root”装入新环境。有关详细信息,请参见第 35.5.2.3 节 “访问已安装系统”。
如果使用的是 DUD,请安装/重新安装/更新有故障的设备驱动程序包。始终确保已安装的内核版本与您正在安装的驱动程序版本完全相同。
如果要修复有故障的内核更新安装,可以从安装媒体使用以下过程安装原始内核。
使用
hwinfo --cdrom
命令确定您的 DVD 设备信息,使用mount /dev/sr0 /mnt
命令装入设备。导航到 DVD 上储存内核文件的目录,例如,
cd /mnt/suse/x86_64/
。使用
rpm -i
命令安装具有您风格的必需kernel-*
、kernel-*-base
和kernel-*-extra
包。
更新配置文件,必要时可重初始化引导加载程序。有关详细信息,请参见第 35.5.2.4 节 “修改和重新安装引导加载程序”。
从系统驱动器中删除所有可引导的媒体,然后重引导。
A 网络示例 #
此网络示例贯穿 SUSE® Linux Enterprise Desktop 文档中所有与网络相关的章节。
B GNU 许可证 #
此附录包含 GNU 自由文档许可证版本 1.2。
GNU Free Documentation License #
Copyright (C) 2000, 2001, 2002 Free Software Foundation, Inc. 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed.
0. PREAMBLE #
The purpose of this License is to make a manual, textbook, or other functional and useful document "free" in the sense of freedom: to assure everyone the effective freedom to copy and redistribute it, with or without modifying it, either commercially or non-commercially. Secondarily, this License preserves for the author and publisher a way to get credit for their work, while not being considered responsible for modifications made by others.
This License is a kind of "copyleft", which means that derivative works of the document must themselves be free in the same sense. It complements the GNU General Public License, which is a copyleft license designed for free software.
We have designed this License to use it for manuals for free software, because free software needs free documentation: a free program should come with manuals providing the same freedoms that the software does. But this License is not limited to software manuals; it can be used for any textual work, regardless of subject matter or whether it is published as a printed book. We recommend this License principally for works whose purpose is instruction or reference.
1. APPLICABILITY AND DEFINITIONS #
This License applies to any manual or other work, in any medium, that contains a notice placed by the copyright holder saying it can be distributed under the terms of this License. Such a notice grants a world-wide, royalty-free license, unlimited in duration, to use that work under the conditions stated herein. The "Document", below, refers to any such manual or work. Any member of the public is a licensee, and is addressed as "you". You accept the license if you copy, modify or distribute the work in a way requiring permission under copyright law.
A "Modified Version" of the Document means any work containing the Document or a portion of it, either copied verbatim, or with modifications and/or translated into another language.
A "Secondary Section" is a named appendix or a front-matter section of the Document that deals exclusively with the relationship of the publishers or authors of the Document to the Document's overall subject (or to related matters) and contains nothing that could fall directly within that overall subject. (Thus, if the Document is in part a textbook of mathematics, a Secondary Section may not explain any mathematics.) The relationship could be a matter of historical connection with the subject or with related matters, or of legal, commercial, philosophical, ethical or political position regarding them.
The "Invariant Sections" are certain Secondary Sections whose titles are designated, as being those of Invariant Sections, in the notice that says that the Document is released under this License. If a section does not fit the above definition of Secondary then it is not allowed to be designated as Invariant. The Document may contain zero Invariant Sections. If the Document does not identify any Invariant Sections then there are none.
The "Cover Texts" are certain short passages of text that are listed, as Front-Cover Texts or Back-Cover Texts, in the notice that says that the Document is released under this License. A Front-Cover Text may be at most 5 words, and a Back-Cover Text may be at most 25 words.
A "Transparent" copy of the Document means a machine-readable copy, represented in a format whose specification is available to the general public, that is suitable for revising the document straightforwardly with generic text editors or (for images composed of pixels) generic paint programs or (for drawings) some widely available drawing editor, and that is suitable for input to text formatters or for automatic translation to a variety of formats suitable for input to text formatters. A copy made in an otherwise Transparent file format whose markup, or absence of markup, has been arranged to thwart or discourage subsequent modification by readers is not Transparent. An image format is not Transparent if used for any substantial amount of text. A copy that is not "Transparent" is called "Opaque".
Examples of suitable formats for Transparent copies include plain ASCII without markup, Texinfo input format, LaTeX input format, SGML or XML using a publicly available DTD, and standard-conforming simple HTML, PostScript or PDF designed for human modification. Examples of transparent image formats include PNG, XCF and JPG. Opaque formats include proprietary formats that can be read and edited only by proprietary word processors, SGML or XML for which the DTD and/or processing tools are not generally available, and the machine-generated HTML, PostScript or PDF produced by some word processors for output purposes only.
The "Title Page" means, for a printed book, the title page itself, plus such following pages as are needed to hold, legibly, the material this License requires to appear in the title page. For works in formats which do not have any title page as such, "Title Page" means the text near the most prominent appearance of the work's title, preceding the beginning of the body of the text.
A section "Entitled XYZ" means a named subunit of the Document whose title either is precisely XYZ or contains XYZ in parentheses following text that translates XYZ in another language. (Here XYZ stands for a specific section name mentioned below, such as "Acknowledgements", "Dedications", "Endorsements", or "History".) To "Preserve the Title" of such a section when you modify the Document means that it remains a section "Entitled XYZ" according to this definition.
The Document may include Warranty Disclaimers next to the notice which states that this License applies to the Document. These Warranty Disclaimers are considered to be included by reference in this License, but only as regards disclaiming warranties: any other implication that these Warranty Disclaimers may have is void and has no effect on the meaning of this License.
2. VERBATIM COPYING #
You may copy and distribute the Document in any medium, either commercially or non-commercially, provided that this License, the copyright notices, and the license notice saying this License applies to the Document are reproduced in all copies, and that you add no other conditions whatsoever to those of this License. You may not use technical measures to obstruct or control the reading or further copying of the copies you make or distribute. However, you may accept compensation in exchange for copies. If you distribute a large enough number of copies you must also follow the conditions in section 3.
You may also lend copies, under the same conditions stated above, and you may publicly display copies.
3. COPYING IN QUANTITY #
If you publish printed copies (or copies in media that commonly have printed covers) of the Document, numbering more than 100, and the Document's license notice requires Cover Texts, you must enclose the copies in covers that carry, clearly and legibly, all these Cover Texts: Front-Cover Texts on the front cover, and Back-Cover Texts on the back cover. Both covers must also clearly and legibly identify you as the publisher of these copies. The front cover must present the full title with all words of the title equally prominent and visible. You may add other material on the covers in addition. Copying with changes limited to the covers, as long as they preserve the title of the Document and satisfy these conditions, can be treated as verbatim copying in other respects.
If the required texts for either cover are too voluminous to fit legibly, you should put the first ones listed (as many as fit reasonably) on the actual cover, and continue the rest onto adjacent pages.
If you publish or distribute Opaque copies of the Document numbering more than 100, you must either include a machine-readable Transparent copy along with each Opaque copy, or state in or with each Opaque copy a computer-network location from which the general network-using public has access to download using public-standard network protocols a complete Transparent copy of the Document, free of added material. If you use the latter option, you must take reasonably prudent steps, when you begin distribution of Opaque copies in quantity, to ensure that this Transparent copy will remain thus accessible at the stated location until at least one year after the last time you distribute an Opaque copy (directly or through your agents or retailers) of that edition to the public.
It is requested, but not required, that you contact the authors of the Document well before redistributing any large number of copies, to give them a chance to provide you with an updated version of the Document.
4. MODIFICATIONS #
You may copy and distribute a Modified Version of the Document under the conditions of sections 2 and 3 above, provided that you release the Modified Version under precisely this License, with the Modified Version filling the role of the Document, thus licensing distribution and modification of the Modified Version to whoever possesses a copy of it. In addition, you must do these things in the Modified Version:
Use in the Title Page (and on the covers, if any) a title distinct from that of the Document, and from those of previous versions (which should, if there were any, be listed in the History section of the Document). You may use the same title as a previous version if the original publisher of that version gives permission.
List on the Title Page, as authors, one or more persons or entities responsible for authorship of the modifications in the Modified Version, together with at least five of the principal authors of the Document (all of its principal authors, if it has fewer than five), unless they release you from this requirement.
State on the Title page the name of the publisher of the Modified Version, as the publisher.
Preserve all the copyright notices of the Document.
Add an appropriate copyright notice for your modifications adjacent to the other copyright notices.
Include, immediately after the copyright notices, a license notice giving the public permission to use the Modified Version under the terms of this License, in the form shown in the Addendum below.
Preserve in that license notice the full lists of Invariant Sections and required Cover Texts given in the Document's license notice.
Include an unaltered copy of this License.
Preserve the section Entitled "History", Preserve its Title, and add to it an item stating at least the title, year, new authors, and publisher of the Modified Version as given on the Title Page. If there is no section Entitled "History" in the Document, create one stating the title, year, authors, and publisher of the Document as given on its Title Page, then add an item describing the Modified Version as stated in the previous sentence.
Preserve the network location, if any, given in the Document for public access to a Transparent copy of the Document, and likewise the network locations given in the Document for previous versions it was based on. These may be placed in the "History" section. You may omit a network location for a work that was published at least four years before the Document itself, or if the original publisher of the version it refers to gives permission.
For any section Entitled "Acknowledgements" or "Dedications", Preserve the Title of the section, and preserve in the section all the substance and tone of each of the contributor acknowledgements and/or dedications given therein.
Preserve all the Invariant Sections of the Document, unaltered in their text and in their titles. Section numbers or the equivalent are not considered part of the section titles.
Delete any section Entitled "Endorsements". Such a section may not be included in the Modified Version.
Do not retitle any existing section to be Entitled "Endorsements" or to conflict in title with any Invariant Section.
Preserve any Warranty Disclaimers.
If the Modified Version includes new front-matter sections or appendices that qualify as Secondary Sections and contain no material copied from the Document, you may at your option designate some or all of these sections as invariant. To do this, add their titles to the list of Invariant Sections in the Modified Version's license notice. These titles must be distinct from any other section titles.
You may add a section Entitled "Endorsements", provided it contains nothing but endorsements of your Modified Version by various parties--for example, statements of peer review or that the text has been approved by an organization as the authoritative definition of a standard.
You may add a passage of up to five words as a Front-Cover Text, and a passage of up to 25 words as a Back-Cover Text, to the end of the list of Cover Texts in the Modified Version. Only one passage of Front-Cover Text and one of Back-Cover Text may be added by (or through arrangements made by) any one entity. If the Document already includes a cover text for the same cover, previously added by you or by arrangement made by the same entity you are acting on behalf of, you may not add another; but you may replace the old one, on explicit permission from the previous publisher that added the old one.
The author(s) and publisher(s) of the Document do not by this License give permission to use their names for publicity for or to assert or imply endorsement of any Modified Version.
5. COMBINING DOCUMENTS #
You may combine the Document with other documents released under this License, under the terms defined in section 4 above for modified versions, provided that you include in the combination all of the Invariant Sections of all of the original documents, unmodified, and list them all as Invariant Sections of your combined work in its license notice, and that you preserve all their Warranty Disclaimers.
The combined work need only contain one copy of this License, and multiple identical Invariant Sections may be replaced with a single copy. If there are multiple Invariant Sections with the same name but different contents, make the title of each such section unique by adding at the end of it, in parentheses, the name of the original author or publisher of that section if known, or else a unique number. Make the same adjustment to the section titles in the list of Invariant Sections in the license notice of the combined work.
In the combination, you must combine any sections Entitled "History" in the various original documents, forming one section Entitled "History"; likewise combine any sections Entitled "Acknowledgements", and any sections Entitled "Dedications". You must delete all sections Entitled "Endorsements".
6. COLLECTIONS OF DOCUMENTS #
You may make a collection consisting of the Document and other documents released under this License, and replace the individual copies of this License in the various documents with a single copy that is included in the collection, provided that you follow the rules of this License for verbatim copying of each of the documents in all other respects.
You may extract a single document from such a collection, and distribute it individually under this License, provided you insert a copy of this License into the extracted document, and follow this License in all other respects regarding verbatim copying of that document.
7. AGGREGATION WITH INDEPENDENT WORKS #
A compilation of the Document or its derivatives with other separate and independent documents or works, in or on a volume of a storage or distribution medium, is called an "aggregate" if the copyright resulting from the compilation is not used to limit the legal rights of the compilation's users beyond what the individual works permit. When the Document is included in an aggregate, this License does not apply to the other works in the aggregate which are not themselves derivative works of the Document.
If the Cover Text requirement of section 3 is applicable to these copies of the Document, then if the Document is less than one half of the entire aggregate, the Document's Cover Texts may be placed on covers that bracket the Document within the aggregate, or the electronic equivalent of covers if the Document is in electronic form. Otherwise they must appear on printed covers that bracket the whole aggregate.
8. TRANSLATION #
Translation is considered a kind of modification, so you may distribute translations of the Document under the terms of section 4. Replacing Invariant Sections with translations requires special permission from their copyright holders, but you may include translations of some or all Invariant Sections in addition to the original versions of these Invariant Sections. You may include a translation of this License, and all the license notices in the Document, and any Warranty Disclaimers, provided that you also include the original English version of this License and the original versions of those notices and disclaimers. In case of a disagreement between the translation and the original version of this License or a notice or disclaimer, the original version will prevail.
If a section in the Document is Entitled "Acknowledgements", "Dedications", or "History", the requirement (section 4) to Preserve its Title (section 1) will typically require changing the actual title.
9. TERMINATION #
You may not copy, modify, sublicense, or distribute the Document except as expressly provided for under this License. Any other attempt to copy, modify, sublicense or distribute the Document is void, and will automatically terminate your rights under this License. However, parties who have received copies, or rights, from you under this License will not have their licenses terminated so long as such parties remain in full compliance.
10. FUTURE REVISIONS OF THIS LICENSE #
The Free Software Foundation may publish new, revised versions of the GNU Free Documentation License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. See http://www.gnu.org/copyleft/.
Each version of the License is given a distinguishing version number. If the Document specifies that a particular numbered version of this License "or any later version" applies to it, you have the option of following the terms and conditions either of that specified version or of any later version that has been published (not as a draft) by the Free Software Foundation. If the Document does not specify a version number of this License, you may choose any version ever published (not as a draft) by the Free Software Foundation.
ADDENDUM: How to use this License for your documents #
Copyright (c) YEAR YOUR NAME. Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. A copy of the license is included in the section entitled “GNU Free Documentation License”.
If you have Invariant Sections, Front-Cover Texts and Back-Cover Texts, replace the “with...Texts.” line with this:
with the Invariant Sections being LIST THEIR TITLES, with the Front-Cover Texts being LIST, and with the Back-Cover Texts being LIST.
If you have Invariant Sections without Cover Texts, or some other combination of the three, merge those two alternatives to suit the situation.
If your document contains nontrivial examples of program code, we recommend releasing these examples in parallel under your choice of free software license, such as the GNU General Public License, to permit their use in free software.