4 配置和安装选项 #
本章包含服务、注册、用户和组管理、升级、分区、配置管理、SSH 密钥管理、防火墙配置及其他安装选项的配置示例。
本章介绍了用于标准用途的控制文件的重要组成部分。要了解其他可用选项,请使用配置管理系统。
请注意,要使某些配置选项有效,需要根据您已配置的软件选项安装其他软件包。如果您选择安装精简系统,则可能会缺少某些软件包,需将这些软件包添加到各个软件包选项中。
YaST 会在 AutoYaST 安装后阶段开始之前的第二个安装阶段安装所需的软件包。但是,如果所需的 YaST 模块在系统中不可用,则会跳过重要的配置步骤。例如,如果未安装 yast2-security
,则不会配置安全设置。
4.1 一般选项 #
general 部分包含影响安装工作流程的所有设置。此部分的整体结构如下所示:
<?xml version="1.0"?> <!DOCTYPE profile> <profile xmlns="http://www.suse.com/1.0/yast2ns" xmlns:config="http://www.suse.com/1.0/configns"> <general> <ask-list>1 ... </ask-list> <cio_ignore>2 ... </cio_ignore> <mode>3 ... </mode> <proposals>4 ... </proposals> <self_update>5 ... </self_update> <self_update_url> ... </self_update_url> <semi-automatic config:type="list">6 ... </semi-automatic> <signature-handling>7 ... </signature-handling> <storage>8 ... </storage> <wait>9 ... </wait> </general> <profile>
4.1.1 mode 部分 #
Mode 部分配置有关用户确认和重引导的 AutoYaST 行为。允许在 mode
部分中使用以下元素:
activate_systemd_default_target
如果您将此项设置为
false
,则不会通过调用systemd
systemctl isolate激活默认的
目标。设置此值是可选操作。默认值为true
。<general> <mode> <activate_systemd_default_target config:type="boolean"> true </activate_systemd_default_target> </mode> ... </general>
confirm
默认情况下,会在出现
屏幕时停止安装。截至此时,尚未对系统进行任何更改,可在此屏幕中更改设置。要继续操作并最终开始安装,用户需要确认设置。将此值设置为false
会自动接受设置并开始安装。只有设置为false
才能执行完全无人照管的安装。设置此值是可选操作。默认值为true
。<general> <mode> <confirm config:type="boolean">true</confirm> </mode> ... </general>
confirm_base_product_license
如果将此元素设置为
true
,则会显示基础产品的 EULA。用户需要接受此许可。否则会取消安装。设置此值是可选操作。默认设置为false
。此设置仅适用于基础产品许可。在add-on
部分使用标志confirm_license
可确认其他许可(有关细节,请参见第 4.9.3 节 “安装其他/自定义的软件包或产品”)。<general> <mode> <confirm_base_product_license config:type="boolean"> false </confirm_base_product_license> </mode> ... </general>
final_halt
如果设置为
true
,则在安装并配置所有组件后(第二个阶段结束时),计算机将会关机。如果您启用final_halt
,则不需要将final_reboot
选项设置为true
。<general> <mode> <final_halt config:type="boolean">false</final_halt> </mode> ... </general>
final_reboot
如果设置为
true
,则在安装并配置所有组件后(第二个阶段结束时),计算机将重引导。如果您启用final_reboot
,则不需要将final_halt
选项设置为true
。<general> <mode> <final_reboot config:type="boolean">true</final_reboot> </mode> ... </general>
final_restart_services
如果您将此项设置为
false
,则在安装结束时(第二个阶段结束时,此时已安装并配置好所有组件)将不重启动服务。设置此值是可选操作。默认值为true
。<general> <mode> <final_restart_services config:type="boolean"> true </final_restart_services> </mode> ... </general>
halt
完成第一阶段后关闭计算机。已安装所有软件包和引导加载程序,并已运行所有 chroot 脚本。计算机不会重引导进入第二个阶段,而是关闭。如果您再次开机,计算机将会引导,且开始第二个自动安装阶段。设置此值是可选操作。默认设置为
false
。<general> <mode> <halt config:type="boolean">false</halt> </mode> ... </general>
max_systemd_wait
指定 AutoYaST 等待
systemd
设置默认目标的最长时间(以秒为单位)。设置此值是可选操作,通常不需要设置。默认值为30
(秒)。<general> <mode> <max_systemd_wait config:type="integer">30</max_systemd_wait> </mode> ... </general>
ntp_sync_time_before_installation
指定在开始安装之前用于同步时间的 NTP 服务器。只有设置了此选项才会进行时间同步。请记住,需要建立网络连接并有权访问时间服务器。设置此值是可选操作。默认不会进行时间同步。
<general> <mode> <ntp_sync_time_before_installation> &ntpname; </max_systemd_wait> </mode> ... </general>
second_stage
常规 SUSE Linux Enterprise Server 安装在一个阶段内执行。而自动安装过程则分为两个阶段。安装基本系统后,系统将引导进入第二个阶段,系统配置在此阶段完成。将此选项设置为
false
会禁用第二个阶段。设置此值是可选操作。默认值为true
。<general> <mode> <second_stage config:type="boolean">true</second_stage> </mode> ... </general>
4.1.2 配置“安装设置”屏幕 #
AutoYaST 允许您配置proposal
标记可以控制要在安装屏幕中显示哪些设置(“建议”)。安装媒体上的 /control.xml
文件中提供了适用于您产品的有效建议列表。该设置是可选的。默认会显示所有配置选项。
<proposals config:type="list"> <proposal>partitions_proposal</proposal> <proposal>timezone_proposal</proposal> <proposal>software_proposal</proposal> </proposals>
4.1.3 self-update 部分 #
在安装期间,YaST 可以自我更新,以解决发布后所发现的安装程序 Bug。有关此功能的更多信息,请参见部署指南。
仅当您使用统一安装程序的 GM
映像和软件包 ISO 时,才能使用安装程序自我更新。如果您从作为季度更新发布的 ISO(可以根据名称中的字符串 QU
来识别)进行安装,则安装程序无法自我更新,因为此功能在更新媒体中已禁用。
使用以下标记来配置 YaST 自我更新:
self_update
如果设置为
true
或false
,此选项将启用或禁用 YaST 自我更新功能。设置此值是可选操作。默认值为true
。<general> <self_update config:type="boolean">true</self_update> ... </general>
或者,您可以在内核命令行上指定引导参数
self_update=1
。self_update_url
在 YaST 自我更新期间要使用的更新软件源的位置。有关详细信息,请参见第 8.2.2 节 “自定义自我更新软件源”。
重要:仅指定安装程序自我更新软件源只能为
self_update_url
参数指定安装程序自我更新软件源 URL。不要提供任何其他软件源 URL,例如软件更新软件源 URL。<general> <self_update_url> http://example.com/updates/$arch </self_update_url> ... </general>
该 URL 可包含变量
$arch
。该变量将由系统的体系结构(例如x86_64
、s390x
等)替换。或者,您可以在内核命令行上连同
self_update=URL
一起指定引导参数self_update=1
。
4.1.4 semi-automatic 部分 #
AutoYaST 允许在安装期间启动某些 YaST 模块。这使安装计算机的管理员可以手动配置某些安装设置,同时自动完成剩余的安装步骤。在 semi-automatic 部分可以启动以下 YaST 模块:
网络设置模块 (
networking
)分区程序 (
partitioning
)注册模块 (
scc
)
以下示例会在安装期间启动所有三个支持的 YaST 模块:
<general> <semi-automatic config:type="list"> <semi-automatic_entry>networking</semi-automatic_entry> <semi-automatic_entry>scc</semi-automatic_entry> <semi-automatic_entry>partitioning</semi-automatic_entry> </semi-automatic> </general>
4.1.5 签名处理部分 #
默认情况下,AutoYaST 只会从具有已知 GPG 密钥的源安装已签名的软件包。使用此部分可以重写默认设置。
安装未签名的软件包、未通过校验和检查的软件包或者来自您不信任的源的软件包会带来重大安全风险。软件包可能已经过修改,并可能会在您的计算机上安装恶意软件。请仅在您确认软件源和软件包可信时,才重写此部分的默认设置。对于在禁用完整性检查的情况下安装的软件所造成的任何问题,SUSE 概不负责。
所有选项的默认值均为 false。如果某个选项设置为 false,而某个软件包或软件源未通过相关测试,则会以静默方式忽略而不予安装。
accept_unsigned_file
如果设置为
true
,AutoYaST 将接受未签名的文件(例如内容文件)。<general> <signature-handling> <accept_unsigned_file config:type="boolean"> false </accept_unsigned_file> </signature-handling> ... <general>
accept_file_without_checksum
如果设置为
true
,AutoYaST 将接受内容文件中没有校验和的文件。<general> <signature-handling> <accept_file_without_checksum config:type="boolean"> false </accept_file_without_checksum> </signature-handling> ... <general>
accept_verification_failed
如果设置为
true
,即使签名校验失败,AutoYaST 也会接受这些已签名的文件。<general> <signature-handling> <accept_verification_failed config:type="boolean"> false </accept_verification_failed> </signature-handling> ... <general>
accept_unknown_gpg_key
如果设置为
true
,AutoYaST 将接受安装源的新 GPG 密钥,例如,用来对内容文件签名的密钥。<general> <signature-handling> <accept_unknown_gpg_key config:type="boolean"> false </accept_unknown_gpg_key> </signature-handling> ... <general>
accept_non_trusted_gpg_key
将此选项设置为
true
会接受您尚未信任的已知密钥。<general> <signature-handling> <accept_non_trusted_gpg_key config:type="boolean"> false </accept_non_trusted_gpg_key> </signature-handling> ... <general>
import_gpg_key
如果设置为
true
,AutoYaST 将接受安装源上的新 GPG 密钥并将其导入自身的数据库中。<general> <signature-handling> <import_gpg_key config:type="boolean"> false </import_gpg_key> </signature-handling> ... <general>
4.1.6 wait 部分 #
在第二个安装阶段,将通过运行模块来配置系统,例如网络配置。在 wait
部分内,您可以定义在特定模块运行之前和之后要执行的脚本。还可以在每个模块的前面和后面配置系统处于非活动状态(“休眠”)的时间跨度。
pre-modules
定义启动配置模块之前执行的脚本和休眠时间。以下代码演示了一个将休眠时间设置为 10 秒,并在运行网络配置模块之前执行 echo 命令的示例。
<general> <wait> <pre-modules config:type="list"> <module> <name>networking</name> <sleep> <time config:type="integer">10</time> <feedback config:type="boolean">true</feedback> </sleep> <script> <source>echo foo</source> <debug config:type="boolean">false</debug> </script> </module> </pre-modules> ... </wait> <general>
post-modules
定义启动配置模块之后执行的脚本和休眠时间。以下代码演示了一个将休眠时间设置为 10 秒,并在运行网络配置模块之后执行 echo 命令的示例。
<general> <wait> <post-modules config:type="list"> <module> <name>networking</name> <sleep> <time config:type="integer">10</time> <feedback config:type="boolean">true</feedback> </sleep> <script> <source>echo foo</source> <debug config:type="boolean">false</debug> </script> </module> </post-modules> ... </wait> <general>
4.1.7 将 IBM Z 上未用的设备加入黑名单 #
在 IBM Z 上,您可以通过运行 cio_ignore
并将未用的硬件设备加入黑名单,来防止内核查找这些设备。为此,可将同名的 AutoYaST 参数设置为 true
。设置此值是可选操作,仅适用于 IBM Z 硬件上的安装。默认设置为 false
。
<general> <cio_ignore config:type="boolean">false</cio_ignore> ... <general>
4.1.8 general
部分的示例 #
本节提供了多个用例。
本示例演示 general 部分中最常用的选项。pre-modules 和 post-modules 部分中的脚本只是用于说明概念的虚设脚本。
<?xml version="1.0"?> <!DOCTYPE profile> <profile xmlns="http://www.suse.com/1.0/yast2ns" xmlns:config="http://www.suse.com/1.0/configns"> <general> <mode> <halt config:type="boolean">false</halt> <forceboot config:type="boolean">false</forceboot> <final_reboot config:type="boolean">false</final_reboot> <final_halt config:type="boolean">false</final_halt> <confirm_base_product_license config:type="boolean"> false </confirm_base_product_license> <confirm config:type="boolean">true</confirm> <second_stage config:type="boolean">true</second_stage> </mode> <proposals config:type="list"> <proposal>partitions_proposal</proposal> </proposals> <self_update config:type="boolean">true</self_update> <self_update_url>http://example.com/updates/$arch</self_update_url> <signature-handling> <accept_unsigned_file config:type="boolean"> true </accept_unsigned_file> <accept_file_without_checksum config:type="boolean"> true </accept_file_without_checksum> <accept_verification_failed config:type="boolean"> true </accept_verification_failed> <accept_unknown_gpg_key config:type="boolean"> true </accept_unknown_gpg_key> <import_gpg_key config:type="boolean">true</import_gpg_key> <accept_non_trusted_gpg_key config:type="boolean"> true </accept_non_trusted_gpg_key> </signature-handling> <wait> <pre-modules config:type="list"> <module> <name>networking</name> <sleep> <time config:type="integer">10</time> <feedback config:type="boolean">true</feedback> </sleep> <script> <source>>![CDATA[ echo "Sleeping 10 seconds" ]]></source> <debug config:type="boolean">false</debug> </script> </module> </pre-modules> <post-modules config:type="list"> <module> <name>networking</name> <sleep> <time config:type="integer">10</time> <feedback config:type="boolean">true</feedback> </sleep> <script> <source>>![CDATA[ echo "Sleeping 10 seconds" ]]></source> <debug config:type="boolean">false</debug> </script> </module> </post-modules> </wait> </general> </profile>
4.2 报告 #
report
资源管理安装期间可能显示的三种弹出窗口:
消息弹出窗口(通常是非关键的信息性消息);
警告弹出窗口(如果可能出现问题);
错误弹出窗口(如果发生了错误)。
<report> <errors> <show config:type="boolean">true</show> <timeout config:type="integer">0</timeout> <log config:type="boolean">true</log> </errors> <warnings> <show config:type="boolean">true</show> <timeout config:type="integer">10</timeout> <log config:type="boolean">true</log> </warnings> <messages> <show config:type="boolean">true</show> <timeout config:type="integer">10</timeout> <log config:type="boolean">true</log> </messages> <yesno_messages> <show config:type="boolean">true</show> <timeout config:type="integer">10</timeout> <log config:type="boolean">true</log> </yesno_messages> </report>
您可以根据自己的经验跳过、记录和显示(结合使用超时)这些消息。建议结合使用超时显示所有 messages
。在某些情况下可以跳过警告,但不应将其忽略。
自动安装模式下的默认设置是显示错误且不设置超时,并以 10 秒超时显示所有警告/消息。
请注意,安装期间显示的消息并非全部由 report
资源控制。某些涉及到软件包安装和分区的关键消息将会忽略 report
部分中的设置直接显示出来。通常需要单击 或 来回答这些消息。
4.3 系统注册和扩展选择 #
可以在 suse_register
资源中配置于注册服务器中注册系统的操作。以下示例显示在 SUSE Customer Center 中注册系统。如果您的组织提供有自己的注册服务器,则您需要使用 reg_server*
属性指定所需的数据。有关细节,请参见下面的列表。
<suse_register> <do_registration config:type="boolean">true</do_registration> <email>tux@example.com</email> <reg_code>MY_SECRET_REGCODE</reg_code> <install_updates config:type="boolean">true</install_updates> <slp_discovery config:type="boolean">false</slp_discovery> <--! optionally register some add-ons --> <addons config:type="list"> <addon> <name>sle-module-basesystem</name> <version>15.4</version> <arch>x86_64</arch> </addon> </addons> </suse_register>
建议至少注册 Basesystem Module,以便能够访问基础系统(Linux 内核、系统库和服务)的更新。
作为全自动注册的替代方法,还可将 AutoYaST 配置为在安装期间启动 YaST 注册模块。这样就可以手动输入注册数据。需要提供以下 XML 代码:
<general> <semi-automatic config:type="list"> <semi-automatic_entry>scc</semi-automatic_entry> </semi-automatic> </general>
如果您要使用安装时所用的相同网络设置,AutoYaST 需要在启动注册前的第 1 阶段运行网络设置:
<networking> <setup_before_proposal config:type="boolean">true</setup_before_proposal> </networking>
suse_register 值
#- do_registration
布尔
<do_registration config:type="boolean">true</do_registration>
指定是否应注册系统。如果设置为
false
,则会忽略所有其他选项,并且不注册系统。电子邮件地址
<email>tux@example.com</email>
可选。与注册代码匹配的电子邮件地址。
- reg_code
文本
<reg_code>SECRET_REGCODE</reg_code>
必要。注册代码。
- install_updates
布尔
<install_updates config:type="boolean">true</install_updates>
可选。确定是否应安装来自“更新”频道的更新。默认为不安装这些更新 (
false
)。- slp_discovery
布尔
<slp_discovery config:type="boolean">true</slp_discovery>
可选。通过 SLP 搜索注册服务器。默认值为
false
。预期会查找单个服务器。如果找到多个服务器,安装将会失败。如果有多个可用的注册服务器,您需要使用
reg_server
指定一个服务器。如果
slp_discovery
和reg_server
都未设置,将在 SUSE Customer Center 中注册系统。此设置也会影响自我更新功能:如果禁用此设置,将不执行 SLP 搜索。
- reg_server
URL
<reg_server>https://smt.example.com</reg_server>
可选。RMT 服务器 URL。如果
slp_discovery
和reg_server
都未设置,将在 SUSE Customer Center 中注册系统。将从 RMT 服务器查询自我更新软件源的 URL。因此,如果未设置
self_update_url
,RMT 服务器将影响自我更新的下载位置。有关此功能的更多信息,请参见《部署指南》。- reg_server_cert_fingerprint_type
SHA1
或SHA256
<reg_server_cert_fingerprint_type>SHA1</reg_server_cert_fingerprint_type>
可选。需要通过
reg_server_cert_fingerprint
提供校验和值。建议使用指纹,因为它可以确保 SSL 证书经过校验。当 SSL 通讯由于校验错误而失败时,将自动导入匹配的证书。- reg_server_cert_fingerprint
采用十六进制表示法(不区分大小写)的服务器证书指纹值。
<reg_server_cert_fingerprint>01:AB...:EF</reg_server_cert_fingerprint>
可选。需要通过
reg_server_cert_fingerprint_type
提供指纹类型值。建议使用指纹,因为它可以确保 SSL 证书经过校验。当 SSL 通讯由于校验错误而失败时,将自动导入匹配的证书。- reg_server_cert
URL
<reg_server_cert>http://smt.example.com/smt.crt</reg_server_cert>
可选。服务器上 SSL 证书的 URL。不建议使用此选项,因为不会校验下载的证书。请改用
reg_server_cert_fingerprint
。- addons
附加产品列表
指定应添加到安装软件源的注册服务器中的扩展。有关详细信息,请参见 第 4.3.1 节 “扩展”。
要获取与 reg_server_cert_fingerprint
项配合使用的服务器证书指纹,请在 SMT 服务器上运行以下命令(如果需要,请编辑 smt.crt
文件的默认路径):
openssl x509 -noout -in /srv/www/htdocs/smt.crt -fingerprint -sha256
要从 SMT 服务器检索指纹,请使用以下命令:
curl --insecure -v https://scc.suse.com/smt.crt 2> /dev/null | openssl \ x509 -noout -fingerprint -sha256
请将 scc.suse.com
替换为您的服务器。
注意:只能在可信网络中使用此命令!在不可信的网络(例如互联网)中,应通过其他方式直接从服务器获取指纹。可通过 SSH、保存的服务器配置和其他源提取指纹。或者,您也可以校验下载的证书是否与服务器上的证书相同。
4.3.1 扩展 #
SUSE Customer Center 提供多个扩展,例如 sle-module-development-tools
(Development Tools Module),在安装期间,可作为附加源包含这些扩展。可通过 suse_register
块中的 addons
属性添加扩展。
扩展的可用性与产品和体系结构有关,并非所有扩展都可在所有体系结构上使用。
某些扩展(例如 sle-ha
)需要注册代码。根据您的订阅,请使用扩展的专用注册代码,或者重申基础产品的注册代码。
使用 SUSEConnect --list-extensions
,您可以列出注册系统中所有可用的扩展,以及用于激活和禁用这些扩展的命令。
下面的示例显示了哪些扩展已激活,并标记了需要自己的注册代码的扩展:
>
sudo
SUSEConnect --list-extensions AVAILABLE EXTENSIONS AND MODULES Basesystem Module 15 SP 4 x86_64 (Activated) Deactivate with: SUSEConnect -d -p sle-module-basesystem/15.4/x86_64 Containers Module 15 SP 4 x86_64 Activate with: SUSEConnect -p sle-module-containers/15.4/x86_64 Desktop Applications Module 15 SP 4 x86_64 (Activated) Deactivate with: SUSEConnect -d -p sle-module-desktop-applications/ 15.4/x86_64 SUSE Linux Enterprise Workstation Extension 15 SP 4 x86_64 (BETA) Activate with: SUSEConnect -p sle-we/15.4/x86_64 -r ADDITIONAL REGCODE [...]
-p
参数(在上面的示例中)显示可在 AutoYaST 配置文件中使用的 NAME/VERSION/ARCH 值。
下面的示例显示如何配置扩展列表。相应指令包含在 suse_register
块中:
<suse_register> <do_registration config:type="boolean">true</do_registration> <email>tux@example.com</email> <reg_code>MY_SECRET_REGCODE</reg_code> <install_updates config:type="boolean">true</install_updates> <slp_discovery config:type="boolean">false</slp_discovery> <--! optionally register some add-ons --> <addons config:type="list"> <addon> <!-- Development Tools Module --> <!-- Depends on: Desktop Applications Module --> <name>sle-module-development-tools</name> <version>15.3</version> <arch>x86_64</arch> </addon> <addon> <!-- SUSE CaaS Platform (BETA) --> <!-- Depends on: Containers Module --> <name>caasp</name> <version>4.0</version> <arch>x86_64</arch> <reg_code>REG_CODE_REQUIRED</reg_code> </addon> <addon> <!-- SUSE Enterprise Storage --> <!-- Depends on: Server Applications Module --> <name>ses</name> <version>6</version> <arch>x86_64</arch> <reg_code>REG_CODE_REQUIRED</reg_code> </addon> <addon> <!-- SUSE Linux Enterprise High Availability Extension --> <!-- Depends on: Server Applications Module --> <name>sle-ha</name> <version>15.3</version> <arch>x86_64</arch> <reg_code>REG_CODE_REQUIRED</reg_code> </addon> </addons> </suse_register>
您也可以在 https://scc.suse.com/packages 上查看所有可用的模块和扩展。选择您的产品和体系结构,然后单击“在模块中”表单即可查看所有扩展列表。
从 SLES 15 开始,在注册期间,AutoYaST 会根据扩展的依赖项对扩展进行重新排序。这意味着,AutoYaST 配置文件中的扩展顺序并不重要。
另外,AutoYaST 会自动注册依赖扩展,即使这些扩展在配置文件中缺失也会如此。这意味着,您不需要填写整个扩展列表。
但是,如果依赖扩展需要注册密钥,则必须在配置文件中指定这一点(包括该注册密钥)。否则注册将会失败。
扩展的体系结构和版本不是必要信息。注册工作流程将会评估合适的扩展。
4.4 引导加载程序 #
本文档用于 yast2-bootloader
,并适用于 GRUB 2。对于传统 GRUB 随附的早期产品版本,请参见 /usr/share/doc/packages/autoyast2/
中发行套件随附的文档
AutoYaST 引导加载程序部分的一般结构如下所示:
<bootloader> <loader_type> <!-- boot loader type (grub2 or grub2-efi) --> </loader_type> <global> <!-- entries defining the installation settings for GRUB 2 and the generic boot code --> </global> <device_map config:type="list"> <!-- entries defining the order of devices --> </device_map> </bootloader>
4.4.1 加载程序类型 #
此部分定义要使用哪个引导加载程序(UEFI 或 BIOS/传统)。并非所有体系结构都支持引导加载程序的传统和 EFI 这两种变体。最安全的 (default
) 选项是让安装程序做出决定。
<loader_type>LOADER_TYPE</loader_type>
LOADER_TYPE 的可能值为:
default
:安装程序选择正确的引导加载程序。未定义选项时,这是默认选项。grub2
:使用传统 BIOS 引导加载程序。grub2-efi
:使用 EFI 引导加载程序。none
:引导进程不由安装程序管理和配置。
4.4.2 全局 #
这是一个可选但又很重要的部分。在此处定义要将 GRUB 2 安装到何处以及引导进程的工作方式。同样,如果您未定义配置,yast2-bootloader
将建议一种配置。通常,AutoYaST 控制文件仅包含此部分,在安装期间 yast2-bootloader
会自动添加所有其他部分。除非您有特殊的要求,否则请不要在 XML 文件中指定引导加载程序配置。
<global> <activate>true</activate> <timeout config:type="integer">10</timeout> <terminal>gfxterm</terminal> <gfxmode>1280x1024x24</gfxmode> </global>
- activate
在引导分区上设置引导标志。如果没有单独的
/boot
分区,引导分区可以是/
。如果引导分区位于逻辑分区上,引导标志将设置为扩展分区。<activate>true</activate>
- append
在常规和恢复模式的引导项末尾添加的内核参数。
<append>nomodeset vga=0x317</append>
- boot_boot
将 GRUB 2 写入单独的
/boot
分区。如果不存在单独的/boot
分区,则会将 GRUB 2 写入/
。<boot_boot>false</boot_boot>
- boot_custom
将 GRUB 2 写入自定义设备。
<boot_custom>/dev/sda3</boot_custom>
- boot_extended
将 GRUB 2 写入扩展分区(如果您想要使用通用引导代码,而
/boot
分区是逻辑分区,则此属性非常重要)。注意:如果引导分区是逻辑分区,则您应该使用boot_mbr
(将 GRUB 2 写入 MBR)而不是generic_mbr
。<boot_extended>false</boot_extended>
- boot_mbr
按顺序将 GRUB 2 写入第一块磁盘的 MBR(
device.map
包含磁盘的顺序)。<boot_mbr>false</boot_mbr>
- boot_root
将 GRUB 2 写入
/
分区。<boot_root>false</boot_root>
- cpu_mitigations
允许选择 CPU 缓解措施内核引导命令行参数的默认设置(同时在安全性与性能之间取得平衡)。
可能的值为:
- auto
启用您的 CPU 型号所需的全部缓解策略,但不防范跨 CPU 线程的攻击。此设置可能会在一定程度上影响性能,具体视工作负载而定。
- nosmt
提供整套可用的安全缓解策略。启用您的 CPU 型号所需的全部缓解策略。此外,它还会禁用同步多线程 (SMT),以免受到跨多个 CPU 线程发起的边信道攻击。此设置可能会进一步影响性能,具体取决于工作负载。
- off
禁用所有缓解策略。CPU 可能会遭到边信道攻击,具体取决于 CPU 型号。此设置不会对性能造成任何影响。
- manual
不设置任何缓解措施级别。请使用内核命令行选项手动指定 CPU 缓解措施。
<cpu_mitigations>auto</cpu_mitigations>
如果未在 AutoYaST 中设置,可通过内核命令行更改相应设置。默认将使用安装媒体上
/control.xml
文件中的(特定于产品的)设置(如果未指定其他设置)。- generic_mbr
将通用引导代码写入 MBR(如果
boot_mbr
设置为true
,将忽略此属性)。<generic_mbr config:type="boolean">false</generic_mbr>
- gfxmode
GRUB 2 屏幕的图形分辨率(需要将 <terminal> 设置为
gfxterm
)。有效项为
auto
、HORIZONTALxVERTICAL
或HORIZONTALxVERTICALxCOLOR DEPTH
。您可以在运行中系统的 GRUB 2 命令行上,使用vbeinfo
命令来查看特定系统上的 GRUB 2 支持的屏幕分辨率。<gfxmode>1280x1024x24</gfxmode>
- os_prober
如果设置为
true
,则在安装期间会自动搜索已安装的操作系统并为其生成引导项。<os_prober>false</os_prober>
- password
如果定义了此元素,将使用口令来保护引导加载程序。除非输入口令,否则系统将不会引导。
它包含三个子元素:
value
、encrypted
和unrestricted
。vaule
用于存放口令。口令可以是纯文本,YaST 会对其进行加密,也可以是已使用grub-mkpasswd-pbkdf2
加密的口令。如果您使用已加密口令,请将encrypted
设为true
。如果
unrestricted
设为false
,用户需要输入通过value
子元素定义的口令才能引导或编辑 GRUB 2 菜单项(通过对所选引导菜单项按 E 来编辑)。如果其设为true
,用户无需输入口令即可引导系统,但需输入口令才能编辑 GRUB 2 菜单项。如果省略该选项,该选项默认设为true
。<password><value>my_strong_password</value><encrypted>false</encrypted><unrestricted>false</unrestricted></password>
- suse_btrfs
已过时,不再使用。将自动启用从 Btrfs 快照引导。
- serial
当 GRUB 2 终端模式设置为
serial
时要执行的命令。<serial>serial --speed=115200 --unit=0 --word=8 --parity=no --stop=1</serials>
- secure_boot
如果设置为
false
,则禁用 UEFI 安全引导。仅适用于grub2-efi
引导加载程序。<secure_boot>false</secure_boot>
- terminal
指定要使用的 GRUB 2 终端模式。有效的项为
console
、gfxterm
和serial
。如果设置为serial
,则还需要使用 <serial> 指定串行命令。<terminal>serial</terminal>
- timeout
在自动引导默认引导项之前经过的超时(以秒为单位)。
<timeout config:type="integer">10</timeout>
- trusted_boot
如果设置为
true
,则使用可信 GRUB。可信 GRUB 支持可信平台模块 (TPM)。仅适用于grub2
引导加载程序。<trusted_boot">true</trusted_boot>
- update_nvram
如果设置为
true
,则 AutoYaST 会在固件中添加引导加载程序对应的 NVRAM 项。除非您希望保留特定设置或需要解决固件问题,否则此为所需行为。<update_nvram>true</update_nvram>
- vgamode
将内核参数
vga=VALUE
添加到引导项。<vgamode>0x317</vgamode>
- xen_append
在 Xen Guest 的引导项末尾添加的内核参数。
<xen_append>nomodeset vga=0x317</xen_append>
- xen_kernel_append
在 VM 主机服务器上的 Xen 内核的引导项末尾添加的内核参数。
<xen_kernel_append>dom0_mem=768M</xen_kernel_append>
4.4.3 设备映射 #
GRUB 2 在生成其配置文件时,会使用设备 ID 字符串 (UUID) 或文件系统标签来避免 BIOS 驱动器与 Linux 设备之间出现映射问题。GRUB 2 实用程序会即时创建一个临时设备映射,这通常足以满足需要,在单磁盘系统上尤其如此。但是,如果您需要覆盖自动设备映射机制,请在此部分创建自定义映射。
<device_map config:type="list"> <device_map_entry> <firmware>hd0</firmware> <!-- order of devices in target map --> <linux>/dev/disk/by-id/ata-ST3500418AS_6VM23FX0</linux> <!-- name of device (disk) --> </device_map_entry> </device_map>
4.5 分区 #
在涉及到分区时,我们可以将 AutoYaST 用例分为三个不同的级别:
自动分区。用户不关心分区,并信任 AutoYaST 会采取适当的做法。
引导式分区。用户想要设置一些基本设置。例如,某个用户想要使用 LVM,但不知道如何配置分区、卷组等。
专家分区。用户指定如何布局。但是,他们不需要指定完整的定义,AutoYaST 应为缺少的部分建议合理的默认值。
在一定程度上,这类似于使用常规安装程序。您可以跳过分区屏幕并信任 YaST、使用
,或通过 定义分区布局。4.5.1 自动分区 #
无需任何用户指示,AutoYaST 可提供合理的分区布局。尽管分区布局取决于选择安装的产品,但 AutoYaST 通常会建议使用 Btrfs 根文件系统、一个使用 XFS 的独立 /home
,以及一个交换分区。此外,根据体系结构,它还会添加可能需要引导的任何分区(例如 BIOS GRUB 分区)。
但是,这些默认值可能会由于各种因素(例如可用磁盘空间)而发生变化。例如,是否具有独立的 /home
取决于可用磁盘空间量。
如果您想要影响这些默认值,可以使用第 4.5.2 节 “引导式分区”中所述的方法。
4.5.2 引导式分区 #
虽然 AutoYaST 可以在没有任何用户指示的情况下提供分区布局,但有时设置一些通用参数并让 AutoYaST 来完成其余设置是很有用的。例如,您可能想要使用 LVM 或加密文件系统,但同时又不想要处理细节。这种情况类似于在常规安装中使用引导式建议时的做法。
例 4.3 “基于 LVM 的引导式分区”中的 storage
部分指示 AutoYaST 使用 LVM 设置一个分区布局,并删除所有 Windows 分区,不管是否需要这些分区。
<general> <storage> <proposal> <lvm config:type="boolean">true<lvm> <windows_delete_mode config:type="symbol">all<windows_delete_mode> </proposal> <storage> <general>
- lvm
创建基于 LVM 的建议。默认设置为
false
。<lvm config:type="boolean">true</lvm>
- resize_windows
设置为
true
时,如果需要为安装腾出空间,AutoYaST 将调整 Windows 分区的大小。<resize_windows config:type="boolean">false</resize_windows>
- windows_delete_mode
如果设置为
none
,将不会去除 Windows 分区。如果设置为
ondemand
,将在需要时去除 Windows 分区。如果设置为
all
,将去除所有 Windows 分区。
<windows_delete_mode config:type="symbol">ondemand</windows_delete_mode>
- linux_delete_mode
如果设置为
none
,将不会去除 Linux 分区。如果设置为
ondemand
,将在需要时去除 Linux 分区。如果设置为
all
,将去除所有 Linux 分区。
<linux_delete_mode config:type="symbol">ondemand</linux_delete_mode>
- other_delete_mode
如果设置为
none
,将不会去除其他分区。如果设置为
ondemand
,将在需要时去除其他分区。如果设置为
all
,将去除所有其他分区。
<other_delete_mode config:type="symbol">ondemand</other_delete_mode>
- encryption_password
启用使用指定的口令进行加密。默认为禁用加密。
<encryption_password>some-secret</encryption_password>
4.5.3 专家分区 #
作为引导式分区的替代方案,AutoYaST 允许通过 partitioning
部分描述分区布局。但是,AutoYaST 无需知道每一项细节就能基于一个不太完整的规范构建合理的布局。
partitioning
部分是 drive
元素的列表。其中的每个部分描述分区布局的一个元素,例如磁盘、LVM 卷组、RAID、多设备 Btrfs 文件系统等。
例 4.4 “创建 /
、/home
和 swap
分区”要求 AutoYaST 使用整个磁盘创建 /
、/home
和 swap
分区。请注意,其中缺少了一些信息,例如每个分区应使用的文件系统。但这不是一个问题,因为 AutoYaST 将为缺少的项建议合理的值。
/
、/home
和 swap
分区 #<partitioning config:type="list"> <drive> <use>all</use> <partitions config:type="list"> <partition> <mount>/</mount> <size>20GiB</size> </partition> <partition> <mount>/home</mount> <size>max</size> </partition> <partition> <mount>swap</mount> <size>1GiB</size> </partition> </partitions> </drive>
AutoYaST 会检查配置文件中描述的布局是否可引导。如果不可引导,它会添加缺少的分区。因此,如果您不确定需要引导哪些分区,可以依赖 AutoYaST 做出适当的决策。
4.5.3.1 驱动器配置 #
下面列出的元素必须放在以下 XML 结构中:
<profile> <partitioning config:type="list"> <drive> ... </drive> </partitioning> </profile>
- device
可选,要配置的设备。如果留空,AutoYaST 将尝试猜测设备。有关如何影响猜测,请参见提示:跳过设备。
如果设置为
ask
,AutoYaST 将在安装期间询问用户要使用哪个设备。可以通过 ID 使用持久设备名称(例如
/dev/disk/by-id/ata-WDC_WD3200AAKS-75L9
),或者通过 by-path 使用持久设备名称(例如/dev/disk/by-path/pci-0001:00:03.0-scsi-0:0:0:0
)。<device>/dev/sda</device>
对于卷组、软件 RAID 或
bcache
设备,已安装系统中的名称可以不同(目的是避免与现有设备相冲突)。有关处理多路径设备的更多信息,请参见第 4.5.7 节 “多路径支持”。
- initialize
可选,默认值为
false
。如果设为true
,在 AutoYaST 启动分区计算之前将擦除分区表。<initialize config:type="boolean">true</initialize>
- partitions
可选,
<partition>
项的列表(请参见第 4.5.3.2 节 “分区配置”)。<partitions config:type="list"> <partition>...</partition> ... </partitions>
如果未指定任何分区,AutoYaST 将创建合理的分区布局(请参见第 4.5.3.5 节 “填补缺失”)。
- pesize
可选,仅适用于 LVM。对于 LVM 卷组,默认值为 4M。
<pesize>8M</pesize>
- use
建议使用,指定 AutoYaST 将用于对硬盘分区的策略。可选的值:
all
,计算新分区时使用整个设备。linux
,仅使用现有的 Linux 分区。free
,仅使用设备上未用的空间,现有分区保留原样。1,2,3,要使用的分区编号的逗号分隔列表。
- type
可选,指定
drive
的类型。默认值为CT_DISK
,表示普通的物理硬盘。所有选项如下:CT_DISK
,表示物理硬盘(默认值)。CT_LVM
,表示 LVM 卷组。CT_MD
,表示软件 RAID 设备。CT_DMMULTIPATH
,表示多路径设备(已弃用,隐式使用 CT_DISK)。CT_
,表示软件bcache
bcache 设备。CT_BTRFS
,表示多设备 Btrfs 文件系统。CT_NFS
,表示 NFS。CT_TMPFS
,表示tmpfs
文件系统。<type config:type="symbol">CT_LVM</type>
- disklabel
可选。默认情况下,YaST 会确定有意义的值。如果已存在其他类型的分区表,仅当该分区表不包含任何应该保留或重复使用的分区时,才会重新创建给定类型的分区表。要使用磁盘而不创建任何分区,请将此元素设置为
none
。所有选项如下:msdos
gpt
none
<disklabel>gpt</disklabel>
- keep_unknown_lv
可选,默认值为
false
。此值仅对 type=CT_LVM 驱动器有意义。如果您正在重复使用某个逻辑卷组并将此项设置为
true
,该组中的所有现有逻辑卷将保留原样,除非在 <partitioning> 部分指定了这些卷。因此,您可保留现有逻辑卷而无需进行指定。<keep_unknown_lv config:type="boolean">false</keep_unknown_lv>
- enable_snapshots
可选,默认值为
true
。在挂载到
/
的 Btrfs 文件系统上启用快照(不适用于其他文件系统,或未挂载到/
的 Btrfs 文件系统)。<enable_snapshots config:type="boolean">false</enable_snapshots>
- quotas
可选,默认值为
false
。启用 Btrfs 子卷定额支持。将此元素设为
true
会对文件系统启用定额支持。不过,您需要为每个子卷设置限额。请查看第 4.5.3.3 节 “Btrfs 子卷”了解更多信息。<quotas config:type="boolean">true</quotas>
use
属性中提供的值确定如何处理现有数据和分区。值 all
表示将擦除整个磁盘。如果您需要保留某些包含重要数据的分区,请创建备份并使用 confirm
属性。否则,不会出现任何弹出窗口来通知您将要删除分区。
在您未自行指定 <device> 项的情况下,可以影响 AutoYaST 的设备猜测。AutoYaST 通常会使用它能够找到的且看上去合理的第一个设备,但您可以将它配置为跳过某些设备,如下所示:
<partitioning config:type="list"> <drive> <initialize config:type="boolean">true</initialize> <skip_list config:type="list"> <listentry> <!-- skip devices that use the usb-storage driver --> <skip_key>driver</skip_key> <skip_value>usb-storage</skip_value> </listentry> <listentry> <!-- skip devices that are smaller than 1GB --> <skip_key>size_k</skip_key> <skip_value>1048576</skip_value> <skip_if_less_than config:type="boolean">true</skip_if_less_than> </listentry> <listentry> <!-- skip devices that are larger than 100GB --> <skip_key>size_k</skip_key> <skip_value>104857600</skip_value> <skip_if_more_than config:type="boolean">true</skip_if_more_than> </listentry> </skip_list> </drive> </partitioning>
如需所有 <skip_key> 可能值列表,请在已安装的系统上运行 yast2 ayast_probe
。
4.5.3.2 分区配置 #
下面列出的元素必须放在以下 XML 结构中:
<drive> <partitions config:type="list"> <partition> ... </partition> </partitions> </drive>
- create
指定是否必须创建此分区或逻辑卷,或者此分区或逻辑卷是否已存在。如果设为
false
,您还需要设置partition_nr
、lv_name
、label
或uuid
其中之一,以告知 AutoYaST 要使用哪个设备。<create config:type="boolean">false</create>
- crypt_method
可选,将使用以下其中一种方法加密分区:
luks1
:常规 LUKS1 加密。pervasive_luks2
:普遍加密。protected_swap
:使用非永久保护的密钥进行加密。secure_swap
:使用非永久的安全密钥进行加密。random_swap
:使用非永久的随机密钥进行加密。
<crypt_method config:type="symbol">luks1</crypt_method>
加密方法选择是在 SUSE Linux Enterprise Server 15 SP2 中引入的。要模仿先前版本的行为,请使用
luks1
。如果需要,请查看
crypt_key
元素了解如何指定加密口令。- crypt_fs
将会加密分区,默认值为
false
。此元素已弃用。请改用crypt_method
。<crypt_fs config:type="boolean">true</crypt_fs>
- crypt_key
如果已将
crypt_method
设为需要口令的方法(例如luks1
或pervasive_luks2
),则此为必要元素。<crypt_key>xxxxxxxx</crypt_key>
- mount
至少应有一个根分区 (/) 和一个交换分区。
<mount>/</mount><mount>swap</mount>
- fstopt
此分区的挂载选项,请参见
man mount
了解可用的挂载选项。<fstopt>ro,noatime,user,data=ordered,acl,user_xattr</fstopt>
- label
分区的标签。格式化设备时很有用(尤其是
mountby
参数设置为label
时),并可用于标识已存在的设备(请参见前面所述的create
)。有关示例,请参见man e2label
。<label>mydata</label>
- uuid
分区的 UUID。仅可用于标识现有设备(请参见前面所述的
create
)。不能对新设备强制使用 UUID(请参见man uuidgen
)。<uuid>1b4e28ba-2fa1-11d2-883f-b9a761bde3fb</uuid>
- size
分区的大小,例如 4G、4500M 等。/boot 分区和交换分区的大小可设为
auto
。然后,AutoYaST 将计算合理的大小。一个分区可以通过设置值max
来使用所有剩余空间。您也可以按百分比指定大小。即指定 10% 将使用 10% 的硬盘或卷组大小。如果需要,您可以混用
auto
、max
、size
和百分比。<size>10G</size>
从 SUSE Linux Enterprise Server 15 开始,所有值(包括
auto
和max
)也都可用于调整分区大小。- format
指定 AutoYaST 是否应格式化分区。如果您将
create
设置为true
,则也可能想要将此选项设置为true
。<format config:type="boolean">false</format>
- file system
可选。对于根分区 (
/
),默认值为btrfs
;对于数据分区,默认值为xfs
。指定要在此分区上使用的文件系统:btrfs
ext2
ext3
ext4
fat
xfs
swap
<filesystem config:type="symbol">ext3</filesystem>
- mkfs_options
可选,指定
mkfs
的选项字符串。请仅在您完全清楚自己所执行的操作时,才使用此元素。(请参见相关 mkfs 手册页以了解您要使用的文件系统。)<mkfs_options>-I 128</mkfs_options>
- partition_nr
此分区的编号。如果您已设置
create=false
或者要使用 LVM,则您可以通过partition_nr
指定分区。<partition_nr config:type="integer">2</partition_nr>
- partition_id
partition_id
用于设置分区的 ID。如果您要为 Linux 分区指定 131 以外的标识符,或者要为交换分区指定 130 以外的标识符,请使用partition_id
配置标识符。Linux 分区的默认 ID 为131
,交换分区的默认 ID 为130
。<partition_id config:type="integer">131</partition_id>
FAT16 (MS-DOS): 6
NTFS (MS-DOS): 7
FAT32 (MS-DOS): 12
扩展 FAT16 (MS-DOS): 15
DIAG、诊断和固件(MS-DOS、GPT): 18
PPC PReP 引导分区(MS-DOS、GPT): 65
交换(MS-DOS、GPT、DASD、隐式): 130
Linux(MS-DOS、GPT、DASD): 131
Intel Rapid Start 技术(MS-DOS、GPT): 132
LVM(MS-DOS、GPT、DASD): 142
EFI 系统分区(MS-DOS、GPT): 239
MD RAID(MS-DOS、GPT、DASD): 253
BIOS 引导 (GPT): 257
Windows 基本数据 (GPT): 258
EFI (GPT): 259
Microsoft 预留 (GPT): 261
- partition_type
可选。可用的值为
primary
(默认值)和logical
。使用msdos
分区表时,此元素可设置分区类型。值可以是primary
或logical
。使用gpt
分区表时会忽略此值,因为在此情况下不存在这种差别。<partition_type>primary</partition_type>
- mountby
如果不使用分区编号,您可以告知 AutoYaST 按
device
、label
、uuid
、path
或id
(udev 路径和 udev ID)挂载分区(请参见/dev/disk/...
)。请参见上文有关
label
和uuid
的说明。默认值取决于 YaST,通常是id
。<mountby config:type="symbol">label</mountby>
- subvolumes
要为 Btrfs 类型的文件系统创建的子卷列表。此键仅对 Btrfs 类型的文件系统有意义。(有关详细信息,请参见第 4.5.3.3 节 “Btrfs 子卷”。)
如果未为分区描述定义
subvolumes
部分,AutoYaST 将为给定的挂载点创建一组预定义的子卷。<subvolumes config:type="list"> <path>tmp</path> <path>opt</path> <path>srv</path> <path>var</path> ... </subvolumes>
- create_subvolumes
确定是否应创建 Btrfs 子卷。默认设置为
true
。如果设置为false
,则不创建子卷。- subvolumes_prefix
设置 Btrfs 子卷前缀名称。如果不需要前缀,则必须将此元素设置为空值:
<subvolumes_prefix><![CDATA[]]></subvolumes_prefix>
默认设置为
@
。- lv_name
如果此分区位于卷组中的某个逻辑卷上,请在此处指定该逻辑卷的名称(请查看驱动器配置中的
type
参数)。<lv_name>opt_lv</lv_name>
- stripes
用于配置 LVM 分段的整数。指定您要分段到多少个设备(分散数据)。
<stripes config:type="integer">2</stripes>
- stripesize
指定每个块的大小,以 KB 为单位。
<stripesize config:type="integer">4</stripesize>
- lvm_group
如果这是(部分)卷组 (LVM) 使用的物理分区,则您需要在此处指定该卷组的名称。
<lvm_group>system</lvm_group>
- pool
如果 LVM 逻辑卷应是 LVM 精简池,则
pool
必须设置为true
。<pool config:type="boolean">true</pool>
- used_pool
用作此精简逻辑卷的数据储存的 LVM 精简池名称。如果设置为非空值,则表示该卷是所谓的精简逻辑卷。
<used_pool>my_thin_pool</used_pool>
- raid_name
如果此物理卷是 RAID 阵列的一部分,请指定该 RAID 阵列的名称。
<raid_name>/dev/md/0</raid_name>
- raid_options
指定 RAID 选项。在
partition
级别设置 RAID 选项的功能已弃用。请参见第 4.5.6 节 “软件 RAID”。- bcache_backing_for
如果此设备用作
bcache
后端设备,请指定bcache
设备的名称。有关更多详细信息,请参见第 4.5.8 节 “bcache
配置”。<bcache_backing_for>/dev/bcache0</bcache_backing_for>
- bcache_caching_for
如果此设备用作
bcache
缓存设备,请指定bcache
设备的名称。有关更多详细信息,请参见第 4.5.8 节 “bcache
配置”。<bcache_caching_for config:type="list"><listentry>/dev/bcache0</listentry></bcache_caching_for>
- resize
从 SUSE Linux Enterprise Server 15 开始,调整大小功能适用于物理磁盘分区和 LVM 卷
<resize config:type="boolean">false</resize>
4.5.3.3 Btrfs 子卷 #
如第 4.5.3.2 节 “分区配置”中所述,可为每个 Btrfs 文件系统定义一组子卷。最简单的指定方式是使用路径列表:
<subvolumes config:type="list"> <path>usr/local</path> <path>tmp</path> <path>opt</path> <path>srv</path> <path>var</path> </subvolumes>
不过,您可以为每个子卷指定更多设置。例如,我们可能需要设置定额,或禁用写入时复制机制。为此,可以扩展下例所示列表中的任何元素:
<subvolumes config:type="list"> <listentry>usr/local</listentry> <listentry> <path>tmp</path> <referenced_limit>1 GiB</referenced_limit> </listentry> <listentry>opt</listentry> <listentry>srv</listentry> <listentry> <path>var/lib/pgsql</path> <copy_on_write config:type="boolean">false</copy_on_write> </listentry> </subvolumes>
path
子卷的挂载点。
<path>tmp</tmp>
必要。如果未指定
path
,AutoYaST 将忽略该子卷。copy-on-write
是否应对该子卷启用写入时复制选项。
<copy-on-write config:type="boolean">false</copy-on-write>
可选。默认值为
false
。referenced_limit
为子卷设置定额。
<referenced_limit>1 GiB</referenced_limit>
可选。默认值为
unlimited
。Btrfs 支持两种限制:referenced
和exclusive
。目前仅支持前一种限制。
如果对发行套件使用默认子卷(例如 SUSE Linux Enterprise Server 中的 @
),则会自动在所定义子卷的名称前面加上此默认子卷的名称。可以通过在第 4.5.3.1 节 “驱动器配置”中设置 subvolumes_prefix
来禁用此行为。
<subvolumes_prefix><![CDATA[]]></subvolumes_prefix>
4.5.3.4 使用整个磁盘 #
AutoYaST 允许通过将 disklabel
设置为 none
(请参见第 4.5.3.1 节 “驱动器配置”)来使用整个磁盘而不创建任何分区。在这种情况下,drive
中第一个 partition
中的配置将应用到整个磁盘。
在以下示例中,我们将使用第二个磁盘 (/dev/sdb
) 作为 /home
文件系统。
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <partitions config:type="list"> <partition> <create config:type="boolean">true</create> <format config:type="boolean">true</format> <mount>/</mount> <size>max</size> </partition> </partitions> </drive> <drive> <device>/dev/sdb</device> <disklabel>none</disklabel> <partitions config:type="list"> <partition> <format config:type="boolean">true</format> <mount>/home</mount> </partition> </partitions> </drive>
此外,还可将整个磁盘用作 LVM 物理卷或软件 RAID 成员。有关设置 LVM 或软件 RAID 的更多细节,请参见第 4.5.5 节 “逻辑卷管理器 (LVM)”和第 4.5.6 节 “软件 RAID”。
出于向后兼容的原因,可以通过将 <partition_nr>
元素设置为 0
来实现相同的效果。但是,从 SUSE Linux Enterprise Server 15 开始,已弃用 <partition_nr>
元素的这种用法。
4.5.3.5 填补缺失 #
使用
方法时,AutoYaST 可以基于一个不太完整的配置文件创建分区计划。以下配置文件演示了如何描述分区布局的一些细节,然后让 AutoYaST 完成余下的操作。下面是单个驱动器系统的示例,该驱动器未预先分区,应根据描述的预定义分区计划进行自动分区。如果您未指定设备,系统将自动检测设备。
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <use>all</use> </drive> </partitioning>
有一个更详细的示例演示了如何处理现有分区和多个驱动器。
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <use>all</use> <partitions config:type="list"> <partition> <mount>/</mount> <size>10G</size> </partition> <partition> <mount>swap</mount> <size>1G</size> </partition> </partitions> </drive> <drive> <device>/dev/sdb</device> <use>free</use> <partitions config:type="list"> <partition> <filesystem config:type="symbol">ext4</filesystem> <mount>/data1</mount> <size>15G</size> </partition> <partition> <filesystem config:type="symbol">xfs</filesystem> <mount>/data2</mount> <size>auto</size> </partition> </partitions> </drive> </partitioning>
4.5.4 高级分区功能 #
4.5.4.1 擦除分区表 #
通常不需要执行此操作,因为 AutoYaST 可以自动地逐个删除分区。但是,您需要使用相应的选项来让 AutoYaST 清除分区表,而不是逐个删除分区。
转到 drive
部分并添加:
<initialize config:type="boolean">true</initialize>
指定此设置后,AutoYaST 会先删除分区表,然后再开始分析实际分区并计算其分区计划。当然,这也意味着您无法保留任何现有分区。
4.5.4.2 挂载选项 #
默认情况下,要挂载的文件系统在 /etc/fstab
中按设备名称标识。可以更改此标识,以便通过搜索 UUID 或卷标来查找文件系统。请注意,并非所有文件系统都可按 UUID 或卷标挂载。要指定如何挂载分区,请使用具有 symbol
类型的 mountby
属性。可能的选项为:
device
(默认值)label
UUID
如果您选择使用标签挂载新分区,请使用 label
属性指定其值。
在 /etc/fstab
的第四个字段中添加任何有效挂载选项。用逗号分隔多个选项。可能的 fstab 选项:
- 只读挂载 (
ro
) 对文件系统没有写入访问权限。默认为
false
。- 不更新访问时间 (
noatime
) 读取文件时不更新访问时间。默认为
false
。- 可由用户挂载 (
user
) 文件系统可由普通用户挂载。默认为
false
。- 数据日志模式(
ordered
、journal
、writeback
) journal
在将所有数据写入主文件系统之前将其提交到日志。
ordered
在将所有数据的元数据提交到日志之前,将所有数据直接写入主文件系统。
writeback
不保留数据顺序。
- 访问控制列表 (
acl
) 在文件系统上启用访问控制列表。
- 扩展用户属性 (
user_xattr
) 在文件系统上允许扩展用户属性。
<partitions config:type="list"> <partition> <filesystem config:type="symbol">ext4</filesystem> <format config:type="boolean">true</format> <fstopt>ro,noatime,user,data=ordered,acl,user_xattr</fstopt> <mount>/local</mount> <mountby config:type="symbol">uuid</mountby> <partition_id config:type="integer">131</partition_id> <size>10G</size> </partition> </partitions>
不同的文件系统类型支持不同的选项。请在设置选项之前,请仔细查看相关文档。
4.5.4.3 保留特定的分区 #
在某些情况下,您应该将分区保留原样,仅格式化特定的目标分区,而不要从头开始创建分区。例如,如果有不同的 Linux 安装共存,或者您安装了另一个操作系统,则您可能不想要擦除这些分区。您还可能想要将数据分区保留原样。
此类方案要求对目标系统和硬盘有专门的了解。根据具体的方案,您可能需要知道目标硬盘的确切分区表及其分区 ID、大小和编号。有了这些数据,您便可以告知 AutoYaST 保留特定的分区、格式化其他分区,并根据需要创建新分区。
以下示例将保留分区 1、2、5,并删除分区 6 以创建两个新分区。所有剩余分区只会格式化。
<partitioning config:type="list"> <drive> <device>/dev/sdc</device> <partitions config:type="list"> <partition> <create config:type="boolean">false</create> <format config:type="boolean">true</format> <mount>/</mount> <partition_nr config:type="integer">1</partition_nr> </partition> <partition> <create config:type="boolean">false</create> <format config:type="boolean">false</format> <partition_nr config:type="integer">2</partition_nr> <mount>/space</mount> </partition> <partition> <create config:type="boolean">false</create> <format config:type="boolean">true</format> <filesystem config:type="symbol">swap</filesystem> <partition_nr config:type="integer">5</partition_nr> <mount>swap</mount> </partition> <partition> <format config:type="boolean">true</format> <mount>/space2</mount> <size>5G</size> </partition> <partition> <format config:type="boolean">true</format> <mount>/space3</mount> <size>max</size> </partition> </partitions> <use>6</use> </drive> </partitioning>
最后一个示例要求确切地了解应保留的分区的现有分区表和分区编号。但在某些情况下,可能不提供此类数据,尤其是在使用不同硬盘类型和配置的混合硬件环境中。以下方案适用于采用非 Linux 操作系统并可提供指定的区域进行 Linux 安装的系统。
在此方案中,如图 4.1 “保留分区”所示,AutoYaST 不会创建新分区,而是在系统上搜索特定的分区类型,并根据控制文件中的分区计划使用这些分区类型。在本例中未指定分区编号,而仅指定了挂载点和分区类型(可以提供其他配置数据,例如文件系统选项、加密和文件系统类型)。
<partitioning config:type="list"> <drive> <partitions config:type="list"> <partition> <create config:type="boolean">false</create> <format config:type="boolean">true</format> <mount>/</mount> <partition_id config:type="integer">131</partition_id> </partition> <partition> <create config:type="boolean">false</create> <format config:type="boolean">true</format> <filesystem config:type="symbol">swap</filesystem> <partition_id config:type="integer">130</partition_id> <mount>swap</mount> </partition> </partitions> </drive> </partitioning>
当 AutoYaST 探测储存设备时,尚未分析配置文件中的 partitioning 部分。在某些方案中,无法清楚地知道要使用哪个密钥来解锁设备。例如,定义了多个加密密钥时,就可能会发生这种情况。为了解决此问题,AutoYaST 会尝试所有已加密设备上定义的所有密钥,直到找到有效的密钥。
4.5.5 逻辑卷管理器 (LVM) #
要配置 LVM,请先使用前面所述的常规分区方法创建一个物理卷。
以下示例演示如何在 partitioning
资源中准备 LVM。将在类型为 LVM
并包含卷组 system
的设备 /dev/sda1
上创建一个未格式化的分区。此分区将使用驱动器上的所有可用空间。
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <partitions config:type="list"> <partition> <create config:type="boolean">true</create> <lvm_group>system</lvm_group> <partition_type>primary</partition_type> <partition_id config:type="integer">142</partition_id> <partition_nr config:type="integer">1</partition_nr> <size>max</size> </partition> </partitions> <use>all</use> </drive> </partitioning>
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <partitions config:type="list"> <partition> <lvm_group>system</lvm_group> <partition_type>primary</partition_type> <size>max</size> </partition> </partitions> <use>all</use> </drive> <drive> <device>/dev/system</device> <type config:type="symbol">CT_LVM</type> <partitions config:type="list"> <partition> <filesystem config:type="symbol">ext4</filesystem> <lv_name>user_lv</lv_name> <mount>/usr</mount> <size>15G</size> </partition> <partition> <filesystem config:type="symbol">ext4</filesystem> <lv_name>opt_lv</lv_name> <mount>/opt</mount> <size>10G</size> </partition> <partition> <filesystem config:type="symbol">ext4</filesystem> <lv_name>var_lv</lv_name> <mount>/var</mount> <size>1G</size> </partition> </partitions> <pesize>4M</pesize> <use>all</use> </drive> </partitioning>
对于逻辑卷,可将 size
设置为 max
。当然,只能为一个逻辑卷使用 max
。无法将一个卷组中的两个逻辑卷都设置为 max
。
4.5.6 软件 RAID #
对软件 RAID 设备的支持在 SUSE Linux Enterprise Server 15 SP2 中已得到很大改进。
如果需要,请参见第 4.5.6.1 节 “使用已弃用的语法”来了解有关指定软件 RAID 的旧方法的更多细节,出于向后兼容考虑,这种旧方法仍受支持。
使用 AutoYaST 可以创建和组装软件 RAID 设备。支持的 RAID 级别如下:
- RAID 0
此级别可提高磁盘性能。此模式不提供冗余。如果某个驱动器崩溃,将无法恢复数据。
- RAID 1
此模式提供最佳冗余。在两个或更多个磁盘上可使用此模式。在所有磁盘上保留所有数据的精确副本。只要至少有一个磁盘仍可正常工作,就不会丢失数据。用于此 RAID 类型的分区大小应大致相同。
- RAID 5
此模式结合了更多磁盘的管理功能,同时仍可保持一定程度的冗余。在三个或更多个磁盘上可使用此模式。如果有一个磁盘发生故障,所有数据仍将保持不变。如果两个磁盘同时发生故障,所有数据都会丢失。
- 多路径
此模式允许通过多个控制器访问同一物理设备,以提供冗余来防止控制器卡故障。在至少两个设备上可使用此模式。
类似于 LVM,AutoYaST 配置文件中的软件 RAID 定义由两个不同的部分构成:
确定要将哪些磁盘或分区用作 RAID 成员。为此,您需要在此类设备中设置
raid_name
元素。使用专用的
drive
部分定义 RAID 本身。
以下示例演示了一种 RAID1 配置,该配置使用第一和第二个磁盘中的各一个分区作为 RAID 成员:
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <partitions config:type="list"> <partition> <mount>/</mount> <size>20G</size> </partition> <partition> <raid_name>/dev/md/0</raid_name> <size>max</size> </partition> </partitions> <use>all</use> </drive> <drive> <device>/dev/sdb</device> <disklabel>none</disklabel> <partitions config:type="list"> <partition> <raid_name>/dev/md/0</raid_name> </partition> </partitions> <use>all</use> </drive> <drive> <device>/dev/md/0</device> <partitions config:type="list"> <partition> <mount>/home</mount> <size>40G</size> </partition> <partition> <mount>/srv</mount> <size>10G</size> </partition> </partitions> <raid_options> <chunk_size>4</chunk_size> <parity_algorithm>left_asymmetric</parity_algorithm> <raid_type>raid1</raid_type> </raid_options> <use>all</use> </drive> </partitioning>
如果您不想在软件 RAID 中创建分区,请将 disklabel
设置为 none
,就像对常规磁盘所做那样。在以下示例中,为简洁起见,仅显示了 RAID drive
部分:
<drive> <device>/dev/md/0</device> <disklabel>none</disklabel> <partitions config:type="list"> <partition> <mount>/home</mount> <size>40G</size> </partition> </partitions> <raid_options> <chunk_size>4</chunk_size> <parity_algorithm>left_asymmetric</parity_algorithm> <raid_type>raid1</raid_type> </raid_options> <use>all</use> </drive>
4.5.6.1 使用已弃用的语法 #
如果启用了安装程序自我更新功能,则可以将 SUSE Linux Enterprise Server 15 的软件 RAID 分区。但是,该方案在以前的版本中不受支持,因此定义软件 RAID 的方法略有不同。
本节定义了旧式配置的样式,出于向后兼容的原因,仍然支持这种配置。
使用这种已弃用的语法配置 RAID 时请注意以下几点:
RAID 的设备始终是
/dev/md
。属性
partition_nr
用于确定 MD 设备编号。如果partition_nr
等于 0,则配置/dev/md/0
。添加多个partition
部分表示您想要配置多个软件 RAID(/dev/md/0
、/dev/md/1
等)。所有特定于 RAID 的选项都包含在
raid_options
资源中。
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <partitions config:type="list"> <partition> <partition_id config:type="integer">253</partition_id> <format config:type="boolean">false</format> <raid_name>/dev/md0</raid_name> <raid_type>raid1</raid_type> <size>4G</size> </partition> <!-- Insert a configuration for the regular partitions located on /dev/sda here (for example / and swap) --> </partitions> <use>all</use> </drive> <drive> <device>/dev/sdb</device> <partitions config:type="list"> <partition> <format config:type="boolean">false</format> <partition_id config:type="integer">253</partition_id> <raid_name>/dev/md0</raid_name> <size>4gb</size> </partition> </partitions> <use>all</use> </drive> <drive> <device>/dev/md</device> <partitions config:type="list"> <partition> <filesystem config:type="symbol">ext4</filesystem> <format config:type="boolean">true</format> <mount>/space</mount> <partition_id config:type="integer">131</partition_id> <partition_nr config:type="integer">0</partition_nr> <raid_options> <chunk_size>4</chunk_size> <parity_algorithm>left_asymmetric</parity_algorithm> </raid_options> </partition> </partitions> <use>all</use> </drive> </partitioning>
4.5.6.2 RAID 选项 #
以下元素必须放在以下 XML 结构中:
<partition> <raid_options> ... </raid_options> </partition>
- chunk_size
<chunk_size>4</chunk_size>
- parity_algorithm
可能的值为:
left_asymmetric
、left_symmetric
、right_asymmetric
或right_symmetric
。对于 RAID6 和 RAID10,可使用以下值:
parity_first
、parity_last
、left_asymmetric_6
、left_symmetric_6
、right_asymmetric_6
、right_symmetric_6
、parity_first_6
、n2
、o2
、f2
、n3
、o3
或f3
。<parity_algorithm>left_asymmetric</parity_algorithm>
- raid_type
可能的值为:
raid0
、raid1
、raid5
、raid6
和raid10
。<raid_type>raid1</raid_type>
默认值为
raid1
。- device_order
此列表包含物理设备的顺序:
<device_order config:type="list"><device>/dev/sdb2</device><device>/dev/sda1</device>...</device_order>
这是可选元素,默认采用字母顺序。
4.5.7 多路径支持 #
AutoYaST 可以处理多路径设备。要利用此类设备,您需要按照例 4.16 “使用多路径设备”中所示启用多路径支持。或者,可以在内核命令行上使用以下参数:LIBSTORAGE_MULTIPATH_AUTOSTART=ON
。
与 SUSE Linux Enterprise 12 不同,无需将 drive 部分类型设置为 CT_DMMULTIPATH
。而应使用 CT_DISK
,不过出于历史原因,这两个值是等效的。
<general> <storage> <start_multipath config:type="boolean">true</start_multipath> </storage> </general> <partitioning> <drive> <partitions config:type="list"> <partition> <size>20G</size> <mount>/</mount> <filesystem config:type="symbol">ext4</filesystem> </partition> <partition> <size>auto</size> <mount>swap</mount> </partition> </partitions> <type config:type="symbol">CT_DISK</type> <use>all</use> </drive> </partitioning>
如果您要指定设备,可以使用全球标识符 (WWID)、其设备名称(例如 /dev/dm-0
)、/dev/disk
下表示该多路径设备的任何其他路径,或者设备的任何路径。
以例 4.17 “列出多路径设备”中的 multipath
列表为例,您可以使用 /dev/mapper/14945540000000000f86756dce9286158be4c6e3567e75ba5
、/dev/dm-3
、/dev/disk
下的任何其他对应路径(如例 4.18 “使用 WWID 标识多路径设备”中所示),或设备的任何路径(/dev/sda
或 /dev/sdb
)。
# multipath -l 14945540000000000f86756dce9286158be4c6e3567e75ba5 dm-3 ATA,VIRTUAL-DISK size=40G features='0' hwhandler='0' wp=rw |-+- policy='service-time 0' prio=1 status=active | `- 2:0:0:0 sda 8:0 active ready running `-+- policy='service-time 0' prio=1 status=enabled `- 3:0:0:0 sdb 8:16 active ready running
<drive> <partitions config:type="list"> <device>/dev/mapper/14945540000000000f86756dce9286158be4c6e3567e75ba5</device> <partition> <size>20G</size> <mount>/</mount> <filesystem config:type="symbol">ext4</filesystem> </partition> </partitions> <type config:type="symbol">CT_DISK</type> <use>all</use> </drive>
4.5.8 bcache
配置 #
bcache
是允许使用多个快速驱动器来加速访问一个或多个慢速驱动器的缓存系统。例如,您可以使用一个快速驱动器作为缓存,来改善一个较大(但较慢)驱动器的性能。
有关 SUSE Linux Enterprise Server 上的 bcache 的详细信息,另请参见 https://www.suse.com/c/combine-the-performance-of-solid-state-drive-with-the-capacity-of-a-hard-drive-with-bcache-and-yast/ 上的博客文章。
要设置 bcache
设备,AutoYaST 需要一个指定了以下设置的配置文件:
要将某个(慢速)块设备设置为后端设备,请使用
bcache_backing_for
元素。要将某个(快速)块设备设置为缓存设备,请使用
bcache_caching_for
元素。您可以使用同一设备来加速访问多个驱动器。要指定
bcache
设备的布局,请使用drive
部分,并将type
元素设置为CT_BCACHE
。bcache
设备的布局可以包含分区。
bcache
定义 #<partitioning config:type="list"> <drive> <device>/dev/sda</device> <type config:type="symbol">CT_DISK</type> <use>all</use> <enable_snapshots config:type="boolean">true</enable_snapshots> <partitions config:type="list"> <partition> <filesystem config:type="symbol">btrfs</filesystem> <mount>/</mount> <create config:type="boolean">true</create> <size>max</size> </partition> <partition> <filesystem config:type="symbol">swap</filesystem> <mount>swap</mount> <create config:type="boolean">true</create> <size>2GiB</size> </partition> </partitions> </drive> <drive> <type config:type="symbol">CT_DISK</type> <device>/dev/sdb</device> <disklabel>msdos</disklabel> <use>all</use> <partitions config:type="list"> <partition> <!-- It can serve as caching device for several bcaches --> <bcache_caching_for config:type="list"> <listentry>/dev/bcache0</listentry> </bcache_caching_for> <size>max</size> </partition> </partitions> </drive> <drive> <type config:type="symbol">CT_DISK</type> <device>/dev/sdc</device> <use>all</use> <disklabel>msdos</disklabel> <partitions config:type="list"> <partition> <!-- It can serve as backing device for one bcache --> <bcache_backing_for>/dev/bcache0</bcache_backing_for> </partition> </partitions> </drive> <drive> <type config:type="symbol">CT_BCACHE</type> <device>/dev/bcache0</device> <bcache_options> <cache_mode>writethrough</cache_mode> </bcache_options> <use>all</use> <partitions config:type="list"> <partition> <mount>/data</mount> <size>20GiB</size> </partition> <partition> <mount>swap</mount> <filesystem config:type="symbol">swap</filesystem> <size>1GiB</size> </partition> </partitions> </drive> </partitioning>
目前,bcache_options
部分中唯一支持的选项是下面所述的 cache_mode
。
- cache_mode
bcache
的缓存模式。可能的值为:writethrough
writeback
writearound
none
<cache_mode>writethrough</cache_mode>
4.5.9 多设备 Btrfs 配置 #
Btrfs 支持创建跨越多个储存设备的单个卷,提供与软件 RAID 实现类似的功能,例如 Linux 内核的内置 mdraid
子系统。多设备 Btrfs 比其他某些 RAID 实现更具优势。例如,可将多设备 Btrfs 卷从一个 RAID 级别动态迁移到另一个 RAID 级别、可按文件设置 RAID 级别等。但是,并非所有这些功能在 SUSE Linux Enterprise Server 15 SP 4 中仍受到完全支持。
使用 AutoYaST 时,可以通过指定 CT_BTRFS
类型的驱动器来配置多设备 Btrfs。device
属性用作标识每个多设备 Btrfs 的任意名称。
使用 RAID 时,您需要先创建所有块设备(例如分区、LVM 逻辑卷等),然后将它们指派给要在此类块设备上创建的 Btrfs 文件系统。
以下示例演示了一种简单的多设备 Btrfs 配置:
<partitioning config:type="list"> <drive> <device>/dev/sda</device> <disklabel>none</disklabel> <partitions> <partition> <btrfs_name>root_fs</btrfs_name> </partition> </partitions> <use>all</use> </drive> <drive> <device>/dev/sdb</device> <disklabel>gpt</disklabel> <partitions> <partition> <partition_nr>1</partition_nr> <size>4gb</size> <filesystem>ext4</filesystem> <btrfs_name>root_fs</btrfs_name> </partition> </partitions> <use>all</use> </drive> <drive> <device>root_fs</device> <type config:type="symbol">CT_BTRFS</type> <partitions> <partition config:type="list> <mount>/</mount> </partition> </partitions> <btrfs_options> <raid_leve>raid1</raid_level> <metadata_raid_leve>raid1</metadata_raid_level> </btrfs_options> </drive> </partitioning>
支持的数据和元数据 RAID 级别为:default
、single
、dup
、raid0
、raid1
和 raid10
。默认情况下,文件系统元数据会在两个设备中镜像,而数据会在所有设备间分条。如果只存在一个设备,则在这一个设备上复制元数据。
配置多设备 Btrfs 文件系统时请记住以下几点:
设备需要指明
btrfs_name
属性才能包含到多设备 Btrfs 文件系统中。所有 Btrfs 特定的选项都包含在
CT_BTRFS
驱动器的btrfs_options
资源中。
4.5.10 NFS 配置 #
AutoYaST 允许将 SUSE Linux Enterprise Server 安装到网络文件系统 (NFS) 共享中。为此,您必须创建 CT_NFS
类型的驱动器,并提供 NFS 共享名 (SERVER:PATH) 作为设备名称。与挂载点相关的信息包含在其第一个 partition 部分中。请注意,对于 NFS 驱动器,只会考虑第一个分区。
有关安装系统后如何配置 NFS 客户端和服务器的详细信息,请参见第 4.20 节 “NFS 客户端和服务器”。
<partitioning config:type="list"> <drive> <device>192.168.1.1:/exports/root_fs</device> <type config:type="symbol">CT_NFS</type> <use>all</use> <partitions config:type="list"> <partition> <mount>/</mount> <fstopt>nolock</fstopt> </partition> </partitions> </drive> </partitioning>
4.5.11 tmpfs
配置 #
如果将 type
元素设为 CT_TMPFS
,AutoYaST 将可支持 tmpfs
虚拟文件系统定义。每个 partition
部分都代表一个 tmpfs
文件系统。
tmpfs
定义 #<partitioning config:type="list"> <drive> <type config:type="symbol">CT_TMPFS</type> <partitions config:type="list"> <partition> <mount>/srv</mount> <fstopt>size=512M</fstopt> </partition> <partition> <mount>/temp</mount> </partition> </partitions> <drive> <partitioning>
tmpfs
设备与普通文件系统(如 Ext4 或 Btrfs)不同。因此,仅有的相关元素是 mount
(必要)和 fstopt
。后者用于设置文件系统属性,例如其大小限制、模式等。tmpfs
手册页中提供了有关已知选项的更多信息。
4.5.12 特定于 IBM Z 的配置 #
4.5.12.1 配置 DASD 磁盘 #
下面列出的元素必须放在以下 XML 结构中:
<dasd> <devices config:type="list"> <listentry> ... </listentry> </devices> </dasd>
<profile> 部分中的标记。需在单独的 <listentry> ... </listentry> 部分配置每个磁盘。
- device
DASD
是唯一允许的值.<device>DASD</dev_name>
- dev_name
指定要在此部分中配置的设备 (
dasdN
)。<dev_name>/dev/dasda</dev_name>
可选,但建议指定。如果留空,AutoYaST 将尝试猜测设备。
- channel
用于访问磁盘的通道。
<channel>0.0.0150</channel>
必需。
- diag
启用或禁用
DIAG
。可能的值为true
(启用)或false
(禁用)。<diagconfig:type="boolean">true</diag>
可选。
4.5.12.2 配置 zFCP 磁盘 #
以下元素必须放在以下 XML 结构中:
<profile> <zfcp> <devices config:type="list"> <listentry> ... </listentry> </devices> </zfcp> <profile>
需在单独的 listentry
部分配置每个磁盘。
- controller_id
通道编号
<controller_id>0.0.fc00</controller_id>
controller_id
元素是必要元素。
可选元素有两个,分别是 wwpn
(全球端口号,用于挂接 SCSI 设备的目标端口)和 fcp_lun
(SCSI 设备的逻辑单元号)。对于在 NPIV(节点端口 ID 虚拟化)模式下运行的 FCP 设备,以及 zfcp 模块参数 allow_lun_scan
设为 1(默认设置,可让 zfcp 设备驱动程序自动进行 LUN 扫描)的情况,不需要指定这些选项。
如果自动 LUN 扫描功能不可用,请手动设置 wwpn
和 fcp_lun
选项。
- wwpn
全球端口号
<wwpn>0x500507630300c562</wwpn>
- fcp_lun
逻辑单元号
<fcp_lun>0x4010403200000000</fcp_lun>
有关详细信息,请参见相应 IBM 文档: https://www.ibm.com/docs/en/linux-on-systems?topic=wsd-configuring-devices。
4.6 iSCSI 发起端概述 #
使用 iscsi-client
资源可将目标计算机配置为 iSCSI 客户端。
<iscsi-client> <initiatorname>iqn.2013-02.de.suse:01:e229358d2dea</initiatorname> <targets config:type="list"> <listentry> <authmethod>None</authmethod> <portal>192.168.1.1:3260</portal> <startup>onboot</startup> <target>iqn.2001-05.com.doe:test</target> <iface>default</iface> </listentry> </targets> <version>1.0</version> </iscsi-client>
- initiatorname
InitiatorName
的值取自/etc/iscsi/initiatorname.iscsi
。如果您使用 iBFT,则会从 iBFT 添加此值,您只能在 BIOS 设置中更改此值。- version
YaST 模块的版本。默认值:1.0
- targets
目标列表。每个项包含:
- authmethod
身份验证方法:None/CHAP
- portal
门户地址
- startup
值:manual/onboot
- target
目标名称
- iface
接口名称
4.7 以太网光纤通道 (FCoE) 配置 #
使用 fcoe_cfg
资源可以配置以太网光纤通道 (FCoE)。
<fcoe-client> <fcoe_cfg> <DEBUG>no</DEBUG> <USE_SYSLOG>yes</USE_SYSLOG> </fcoe_cfg> <interfaces config:type="list"> <listentry> <dev_name>eth3</dev_name> <mac_addr>01:000:000:000:42:42</mac_addr> <device>Gigabit 1313</device> <vlan_interface>200</vlan_interface> <fcoe_vlan>eth3.200</fcoe_vlan> <fcoe_enable>yes</fcoe_enable> <dcb_required>yes</dcb_required> <auto_vlan>no</auto_vlan> <dcb_capable>no</dcb_capable> <cfg_device>eth3.200</cfg_device> </listentry> </interfaces> <service_start> <fcoe config:type="boolean">true</fcoe> <lldpad config:type="boolean">true</lldpad> </service_start> </fcoe-client>
- fcoe_cfg
值:
yes
/no
DEBUG
用于启用或禁用 fcoe 服务脚本和 fcoemon 发出的调试消息。如果设置为 yes,则会将
USE_SYSLOG
消息发送到系统日志。- interfaces
网卡列表,包括 VLAN 和 FCoE 配置的状态。
- service_start
值:
yes
/no
启用或禁用在引导时启动
fcoe
和lldpad
服务。启动
fcoe
服务意味着启动以太网光纤通道服务守护程序fcoemon
,该守护程序用于控制 FCoE 接口并建立与lldpad
守护程序的连接。lldpad
服务提供链接层发现协议代理守护程序lldpad
,该守护程序会向fcoemon
告知有关 DCB(数据中心桥接)功能以及接口的配置。
4.8 国家/地区设置 #
语言、时区和键盘设置。
<language> <language>en_GB</language> <languages>de_DE,en_US</languages> </language>
- language
主要语言
- languages
逗号分隔的次要语言
/usr/share/YaST2/data/languages
中提供了可用语言列表。
如果主要语言的配置值未知,它将被重设置为默认值 en_US
。
<timezone> <hwclock>UTC</hwclock> <timezone>Europe/Berlin</timezone> </timezone>
- hwclock
硬件时钟使用的是本地时间还是 UTC。
值:
localtime
/UTC
。- timezone
时区。
在
/usr/share/YaST2/data/timezone_raw.ycp
下可以找到可用时区的列表
<keyboard> <keymap>german</keymap> </keyboard>
- keymap
键盘布局
键映射代码值或键映射别名值均有效。在
/usr/share/YaST2/data/keyboards.rb
中可以找到可用项的列表。例如english-us、us、english-uk、uk
。
4.9 软件 #
4.9.1 产品选择 #
从 SUSE Linux Enterprise Server 15 开始,所有产品都是使用单个安装媒体分发的。因此,您需要使用 product
标记选择要安装的产品。
product
标记的可用值为:
- SLES
SUSE Linux Enterprise Server
- SLE_HPC
SUSE Linux Enterprise High Performance Computing
- SLE_RT
SUSE Linux Enterprise Real Time
- SLES_SAP
SUSE Linux Enterprise Server for SAP Applications
- SLED
SUSE Linux Enterprise Desktop
- SUSE-manager-server
SUSE Manager Server
- SUSE-manager-retail-branch-server
SUSE Manager for Retail
- SUSE-manager-proxy
SUSE Manager Proxy
在以下示例中,所选择的产品为 SUSE Linux Enterprise Desktop:
<software> <products config:type="list"> <product>SLED</product> </products> </software>
在特殊情况下,媒体可能只包含一个产品。如果是这样,则您无需按上面所述显式选择产品。AutoYaST 将自动选择唯一可用的产品。
如果您正在使用或迁移旧版 SUSE Linux Enterprise Server 中的 AutoYaST 配置文件,请注意一些特殊注意事项。有关细节,请参见第 D.1 节 “产品选择”。
4.9.2 使用 patterns 和 packages 部分选择软件包 #
软件集或软件包的配置如下所示:
<software> <patterns config:type="list"> <pattern>directory_server</pattern> </patterns> <packages config:type="list"> <package>apache</package> <package>postfix</package> </packages> <do_online_update config:type="boolean">true</do_online_update> </software>
这些值是真实的软件包或软件集名称。如果软件包名称由于升级而发生更改,则您也需要调整这些设置。
4.9.3 安装其他/自定义的软件包或产品 #
除了 DVD-ROM 中可供安装的软件包以外,您还可以添加外部软件包(包括自定义的内核)。自定义的内核软件包必须与 SUSE 软件包兼容,并且内核文件必须安装到相同的位置。
与先前版本不同,您无需在控制文件中使用特殊的资源即可安装自定义和外部软件包。不过,您需要重新创建软件包数据库,并使用源软件源中的任何新软件包或新软件包版本更新该数据库。
我们提供了一个脚本用于完成此任务。该脚本会查询软件源中提供的软件包并创建软件包数据库。使用命令 /usr/bin/create_package_descr
。openSUSE Build Service 的 inst-source-utils
软件包中提供了此脚本。创建数据库时,所有语言将重设置为英语。
解压缩的 DVD 位于 /usr/local/DVDs/LATEST
中。
>
cp /tmp/inst-source-utils-2016.7.26-1.2.noarch.rpm /usr/local/DVDs/LATEST/suse/noarch>
cd /usr/local/DVDs/LATEST/suse>
create_package_descr -d /usr/local/CDs/LATEST/suse
在上面的示例中,/usr/local/CDs/LATEST/suse
目录包含与体系结构相关的软件包(例如 x86_64
)以及与体系结构不相关的软件包 (noarch
)。在其他体系结构上,可能并不相同。
此方法的优势是可以保留包含固定软件包和已更新软件包的最新软件源。此外,此方法可以简化自定义 CD-ROM 的创建。
要添加您自己的模块,例如 SDK (SUSE Software Development Kit),请将文件 add_on_products.xml
添加到安装源的根目录中。
以下示例演示如何将 SDK 模块添加到基础产品软件源。完整的 SDK 软件源将储存在目录 /sdk
中。
add_on_products.xml
#此文件描述基础产品中包含的 SDK 模块。
<?xml version="1.0"?> <add_on_products xmlns="http://www.suse.com/1.0/yast2ns" xmlns:config="http://www.suse.com/1.0/configns"> <product_items config:type="list"> <product_item> <name>SUSE Linux Enterprise Software Development Kit</name> <url>relurl:////sdk?alias=SLE_SDK</url> <path>/</path> <-- Users are asked whether to add such a product --> <ask_user config:type="boolean">false</ask_user> <-- Defines the default state of pre-selected state in case of ask_user used. --> <selected config:type="boolean">true</selected> </product_item> </product_items> </add_on_products>
除这种特殊情况外,在安装 AutoYaST 期间,还几乎可以从其他每个位置添加所有其他模块、扩展和附加产品。
如果您要使用注册服务器(SMT、RMT 或 SCC)提供的附加产品,请在 suse_register
部分定义这些附加产品。请参见第 4.3.1 节 “扩展”。
在安装期间甚至可以添加没有任何产品或模块信息的软件源。这些软件源称为其他附加项
。
<add-on> <add_on_products config:type="list"> <listentry> <media_url>cd:///sdk</media_url> <product>sle-sdk</product> <alias>SLE SDK</alias> <product_dir>/</product_dir> <priority config:type="integer">20</priority> <ask_on_error config:type="boolean">false</ask_on_error> <confirm_license config:type="boolean">false</confirm_license> <name>SUSE Linux Enterprise Software Development Kit</name> </listentry> </add_on_products> <add_on_others config:type="list"> <listentry> <media_url>https://download.opensuse.org/repositories/YaST:/Head/openSUSE_Leap_15.2/</media_url> <alias>yast2_head</alias> <priority config:type="integer">30</priority> <name>Latest YaST2 packages from OBS</name> </listentry> </add_on_others> </add-on>
add_on_others
和 add_on_products
部分支持相同的值:
- media_url
产品 URL。可包含
cd:///
、http://
、ftp://
等前缀。此项必须指定。如果您使用 SUSE Linux Enterprise Packages DVD 等多产品媒体,则 URL 路径应指向多产品媒体的根目录。使用
product_dir
值选择特定的产品目录(参见下文)。- product
内部产品名(如果附加项是产品)。命令
zypper products
显示已安装产品的名称。- alias
软件源别名。由用户定义。
- product_dir
可选的子路径。此项只可用于 SUSE Linux Enterprise Packages DVD 等多产品媒体。
- priority
设置软件源 libzypp 优先级。1 是最高优先级。数字越大,优先级越低。默认值为 99。
- ask_on_error
在给定的位置找不到软件源时,AutoYaST 可以要求用户提供附加产品、模块或扩展,而不是报告超时错误。请将
ask_on_error
设为true
(默认值为false
)。- confirm_license
用户需要确认许可。默认为
false
。- name
软件源名称。命令
zypper lr
显示已添加的软件源的名称。
要在 AutoYaST 中使用未签名的安装源,请在 AutoYaST 控制文件中使用以下配置关闭检查。
只能在自动安装过程的第一个阶段禁用签名检查。在第二个阶段,已安装系统的配置将优先于 AutoYaST 配置。
下面列出的元素必须放在以下 XML 结构中:
<general> <signature-handling> ... </signature-handling> </general>
所有选项的默认值均为 false
。如果某个选项设置为 false
,而某个软件包或软件源未通过相关测试,则会以静默方式忽略而不予安装。请注意,将其中的任何选项设置为 true
都有可能带来安全风险。使用第三方源提供的软件包或软件源时请勿这样做。
- accept_unsigned_file
如果设为
true
,AutoYaST 将接受未签名的文件,例如内容文件。<accept_unsigned_file config:type="boolean" >true</accept_unsigned_file>
- accept_file_without_checksum
如果设置为
true
,AutoYaST 将接受内容文件中没有校验和的文件。<accept_file_without_checksum config:type="boolean" >true</accept_file_without_checksum>
- accept_verification_failed
如果设置为
true
,即使签名校验失败,AutoYaST 也会接受这些已签名的文件。<accept_verification_failed config:type="boolean" >true</accept_verification_failed>
- accept_unknown_gpg_key
如果设置为
true
,AutoYaST 将接受安装源的新 GPG 密钥,例如,用来对内容文件签名的密钥。<accept_unknown_gpg_key config:type="boolean" >true</accept_unknown_gpg_key>
- accept_non_trusted_gpg_key
将此选项设置为
true
会接受您尚未信任的已知密钥。<accept_non_trusted_gpg_key config:type="boolean" >true</accept_non_trusted_gpg_key>
- import_gpg_key
如果设置为
true
,AutoYaST 将接受安装源上的新 GPG 密钥并将其导入自身的数据库中。<import_gpg_key config:type="boolean" >true</import_gpg_key>
可以单独配置每个附加产品、模块或扩展的签名处理。以下元素必须位于各个附加产品、模块或扩展的 signature-handling
部分之间。所有设置都是可选的。如果未配置,将使用 general
部分中的全局签名处理方式。
- accept_unsigned_file
如果设为
true
,AutoYaST 将接受未签名的文件,例如此附加产品的内容文件。<accept_unsigned_file config:type="boolean" >true</accept_unsigned_file>
- accept_file_without_checksum
如果设置为
true
,AutoYaST 将接受此附加产品的内容文件中没有校验和的文件。<accept_file_without_checksum config:type="boolean" >true</accept_file_without_checksum>
- accept_verification_failed
如果设置为
true
,即使签名校验失败,AutoYaST 也会接受这些已签名的文件。<accept_verification_failed config:type="boolean" >true</accept_verification_failed>
- accept_unknown_gpg_key
如果
all
设置为true
,AutoYaST 将接受安装源上的新 GPG 密钥。<accept_unknown_gpg_key> <all config:type="boolean">true</all> </accept_unknown_gpg_key>
或者,您可以定义单个密钥:
<accept_unknown_gpg_key> <all config:type="boolean">false</all> <keys config:type="list"> <keyid>3B3011B76B9D6523</keyid> lt;/keys> </accept_unknown_gpg_key>
- accept_non_trusted_gpg_key
这表示密钥已知,但不受您的信任。可以通过添加以下命令来信任所有密钥:
<accept_non_trusted_gpg_key> <all config:type="boolean">true</all> </accept_non_trusted_gpg_key>
或者,您可以信任特定的密钥:
<accept_non_trusted_gpg_key> <all config:type="boolean">false</all> <keys config:type="list"> <keyid>3B3011B76B9D6523</keyid> </keys> </accept_non_trusted_gpg_key>
- import_gpg_key
如果
all
设置为true
,AutoYaST 将接受安装源上的所有新 GPG 密钥并将其导入自身的数据库中。<import_gpg_key> <all config:type="boolean">true</all> </import_gpg_key>
只能对特定的密钥执行此操作:
<import_gpg_key> <all config:type="boolean">false</all> <keys config:type="list"> <keyid>3B3011B76B9D6523</keyid> </keys> </import_gpg_key>
4.9.4 内核软件包 #
内核软件包不在任何选项内。所需内核是在安装期间确定的。如果将内核软件包添加到任何选项或单个软件包选项,安装基本上都会由于冲突而失败。
要强制安装特定的内核,请使用 kernel
属性。下面是强制安装默认内核的示例。即使需要 SMP 或其他内核,也会安装此内核。
<software> <kernel>kernel-default</kernel> ... </software>
4.9.5 去除自动选择的软件包 #
某些软件包是由于存在依赖关系或者可供选择而被自动选择的。
去除这些软件包可能会破坏系统一致性,除非已获得可提供相同服务的替代软件包,否则不建议去除基本软件包。邮件传输代理 (MTA) 软件包就是其中最典型的示例。默认会选择并安装 postfix
。要使用其他 MTA(例如 sendmail
),可以使用软件资源中的列表从选定软件包列表中去除 postfix。但请注意,SUSE Linux Enterprise Server 并未随附 sendmail。以下示例演示了如何执行此操作:
<software> <packages config:type="list"> <package>sendmail</package> </packages> <remove-packages config:type="list"> <package>postfix</package> </remove-packages> </software>
请注意,无法去除某个软件集中的软件包(请参见第 4.9.2 节 “使用 patterns 和 packages 部分选择软件包”)。如果指定去除此类软件包,安装将会失败并出现以下错误消息:
The package resolver run failed. Check your software section in the AutoYaST profile.
4.9.6 安装推荐的软件包和软件集 #
使用 AutoYaST,您可以控制安装哪些推荐的软件包和软件集。共有三个选项:
安装所有推荐的软件包和软件集
仅安装必需的软件包和软件集
安装推荐的软件包,忽略推荐的软件集
在配置文件中将 install_recommended
标志设为 true
会安装所有推荐的软件包和软件集。
如果您想要一个极简安装,并且只安装必需的软件包和软件集,请将该标志设为 false
。
在配置文件中省略该标志将只安装推荐的软件包,会忽略所有推荐的软件集。请注意,此标志只会影响全新安装,在升级期间将被忽略。
<software> <install_recommended config:type="boolean">false </install_recommended> </software>
4.9.7 在第 2 个阶段安装软件包 #
要在第二个阶段重引导后安装软件包,可以使用 post-packages
元素:
<software> <post-packages config:type="list"> <package>yast2-cim</package> </post-packages> </software>
4.9.8 在第 2 个阶段安装软件集 #
您还可以在第 2 个阶段安装软件集。为此,请使用 post-patterns
元素:
<software> <post-patterns config:type="list"> <pattern>apparmor</pattern> </post-patterns> </software>
4.9.9 在第 2 个阶段联机更新 #
可以在安装结束时执行联机更新。请将 do_online_update
布尔值设置为 true
。当然,仅当您在 suse-register/customer-center 部分或者安装后脚本中添加了联机更新软件源时,此设置才起作用。如果已通过 add-on 部分在第一个阶段提供了联机更新软件源,则 AutoYaST 应已安装了可用的最新软件包。如果内核更新是通过联机更新完成的,则第二个阶段结束时会触发重引导。
<software> <do_online_update config:type="boolean">true</do_online_update> </software>
4.10 升级 #
AutoYaST 还可用于执行系统升级。除升级软件包以外,还支持以下部分:
scripts/pre-scripts
在所有其他操作实际发生之前的早期阶段运行用户脚本。add-on
定义其他附加产品。language
设置语言。timezone
设置时区。keyboard
设置键盘。software
安装其他软件/软件集。去除已安装的软件包。suse_register
运行注册过程。
要控制升级过程,可定义以下部分:
<upgrade> <stop_on_solver_conflict config:type="boolean">true</stop_on_solver_conflict> </upgrade> <backup> <sysconfig config:type="boolean">true</sysconfig> <modified config:type="boolean">true</modified> <remove_old config:type="boolean">true</remove_old> </backup>
- stop_on_solver_conflict
出现软件包依赖性问题时暂停安装。
- modified
创建已修改文件的备份。
- sysconfig
创建
/etc/sysconfig
目录的备份。- remove_old
从先前的更新中去除备份。
要启动 AutoYaST 升级模式,您需要:
将 AutoYaST 配置文件复制到其文件系统上的
/root/autoupg.xml
中。从安装媒体引导系统。
选择
安装
菜单项。在命令行上设置
autoupgrade=1
。按 Enter 启动升级过程。
从安装媒体引导系统。
选择
安装
菜单项。在命令行上设置
netsetup=dhcp autoupgrade=1 autoyast=http://192.169.3.1/autoyast.xml
。此处将通过 DHCP 设置网络。
按 Enter 启动升级过程。
4.11 服务和目标 #
使用 services-manager
资源可以设置默认的 systemd 目标,并详细指定要启动或停用哪些系统服务及其启动方式。
default-target
属性指定系统要引导进入的默认 systemd 目标。有效选项为 graphical
(图形登录)或 multi-user
(控制台登录)。
要指定引导时应启动的一组服务,请使用 enable
和 disable
列表。要启动某个服务,请将其名称添加到 enable
列表。要确保该服务在引导时不会启动,请将其添加到 disable
列表。
如果某个服务未列为启用或禁用,将使用默认设置。默认设置可以是禁用也可以是启用。
最后,某些服务(例如 cups
)支持按需激活(套接字激活的服务)。如果您想要利用此类功能,请在 on_demand
列表而不是 enable
中列出这些服务的名称。
<services-manager> <default_target>multi-user</default_target> <services> <disable config:type="list"> <service>libvirtd</service> </disable> <enable config:type="list"> <service>sshd</service> </enable> <on_demand config:type="list"> <service>cups</service> </on_demand> </services> </services-manager>
4.12 网络配置 #
4.12.1 配置工作流程 #
网络配置主要用于将单台工作站连接到基于以太网的 LAN。通常在 AutoYaST 启动前配置,以从网络位置提取配置文件。一般通过 linuxrc
来完成网络配置。
linuxrc
程序
有关 linuxrc
的工作原理及其关键字的详细说明,请参见附录 C “高级 linuxrc
选项”。
默认情况下,YaST 会将安装期间使用的网络设置复制到最终安装的系统中。此配置会与 AutoYaST 配置文件中定义的配置合并。
AutoYaST 设置的优先级高于任何现有配置文件的优先级。YaST 将基于配置文件中的项编写 ifcfg-*
文件,且不去除旧项。如果 DNS 和 routing 部分为空或缺失,YaST 将保留任何先前存在的值。如果该部分存在,则会应用配置文件中的设置。
从 SUSE Linux Enterprise Server 15.3 开始,基于配置文件写入配置的步骤发生在第一个阶段结束时。
但如果安装期间需要网络设置,您可以强制 AutoYaST 在进行注册前写入并应用这些设置,只需将 setup_before_proposal
选项设为 true
即可。如果需要进行网络安装,要求 AutoYaST 在早期阶段设置网络非常有用,但该配置太复杂,无法使用 linuxrc 定义(请参见第 9.3.2 节 “自动安装单个系统”)。
<setup_before_proposal config:type="boolean">true</setup_before_proposal>
如果在安装结束时写入配置,只有当系统重引导后才会应用配置。
网络设置和服务激活在配置文件的
networking
全局资源中定义。
4.12.2 网络资源 #
<networking> <dns> <dhcp_hostname config:type="boolean">true</dhcp_hostname> <hostname>linux-bqua</hostname> <nameservers config:type="list"> <nameserver>192.168.1.116</nameserver> <nameserver>192.168.1.117</nameserver> <nameserver>192.168.1.118</nameserver> </nameservers> <resolv_conf_policy>auto</resolv_conf_policy> <searchlist config:type="list"> <search>example.com</search> <search>example.net</search> </searchlist> </dns> <interfaces config:type="list"> <interface> <bootproto>dhcp</bootproto> <name>eth0</name> <startmode>auto</startmode> </interface> </interfaces> <ipv6 config:type="boolean">true</ipv6> <keep_install_network config:type="boolean">false</keep_install_network> #false means use Wicked, true means use NetworkManager <managed config:type="boolean">false</managed> <net-udev config:type="list"> <rule> <name>eth0</name> <rule>ATTR{address}</rule> <value>00:30:6E:08:EC:80</value> </rule> </net-udev> <s390-devices config:type="list"> <listentry> <chanids>0.0.0800:0.0.0801:0.0.0802</chanids> <type>qeth</type> </listentry> </s390-devices> <routing> <ipv4_forward config:type="boolean">false</ipv4_forward> <ipv6_forward config:type="boolean">false</ipv6_forward> <routes config:type="list"> <route> <destination>192.168.100.0/24</destination> <name>eth1</name> <extrapara>scope link src 192.168.100.100 table one</extrapara> <gateway>-</gateway> </route> <route> <destination>default</destination> <device>eth1</device> <gateway>192.168.100.1</gateway> </route> <route> <destination>default</destination> <device>lo</device> <gateway>192.168.5.1</gateway> </route> </routes> </routing> </networking>
如上述示例所示,<networking>
部分可以包含几个子部分:
interfaces
描述网络接口的配置,包括其 IP 地址、启动方式等。dns
指定与 DNS 相关的设置,例如主机名、名称服务器列表等。routing
定义路由规则。s390-devices
包含特定于 z Systems 的设备设置。net-udev
枚举用于设置持久名称的 udev 规则。
另外,还有几个元素可用于修改网络配置的应用方式:
- backend
选择要使用的网络后端。支持的值包括
wicked
、network_manager
或none
,最后一个值将禁用网络服务。<backend>network_manager<backend>
- keep_install_network
如第 4.12.1 节 “配置工作流程”中所述,AutoYaST 默认会将来自运行中系统的网络配置与配置文件中定义的相应配置进行合并。如果您只想使用配置文件中的配置,请将此元素设置为
false
。该值默认为true
。<keep_install_network config:type="boolean">false<keep_install_network>
- managed
确定是否使用 NetworkManager 取代 Wicked。
已弃用。请改用
backend
。<managed config:type="boolean">true<managed>
- start_immediately
写入配置后,立即强制 AutoYaST 重启动网络。
<start_immediately config:type="boolean">true<start_immediately>
- setup_before_proposal
在安装过程中使用配置文件中定义的网络配置。否则,AutoYaST 将依赖于
linuxrc
设置的配置。<setup_before_proposal config:type="boolean">true<setup_before_proposal>
- strict_IP_check_timeout
设置网络后,AutoYaST 会检查指派的 IP 地址是否重复。如果重复,它会显示一条警告,警告的超时(以秒为单位)就是通过此元素控制。如果此元素设置为
0
,则会停止安装。<strict_IP_check_timeout config:type="integer">5<strict_IP_check_timeout>
- virt_bridge_proposal
如果选择安装虚拟化软件包(例如,Xen、QEMU 或 KVM),AutoYaST 会配置网桥。您可以通过将此元素设为
false
来禁用此行为。<virt_bridge_proposal config:type="boolean">false>virt_bridge_proposal>
完全支持在 AutoYaST 中使用 IPv6 地址。要禁用 IPv6 地址支持,请设置 <ipv6 config:type="boolean">false</ipv6>
4.12.3 接口 #
interfaces
部分可让用户定义接口的配置,包括接口的启动方式、其 IP 地址、网络等。以下元素必须包含在 <interfaces>...</interfaces>
标记中。
bootproto
接口使用的引导协议。可能的值:
static
表示静态指派的地址。需使用ipaddr
元素指定 IP。dhcp4
、dhcp6
或dhcp
,用于通过 DHCP 设置 IP 地址(IPv4、IPv6 或任何地址)。dhcp+autoip
用于从 Zeroconf 获取 IPv4 配置,或从 DHCP 获取 IPv6 配置。autoip
用于从 Zeroconf 获取 IPv4 配置。ibft
用于通过 iBFT 协议获取 IP 地址。none
表示跳过地址设置。此值用于桥接和绑定从属。
必要。
broadcast
广播 IP 地址。
仅适用于
static
引导协议。device
设备名称。
已弃用。请改用
name
。name
设备名称,例如:
eth0
。必要。
lladdr
链路层地址(MAC 地址)。
可选。
ipaddr
指派给接口的 IP 地址。
仅适用于
static
引导协议。它可以包含网络前缀,例如:192.168.1.1/24
。remote_ipaddr
用于点对点连接的远程 IP 地址。
仅适用于
static
引导协议。netmask
网络掩码,例如:
255.255.255.0
。已弃用。请改用
prefixlen
,或者在ipaddr
元素中包含网络前缀。network
网络 IP 地址。
已弃用。请改为结合使用
ipaddr
和prefixlen
。prefixlen
网络前缀,例如:
24
。仅适用于
static
引导协议。startmode
何时启动接口。可能的值为:
hotplug
(插入设备时。例如,此值可用于 USB 网卡)。auto
(系统引导时)。onboot
是已弃用的别名。ifplugd
(设备由ifplugd
守护程序管理时)。manual
(应手动启动设备时)。nfsroot
(需要将设备挂载到根文件系统时,例如,当/
位于 NFS 卷上时)。off
(永不启动设备)。
ifplugd_priority
ifplugd
守护程序的优先级。它确定设备的激活顺序。仅适用于
ifplugd
启动模式。usercontrol
不再使用的参数。
已弃用。
bonding_slaveX
绑定设备的名称。
对于绑定设备是必需的。
X
将被替换为从 0 开始的编号,例如bonding_slave0
。每个从属都需要具有一个唯一编号。bonding_module_opts
绑定设备的选项。
仅适用于
bond
设备。mtu
接口的最大传送单位。
可选。
ethtool_options
设备激活期间的 Ethtool 选项。
可选。
zone
接口指派到的防火墙区域名称。
可选。
vlan_id
此 VLAN 使用的标识符。
仅适用于
vlan
设备。etherdevice
VLAN 挂接到的设备。
仅适用于
vlan
设备以及需要它的设备。bridge
如果接口是网桥,则为
yes
。已弃用。从其他属性推断而来。
bridge_ports
网桥端口的空格分隔列表,例如
eth0 eth1
。仅适用于
bridge
设备以及需要它的设备。bridge_stp
生成树协议。可能的值为
on
(启用时)和off
(禁用时)。仅适用于
bridge
设备。bridge_forward_delay
网桥的转发延迟,例如:
15
。仅适用于
bridge
设备。有效值为4
到30
。aliases
其他 IP 地址。请参见 第 4.12.4 节 “指派多个 IP 地址”。
<networking> <setup_before_proposal config:type="boolean">false</setup_before_proposal> <keep_install_network config:type="boolean">false</keep_install_network> <interfaces config:type="list"> <interface> <bonding_master>yes</bonding_master> <bonding_module_opts>mode=active-backup miimon=100</bonding_module_opts> <bonding_slave0>eth1</bonding_slave0> <bonding_slave0>eth2</bonding_slave0> <bondoption>mode=balance-rr miimon=100</bondoption> <bootproto>static</bootproto> <name>bond0</name> <ipaddr>192.168.1.61</ipaddr> <prefixlen>24</prefixlen> <startmode>auto</startmode> </interface> <interface> <bootproto>none</bootproto> <name>eth1</name> <startmode>auto</startmode> </interface> <interface> <bootproto>none</bootproto> <name>eth2</name> <startmode>auto</startmode> </interface> </interfaces> <net-udev config:type="list"> <rule> <name>eth1</name> <rule>ATTR{address}</rule> <value>dc:e4:cc:27:94:c7</value> </rule> <rule> <name>eth2</name> <rule>ATTR{address}</rule> <value>dc:e4:cc:27:94:c8</value> </rule> </net-udev> </networking>
<interfaces config:type="list"> <interface> <name>br0</name> <bootproto>static</bootproto> <bridge>yes</bridge> <bridge_forwarddelay>0</bridge_forwarddelay> <bridge_ports>eth0 eth1</bridge_ports> <bridge_stp>off</bridge_stp> <ipaddr>192.168.1.100</ipaddr> <prefixlen>24</prefixlen> <startmode>auto</startmode> </interface> <interface> <name>eth0</name> <bootproto>none</bootproto> <startmode>hotplug</startmode> </interface> <interface> <name>eth1</name> <bootproto>none</bootproto> <startmode>hotplug</startmode> </interface> </interfaces>
4.12.4 指派多个 IP 地址 #
AutoYaST 允许将多个 IP 地址指派给同一个接口。使用包含每个地址的 aliasX
项的 aliases
元素来指定多个地址。
每个项都支持以下元素:
- IPADDR
其他 IP 地址。它可以包含网络前缀,例如:
192.168.1.1/24
。- PREFIXLEN
网络前缀,例如:
24
。- NETMASK
地址的网络掩码。
已弃用。请改用
PREFIXLEN
,或者在IPADDR
元素中包含网络前缀。- LABEL
地址的标签。
请注意,由于历史原因,aliases
部分中的 IPADDR
、PREFIXLEN
、LABEL
和 NETMASK
元素区分大小写。
<interfaces config:type="list"> <interface> <name>br0</name> <bootproto>static</bootproto> <ipaddr>192.168.1.100</ipaddr> <prefixlen>24</prefixlen> <startmode>auto</startmode> <aliases> <alias0> <IPADDR>192.168.1.101</IPADDR> <PREFIXLEN>24</PREFIXLEN> <LABEL>http</LABEL> </alias0> <alias1> <IPADDR>192.168.2.100</IPADDR> <PREFIXLEN>24</PREFIXLEN> <LABEL>extra</LABEL> </alias1> </aliases> </interface> </interfaces>
4.12.5 网络接口的持久名称 #
net-udev
元素允许指定一组可用于向接口指派持久名称的 udev 规则。
- name
网络接口名称,例如
eth3
。(必需。)- rule
ATTR{address}
表示基于 MAC 的规则,KERNELS
表示基于总线 ID 的规则。(必需。)- value
例如:
f0:de:f1:6b:da:69
针对 MAC 规则,0000:00:1c.1 或 0.0.0700
针对总线 ID 规则。(必需。)
创建不完整的 udev 规则集时,所选设备名称可能与现有的设备名称冲突。例如,将网络接口重命名为 eth0
时,可能会与内核自动生成的设备冲突。AutoYaST 会尽力处理这种情况并重命名有冲突的设备。
<net-udev config:type="list"> <rule> <name>eth1</name> <rule>ATTR{address}</rule> <value>52:54:00:68:54:fb</value> </rule> </net-udev>
4.12.6 域名系统 #
dns
部分用于定义名称服务相关的设置,例如主机名或名称服务器。
- hostname
主机名,不包括域名部分。例如 foo,而不是 foo.bar。Linux 内核允许您使用完全完全限定的域名 (FQDN) 取代主机名,YaST 也同样如此。但在 YaST 的 dns 部分中,这并不是正确的用法。解析程序应该会确定 FQDN。(有关 FQDN 解析方式的信息,请参见
man 1 hostname
的“THE FQDN”部分。)如果未指定主机名且未从 DHCP 服务器获取主机名(请参见
dhcp_hostname
),AutoYaST 将生成一个随机主机名。- nameservers
名称服务器的列表。示例:
<nameservers config:type="list"> <nameserver>192.168.1.116</nameserver> <nameserver>192.168.1.117</nameserver> </nameservers>
- searchlist
用于查找主机名的搜索列表。
<searchlist config:type="list"> <search>example.com</search> </searchlist>
可选。
- dhcp_hostname
指定是否必须从 DHCP 获取主机名。
<dhcp_hostname config:type="boolean">true</dhcp_hostname>
4.12.7 路由选择 #
routing
表允许指定路由列表,以及 IPv4 和 IPv6 的数据包转发设置。
- ipv4_forward
可选:是否必须为 IPv4 启用 IP 转发。
- ipv6_forward
可选:是否必须为 IPv6 启用 IP 转发。
- routes
可选:路由列表。
下面的设置介绍了定义路由的方式。
- destination
必要:路由目标。可以指定地址前缀,例如:
192.168.122.0/24
。可以使用标头
default
来指示路由是与网关位于相同地址族(IPv4 或 IPv6)中的默认网关。- device
必要:与路由关联的接口。
- gateway
可选:网关的 IP 地址。
- netmask
(不推荐.)目标的网络掩码。
最好是指定前缀作为
destination
值的一部分。- extrapara
可选:更多路由选项,例如
metric
、mtu
或table
。
<routing> <ipv4_forward config:type="boolean">true</ipv4_forward> <ipv6_forward config:type="boolean">true</ipv6_forward> <routes config:type="list"> <route> <destination>192.168.100.0/24</destination> <device>eth1</device> <extrapara>scope link src 192.168.100.100 table one</extrapara> </route> <route> <destination>default</destination> <device>eth1</device> <gateway>192.168.100.1</gateway> </route> <route> <destination>default</destination> <device>lo</device> <gateway>192.168.5.1</gateway> </route> </routes> </routing>
4.12.8 s390 选项 #
以下元素必须包含在 <s390-devices
>... </s390-devices
> 标记之中。
- type
qeth
、ctc
或iucv
。- chanids
通道 ID,以冒号(首选)或空格分隔
<chanids>0.0.0700:0.0.0701:0.0.0702</chanids>
- layer2
<layer2 config:type="boolean">true</layer2>
布尔值;默认值:
false
- portname
QETH 端口名(从 SLE 12 SP2 开始已弃用)
- protocol
可选:CTC/LCS 协议,一个较小的数字(字符串形式)
<protocol>1</protocol>
- router
IUCV 路由器/用户
除上述选项外,AutoYaST 还支持在配置文件的其他部分中使用 IBM Z 特定的选项。具体而言,您可以定义逻辑链接地址,即 LLADDR(在以太网中为 MAC 地址)。为此,请在设备定义中使用选项 LLADDR
。
VLAN 设备从底层物理设备继承其 LLADDR。要为 VLAN 设备设置特定的地址,请为底层物理设备设置 LLADDR 选项。
4.13 代理 #
配置互联网代理(缓存)设置。
使用 http_proxy
、https_proxy
和 ftp_proxy
分别配置 HTTP、HTTPS 和 FTP 的代理。需使用 no_proxy
指定应可直接访问的地址或名称(空格分隔值)。如果您使用需要身份验证的代理服务器,请填写 proxy_user
和 proxy_password
。
<proxy> <enabled config:type="boolean">true</enabled> <ftp_proxy>http://192.168.1.240:3128</ftp_proxy> <http_proxy>http://192.168.1.240:3128</http_proxy> <no_proxy>www.example.com .example.org localhost</no_proxy> <proxy_password>testpw</proxy_password> <proxy_user>testuser</proxy_user> </proxy>
如果强制将网络配置写在建议前面或通过 linuxrc
提供代理设置,将会在安装期间写入代理设置。
4.14 NIS 客户端和服务器 #
使用 nis
资源可将目标计算机配置为 NIS 客户端。以下示例演示了使用多个域的详细配置。
<nis> <nis_broadcast config:type="boolean">true</nis_broadcast> <nis_broken_server config:type="boolean">true</nis_broken_server> <nis_domain>test.com</nis_domain> <nis_local_only config:type="boolean">true</nis_local_only> <nis_options></nis_options> <nis_other_domains config:type="list"> <nis_other_domain> <nis_broadcast config:type="boolean">false</nis_broadcast> <nis_domain>domain.com</nis_domain> <nis_servers config:type="list"> <nis_server>10.10.0.1</nis_server> </nis_servers> </nis_other_domain> </nis_other_domains> <nis_servers config:type="list"> <nis_server>192.168.1.1</nis_server> </nis_servers> <start_autofs config:type="boolean">true</start_autofs> <start_nis config:type="boolean">true</start_nis> </nis>
4.15 NIS 服务器 #
可将目标计算机配置为 NIS 服务器。可以使用 NIS 主服务器和 NIS 从属服务器,以及两者的组合。
<nis_server> <domain>mydomain.de</domain> <maps_to_serve config:type="list"> <nis_map>auto.master</nis_map> <nis_map>ethers</nis_map> </maps_to_serve> <merge_passwd config:type="boolean">false</merge_passwd> <mingid config:type="integer">0</mingid> <minuid config:type="integer">0</minuid> <nopush config:type="boolean">false</nopush> <pwd_chfn config:type="boolean">false</pwd_chfn> <pwd_chsh config:type="boolean">false</pwd_chsh> <pwd_srcdir>/etc</pwd_srcdir> <securenets config:type="list"> <securenet> <netmask>255.0.0.0</netmask> <network>127.0.0.0</network> </securenet> </securenets> <server_type>master</server_type> <slaves config:type="list"/> <start_ypbind config:type="boolean">false</start_ypbind> <start_yppasswdd config:type="boolean">false</start_yppasswdd> <start_ypxfrd config:type="boolean">false</start_ypxfrd> </nis_server>
-
domain
NIS 域名。
-
maps_to_serve
服务器可用的映射列表。
值:auto.master、ethers、group、hosts、netgrp、networks、passwd、protocols、rpc、services、shadow
-
merge_passwd
选择是否应将您的 passwd 文件与 shadow 文件合并(仅当 shadow 文件存在时才可以这样做)。
值:true/false
-
mingid
要包含在用户映射中的最小 GID。
-
minuid
要包含在用户映射中的最小 UID。
-
nopush
不要将更改推送到从属服务器。(未发生任何更改时非常有用)。
值:true/false
-
pwd_chfn
YPPWD_CHFN - 允许更改全名
值:true/false
-
pwd_chsh
YPPWD_CHSH - 允许更改登录外壳
值:true/false
-
pwd_srcdir
YPPWD_SRCDIR - passwd 数据的源目录
默认值:
/etc
-
securenets
允许其查询 NIS 服务器的主机列表
当网络等于主机地址和网络掩码的按位 AND 结果时,允许使用主机地址。
包含网络掩码 255.0.0.0 和网络 127.0.0.0 的项必须存在,才允许从本地主机进行连接。
输入网络掩码 0.0.0.0 和网络 0.0.0.0 会授予对所有主机的访问权限。
-
server_type
选择是将 NIS 服务器配置为主服务器或从属服务器,还是不配置 NIS 服务器。
值:master、slave、none
-
slaves
要配置为 NIS 从属服务器的主机名列表。
-
start_ypbind
此主机也是 NIS 客户端(仅适用于在本地配置客户端的情况)。
值:true/false
-
start_yppasswdd
同时启动口令守护程序。
值:true/false
-
start_ypxfrd
同时启动映射传送守护程序。快速映射分发;将加快向从属服务器传送映射的过程。
值:true/false
4.16 主机定义 #
使用 host
资源可将更多项添加到 /etc/hosts
文件。这不会删除现有的项。有关细节,请参见以下示例。
<host> <hosts config:type="list"> <hosts_entry> <host_address>133.3.0.1</host_address> <names config:type="list"> <name>booking</name> </names> </hosts_entry> <hosts_entry> <host_address>133.3.0.5</host_address> <names config:type="list"> <name>test-machine</name> </names> </hosts_entry> </hosts> </host>
4.17 Windows 域成员资格 #
使用 samba-client
资源可以配置工作组、NT 域或 Active Directory 域的成员资格。
<samba-client> <disable_dhcp_hostname config:type="boolean">true</disable_dhcp_hostname> <global> <security>domain</security> <usershare_allow_guests>No</usershare_allow_guests> <usershare_max_shares>100</usershare_max_shares> <workgroup>WORKGROUP</workgroup> </global> <winbind config:type="boolean">false</winbind> </samba-client>
-
disable_dhcp_hostname
不允许 DHCP 更改主机名。
值:true/false
-
global/security
身份验证体系的类型(域技术或 Active Directory 服务器 (ADS))。
值:ADS/domain
-
global/usershare_allow_guests
允许共享 Guest 访问权限。
值:No/Yes
-
global/usershare_max_shares
表示
smb.conf
中的共享数上限。0 表示未启用共享。
-
global/workgroup
工作组名或域名。
-
winbind
使用 winbind。
值:true/false
4.18 Samba 服务器 #
简单 Samba 服务器的配置。
<samba-server> <accounts config:type="list"/> <backend/> <config config:type="list"> <listentry> <name>global</name> <parameters> <security>domain</security> <usershare_allow_guests>No</usershare_allow_guests> <usershare_max_shares>100</usershare_max_shares> <workgroup>WORKGROUP</workgroup> </parameters> </listentry> </config> <service>Disabled</service> <trustdom/> <version>2.11</version> </samba-server>
- accounts
Samba 帐户的列表。
- backend
可用后端的列表.
值:
true
/false
。- config
在
/etc/samba/smb.conf
中设置其他用户定义的参数。该示例显示了
/etc/samba/smb.conf
的global
部分中的参数。- service
在引导期间启动 Samba 服务。
值:
Enabled
/Disabled
。- trustdom/
可信域。
两个映射的映射(键:
establish、revoke
)。每个映射包含采用key: domainname
value: password
格式的项。- version
Samba 版本。
默认值:2.11.
4.19 身份验证客户端 #
配置文件必须采用 JSON 格式。校验 autoyast2 和 autoyast2-installation 均已安装。使用 YaST 中的 模块生成有效的 JSON 配置文件。启动 YaST 并切换到 › 。选择 › ,单击 ,然后配置可用设置。完成后单击 。要保存生成的配置文件,请使用 › 。
要结合本机 SSL(而不是 TLS)使用 LDAP,请添加 ldaps
资源。
4.20 NFS 客户端和服务器 #
可以使用配置系统将某个系统配置为 NFS 客户端或 NFS 服务器。以下示例演示如何配置 NFS 客户端和服务器。
从 SUSE Linux Enterprise Server 15 SP4 开始,NFS 客户端配置结构已更改。引入了一些全局配置选项:enable_nfs4
用于打开/关闭 NFS4 支持,idmapd_domain
用于定义 rpc.idmapd 域名(仅当已启用 NFS4 时才有效)。注意:旧结构与新结构不兼容,因此在较旧版本中创建的包含 NFS 部分的控制文件在较新产品中无效。
有关如何在 NFS 共享上安装 SUSE Linux Enterprise Server 的详细信息,请参见第 4.5.10 节 “NFS 配置”。
<nfs> <enable_nfs4 config:type="boolean">true</enable_nfs4> <idmapd_domain>suse.cz</idmapd_domain> <nfs_entries config:type="list"> <nfs_entry> <mount_point>/home</mount_point> <nfs_options>sec=krb5i,intr,rw</nfs_options> <server_path>saurus.suse.cz:/home</server_path> <vfstype>nfs4</vfstype> </nfs_entry> <nfs_entry> <mount_point>/work</mount_point> <nfs_options>defaults</nfs_options> <server_path>bivoj.suse.cz:/work</server_path> <vfstype>nfs</vfstype> </nfs_entry> <nfs_entry> <mount_point>/mnt</mount_point> <nfs_options>defaults</nfs_options> <server_path>fallback.suse.cz:/srv/dist</server_path> <vfstype>nfs</vfstype> </nfs_entry> </nfs_entries> </nfs>
<nfs_server> <nfs_exports config:type="list"> <nfs_export> <allowed config:type="list"> <allowed_clients>*(ro,root_squash,sync)</allowed_clients> </allowed> <mountpoint>/home</mountpoint> </nfs_export> <nfs_export> <allowed config:type="list"> <allowed_clients>*(ro,root_squash,sync)</allowed_clients> </allowed> <mountpoint>/work</mountpoint> </nfs_export> </nfs_exports> <start_nfsserver config:type="boolean">true</start_nfsserver> </nfs_server>
4.21 NTP 客户端 #
从 SUSE Linux Enterprise Server 15 开始,NTP 客户端配置文件采用了新格式,因此与先前的配置文件不兼容。需要更新您在旧版 SUSE Linux Enterprise Server 中使用的 NTP 客户端配置文件,然后才能与版本 15 和更新版本兼容。
下面是 NTP 客户端配置示例:
<ntp-client> <ntp_policy>auto</ntp_policy>1 <ntp_servers config:type="list"> <ntp_server> <address>cz.pool.ntp.org</address>2 <iburst config:type="boolean">false</iburst>3 <offline config:type="boolean">false</offline>4 </ntp_server> </ntp_servers> <ntp_sync>15</ntp_sync>5 </ntp-client>
| |
时间服务器或时间服务器池的 URL。 | |
启动 | |
将 | |
对于 |
以下示例演示了一个 IPv6 配置。可以使用服务器的 IP 地址和/或主机名:
<ntp-server> <address>2001:418:3ff::1:53</address> </ntp-server> <ntp-server> <address>2.pool.ntp.org</address> </ntp-server>
4.22 邮件服务器配置 #
对于客户端的邮件配置,此模块可让您创建详细的邮件配置。该模块包含各种选项。我们建议至少应在进行初始配置时使用该模块。
<mail> <aliases config:type="list"> <alias> <alias>root</alias> <comment></comment> <destinations>foo</destinations> </alias> <alias> <alias>test</alias> <comment></comment> <destinations>foo</destinations> </alias> </aliases> <connection_type config:type="symbol">permanent</connection_type> <fetchmail config:type="list"> <fetchmail_entry> <local_user>foo</local_user> <password>bar</password> <protocol>POP3</protocol> <remote_user>foo</remote_user> <server>pop.foo.com</server> </fetchmail_entry> <fetchmail_entry> <local_user>test</local_user> <password>bar</password> <protocol>IMAP</protocol> <remote_user>test</remote_user> <server>blah.com</server> </fetchmail_entry> </fetchmail> <from_header>test.com</from_header> <listen_remote config:type="boolean">true</listen_remote> <local_domains config:type="list"> <domains>test1.com</domains> </local_domains> <masquerade_other_domains config:type="list"> <domain>blah.com</domain> </masquerade_other_domains> <masquerade_users config:type="list"> <masquerade_user> <address>joe@test.com</address> <comment></comment> <user>joeuser</user> </masquerade_user> <masquerade_user> <address>bar@test.com</address> <comment></comment> <user>foo</user> </masquerade_user> </masquerade_users> <mta config:type="symbol">postfix</mta> <outgoing_mail_server>test.com</outgoing_mail_server> <postfix_mda config:type="symbol">local</postfix_mda> <smtp_auth config:type="list"> <listentry> <password>bar</password> <server>test.com</server> <user>foo</user> </listentry> </smtp_auth> <use_amavis config:type="boolean">true</use_amavis> <virtual_users config:type="list"> <virtual_user> <alias>test.com</alias> <comment></comment> <destinations>foo.com</destinations> </virtual_user> <virtual_user> <alias>geek.com</alias> <comment></comment> <destinations>bar.com</destinations> </virtual_user> </virtual_users> </mail>
4.23 Apache HTTP 服务器配置 #
本节介绍 Apache HTTP 服务器的配置。
对于经验不足的用户,我们建议使用 HTTP 服务器
YaST 模块配置 Apache 服务器。完成该操作后,调用 AutoYaST 配置
模块,选择 HTTP 服务器
YaST 模块并克隆 Apache 设置。可以通过文件
菜单导出这些设置。
<http-server> <Listen config:type="list"> <listentry> <ADDRESS/> <PORT>80</PORT> </listentry> </Listen> <hosts config:type="list"> <hosts_entry> <KEY>main</KEY> <VALUE config:type="list"> <listentry> <KEY>DocumentRoot</KEY> <OVERHEAD> # # Global configuration that will be applicable for all # virtual hosts, unless deleted here or overriden elsewhere. # </OVERHEAD> <VALUE>"/srv/www/htdocs"</VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <OVERHEAD> # # Configure the DocumentRoot # </OVERHEAD> <SECTIONNAME>Directory</SECTIONNAME> <SECTIONPARAM>"/srv/www/htdocs"</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Options</KEY> <OVERHEAD> # Possible values for the Options directive are "None", "All", # or any combination of: # Indexes Includes FollowSymLinks SymLinksifOwnerMatch # ExecCGI MultiViews # # Note that "MultiViews" must be named *explicitly* # --- "Options All" # does not give it to you. # # The Options directive is both complicated and important. # Please see # http://httpd.apache.org/docs/2.4/mod/core.html#options # for more information. </OVERHEAD> <VALUE>None</VALUE> </listentry> <listentry> <KEY>AllowOverride</KEY> <OVERHEAD> # AllowOverride controls what directives may be placed in # .htaccess files. It can be "All", "None", or any combination # of the keywords: # Options FileInfo AuthConfig Limit </OVERHEAD> <VALUE>None</VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <OVERHEAD> # Controls who can get stuff from this server. </OVERHEAD> <SECTIONNAME>IfModule</SECTIONNAME> <SECTIONPARAM>!mod_access_compat.c</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Require</KEY> <VALUE>all granted</VALUE> </listentry> </VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <SECTIONNAME>IfModule</SECTIONNAME> <SECTIONPARAM>mod_access_compat.c</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Order</KEY> <VALUE>allow,deny</VALUE> </listentry> <listentry> <KEY>Allow</KEY> <VALUE>from all</VALUE> </listentry> </VALUE> </listentry> </VALUE> </listentry> <listentry> <KEY>Alias</KEY> <OVERHEAD> # Aliases: aliases can be added as needed (with no limit). # The format is Alias fakename realname # # Note that if you include a trailing / on fakename then the # server will require it to be present in the URL. So "/icons" # is not aliased in this example, only "/icons/". If the fakename # is slash-terminated, then the realname must also be slash # terminated, and if the fakename omits the trailing slash, the # realname must also omit it. # We include the /icons/ alias for FancyIndexed directory listings. # If you do not use FancyIndexing, you may comment this out. # </OVERHEAD> <VALUE>/icons/ "/usr/share/apache2/icons/"</VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <OVERHEAD> </OVERHEAD> <SECTIONNAME>Directory</SECTIONNAME> <SECTIONPARAM>"/usr/share/apache2/icons"</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Options</KEY> <VALUE>Indexes MultiViews</VALUE> </listentry> <listentry> <KEY>AllowOverride</KEY> <VALUE>None</VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <SECTIONNAME>IfModule</SECTIONNAME> <SECTIONPARAM>!mod_access_compat.c</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Require</KEY> <VALUE>all granted</VALUE> </listentry> </VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <SECTIONNAME>IfModule</SECTIONNAME> <SECTIONPARAM>mod_access_compat.c</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Order</KEY> <VALUE>allow,deny</VALUE> </listentry> <listentry> <KEY>Allow</KEY> <VALUE>from all</VALUE> </listentry> </VALUE> </listentry> </VALUE> </listentry> <listentry> <KEY>ScriptAlias</KEY> <OVERHEAD> # ScriptAlias: This controls which directories contain server # scripts. ScriptAliases are essentially the same as Aliases, # except that documents in the realname directory are treated # as applications and run by the server when requested rather # than as documents sent to the client. # The same rules about trailing "/" apply to ScriptAlias # directives as to Alias. # </OVERHEAD> <VALUE>/cgi-bin/ "/srv/www/cgi-bin/"</VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <OVERHEAD> # "/srv/www/cgi-bin" should be changed to wherever your # ScriptAliased CGI directory exists, if you have that configured. # </OVERHEAD> <SECTIONNAME>Directory</SECTIONNAME> <SECTIONPARAM>"/srv/www/cgi-bin"</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>AllowOverride</KEY> <VALUE>None</VALUE> </listentry> <listentry> <KEY>Options</KEY> <VALUE>+ExecCGI -Includes</VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <SECTIONNAME>IfModule</SECTIONNAME> <SECTIONPARAM>!mod_access_compat.c</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Require</KEY> <VALUE>all granted</VALUE> </listentry> </VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <SECTIONNAME>IfModule</SECTIONNAME> <SECTIONPARAM>mod_access_compat.c</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>Order</KEY> <VALUE>allow,deny</VALUE> </listentry> <listentry> <KEY>Allow</KEY> <VALUE>from all</VALUE> </listentry> </VALUE> </listentry> </VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <OVERHEAD> # UserDir: The name of the directory that is appended onto a # user's home directory if a ~user request is received. # To disable it, simply remove userdir from the list of modules # in APACHE_MODULES in /etc/sysconfig/apache2. # </OVERHEAD> <SECTIONNAME>IfModule</SECTIONNAME> <SECTIONPARAM>mod_userdir.c</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>UserDir</KEY> <OVERHEAD> # Note that the name of the user directory ("public_html") # cannot simply be changed here, since it is a compile time # setting. The apache package would need to be rebuilt. # You could work around by deleting /usr/sbin/suexec, but # then all scripts from the directories would be executed # with the UID of the webserver. </OVERHEAD> <VALUE>public_html</VALUE> </listentry> <listentry> <KEY>Include</KEY> <OVERHEAD> # The actual configuration of the directory is in # /etc/apache2/mod_userdir.conf. </OVERHEAD> <VALUE>/etc/apache2/mod_userdir.conf</VALUE> </listentry> </VALUE> </listentry> <listentry> <KEY>IncludeOptional</KEY> <OVERHEAD> # Include all *.conf files from /etc/apache2/conf.d/. # # This is mostly meant as a place for other RPM packages to drop # in their configuration snippet. # # # You can comment this out here if you want those bits include # only in a certain virtual host, but not here. </OVERHEAD> <VALUE>/etc/apache2/conf.d/*.conf</VALUE> </listentry> <listentry> <KEY>IncludeOptional</KEY> <OVERHEAD> # The manual... if it is installed ('?' means it will not complain) </OVERHEAD> <VALUE>/etc/apache2/conf.d/apache2-manual?conf</VALUE> </listentry> <listentry> <KEY>ServerName</KEY> <VALUE>linux-wtyj</VALUE> </listentry> <listentry> <KEY>ServerAdmin</KEY> <OVERHEAD> </OVERHEAD> <VALUE>root@linux-wtyj</VALUE> </listentry> <listentry> <KEY>NameVirtualHost</KEY> <VALUE>192.168.43.2</VALUE> </listentry> </VALUE> </hosts_entry> <hosts_entry> <KEY>192.168.43.2/secondserver.suse.de</KEY> <VALUE config:type="list"> <listentry> <KEY>DocumentRoot</KEY> <VALUE>/srv/www/htdocs</VALUE> </listentry> <listentry> <KEY>ServerName</KEY> <VALUE>secondserver.suse.de</VALUE> </listentry> <listentry> <KEY>ServerAdmin</KEY> <VALUE>second_server@suse.de</VALUE> </listentry> <listentry> <KEY>_SECTION</KEY> <SECTIONNAME>Directory</SECTIONNAME> <SECTIONPARAM>/srv/www/htdocs</SECTIONPARAM> <VALUE config:type="list"> <listentry> <KEY>AllowOverride</KEY> <VALUE>None</VALUE> </listentry> <listentry> <KEY>Require</KEY> <VALUE>all granted</VALUE> </listentry> </VALUE> </listentry> </VALUE> </hosts_entry> </hosts> <modules config:type="list"> <module_entry> <change>enable</change> <name>socache_shmcb</name> <userdefined config:type="boolean">true</userdefined> </module_entry> <module_entry> <change>enable</change> <name>reqtimeout</name> <userdefined config:type="boolean">true</userdefined> </module_entry> <module_entry> <change>enable</change> <name>authn_core</name> <userdefined config:type="boolean">true</userdefined> </module_entry> <module_entry> <change>enable</change> <name>authz_core</name> <userdefined config:type="boolean">true</userdefined> </module_entry> </modules> <service config:type="boolean">true</service> <version>2.9</version> </http-server>
- Listen
主机
Listen
设置列表PORT
端口地址
ADDRESS
网络地址。如果此项为空,将采用所有地址。
- hosts
主机配置列表
KEY
主机名;
<KEY>main</KEY>
定义主要主机,例如<KEY>192.168.43.2/secondserver.suse.de</KEY>
VALUE
用于描述主机的不同值的列表。
- modules
模块列表。只需描述用户定义的模块。
name
模块名称
userdefined
出于历史原因,此项始终设置为
true
。change
出于历史原因,此项始终设置为
enable
。
- version
使用的 Apache 服务器版本
仅供参考。默认值 2.9
- service
启用 Apache 服务
可选。默认值:false
要正常运行 Apache 服务器,请确保正确配置了防火墙。
4.24 Squid 服务器 #
Squid 是一个缓存和转发 Web 代理。
<squid> <acls config:type="list"> <listentry> <name>QUERY</name> <options config:type="list"> <option>cgi-bin \?</option> </options> <type>urlpath_regex</type> </listentry> <listentry> <name>apache</name> <options config:type="list"> <option>Server</option> <option>^Apache</option> </options> <type>rep_header</type> </listentry> <listentry> <name>all</name> <options config:type="list"> <option>0.0.0.0/0.0.0.0</option> </options> <type>src</type> </listentry> <listentry> <name>manager</name> <options config:type="list"> <option>cache_object</option> </options> <type>proto</type> </listentry> <listentry> <name>localhost</name> <options config:type="list"> <option>127.0.0.1/255.255.255.255</option> </options> <type>src</type> </listentry> <listentry> <name>to_localhost</name> <options config:type="list"> <option>127.0.0.0/8</option> </options> <type>dst</type> </listentry> <listentry> <name>SSL_ports</name> <options config:type="list"> <option>443</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>80</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>21</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>443</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>70</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>210</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>1025-65535</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>280</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>488</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>591</option> </options> <type>port</type> </listentry> <listentry> <name>Safe_ports</name> <options config:type="list"> <option>777</option> </options> <type>port</type> </listentry> <listentry> <name>CONNECT</name> <options config:type="list"> <option>CONNECT</option> </options> <type>method</type> </listentry> </acls> <http_accesses config:type="list"> <listentry> <acl config:type="list"> <listentry>manager</listentry> <listentry>localhost</listentry> </acl> <allow config:type="boolean">true</allow> </listentry> <listentry> <acl config:type="list"> <listentry>manager</listentry> </acl> <allow config:type="boolean">false</allow> </listentry> <listentry> <acl config:type="list"> <listentry>!Safe_ports</listentry> </acl> <allow config:type="boolean">false</allow> </listentry> <listentry> <acl config:type="list"> <listentry>CONNECT</listentry> <listentry>!SSL_ports</listentry> </acl> <allow config:type="boolean">false</allow> </listentry> <listentry> <acl config:type="list"> <listentry>localhost</listentry> </acl> <allow config:type="boolean">true</allow> </listentry> <listentry> <acl config:type="list"> <listentry>all</listentry> </acl> <allow config:type="boolean">false</allow> </listentry> </http_accesses> <http_ports config:type="list"> <listentry> <host/> <port>3128</port> <transparent config:type="boolean">false</transparent> </listentry> </http_ports> <refresh_patterns config:type="list"> <listentry> <case_sensitive config:type="boolean">true</case_sensitive> <max>10080</max> <min>1440</min> <percent>20</percent> <regexp>^ftp:</regexp> </listentry> <listentry> <case_sensitive config:type="boolean">true</case_sensitive> <max>1440</max> <min>1440</min> <percent>0</percent> <regexp>^gopher:</regexp> </listentry> <listentry> <case_sensitive config:type="boolean">true</case_sensitive> <max>4320</max> <min>0</min> <percent>20</percent> <regexp>.</regexp> </listentry> </refresh_patterns> <service_enabled_on_startup config:type="boolean">true</service_enabled_on_startup> <settings> <access_log config:type="list"> <listentry>/var/log/squid/access.log</listentry> </access_log> <cache_dir config:type="list"> <listentry>ufs</listentry> <listentry>/var/cache/squid</listentry> <listentry>100</listentry> <listentry>16</listentry> <listentry>256</listentry> </cache_dir> <cache_log config:type="list"> <listentry>/var/log/squid/cache.log</listentry> </cache_log> <cache_mem config:type="list"> <listentry>8</listentry> <listentry>MB</listentry> </cache_mem> <cache_mgr config:type="list"> <listentry>webmaster</listentry> </cache_mgr> <cache_replacement_policy config:type="list"> <listentry>lru</listentry> </cache_replacement_policy> <cache_store_log config:type="list"> <listentry>/var/log/squid/store.log</listentry> </cache_store_log> <cache_swap_high config:type="list"> <listentry>95</listentry> </cache_swap_high> <cache_swap_low config:type="list"> <listentry>90</listentry> </cache_swap_low> <client_lifetime config:type="list"> <listentry>1</listentry> <listentry>days</listentry> </client_lifetime> <connect_timeout config:type="list"> <listentry>2</listentry> <listentry>minutes</listentry> </connect_timeout> <emulate_httpd_log config:type="list"> <listentry>off</listentry> </emulate_httpd_log> <error_directory config:type="list"> <listentry/> </error_directory> <ftp_passive config:type="list"> <listentry>on</listentry> </ftp_passive> <maximum_object_size config:type="list"> <listentry>4096</listentry> <listentry>KB</listentry> </maximum_object_size> <memory_replacement_policy config:type="list"> <listentry>lru</listentry> </memory_replacement_policy> <minimum_object_size config:type="list"> <listentry>0</listentry> <listentry>KB</listentry> </minimum_object_size> </settings> </squid>
-
acls
访问控制列表 (ACL) 设置。
每个列表项包含名称、类型和其他选项。使用 YaST Squid 配置模块可以获取可能项的概述。
-
http_accesses
在访问控制表中,可以拒绝或允许 ACL 组的访问。
如果一个定义中包含更多 ACL 组,则会同时允许或拒绝属于所有 ACL 组成员的访问。
将按此处的列出顺序检查访问控制表。使用第一个匹配项。
-
http_ports
定义 Squid 将用来侦听客户端 HTTP 请求的所有端口。
Host
可以包含主机名或 IP 地址,也可以留空。transparent
禁用透明的 PMTU 发现。-
refresh_patterns
刷新模式定义 Squid 如何处理缓存中的对象。
将按此处的列出顺序检查刷新模式。使用第一个匹配项。
Min
确定在未指定显式失效时间的情况下,要将某个对象视为新对象的时间长短(分钟)。Max
是将未指定显式失效时间的对象视为新对象的时间长短上限。Percent
是对象新旧程度的百分比(自上次修改以来消逝的时间)。未指定显式失效时间的对象将被视为新对象。-
settings
具有默认值的所有可用常规参数的映射。
使用 YaST Squid 配置模块可以获取有关可能项的概述。
-
service_enabled_on_startup
引导时启动 Squid 服务。
值:true/false
4.25 FTP 服务器 #
配置 FTP 互联网服务器设置
<ftp-server> <AnonAuthen>2</AnonAuthen> <AnonCreatDirs>NO</AnonCreatDirs> <AnonMaxRate>0</AnonMaxRate> <AnonReadOnly>NO</AnonReadOnly> <AntiWarez>YES</AntiWarez> <Banner>Welcome message</Banner> <CertFile/> <ChrootEnable>NO</ChrootEnable> <EnableUpload>YES</EnableUpload> <FTPUser>ftp</FTPUser> <FtpDirAnon>/srv/ftp</FtpDirAnon> <FtpDirLocal/> <GuestUser/> <LocalMaxRate>0</LocalMaxRate> <MaxClientsNumber>10</MaxClientsNumber> <MaxClientsPerIP>3</MaxClientsPerIP> <MaxIdleTime>15</MaxIdleTime> <PasMaxPort>40500</PasMaxPort> <PasMinPort>40000</PasMinPort> <PassiveMode>YES</PassiveMode> <SSL>0</SSL> <SSLEnable>NO</SSLEnable> <SSLv2>NO</SSLv2> <SSLv3>NO</SSLv3> <StartDaemon>2</StartDaemon> <TLS>YES</TLS> <Umask/> <UmaskAnon/> <UmaskLocal/> <VerboseLogging>NO</VerboseLogging> <VirtualUser>NO</VirtualUser> </ftp-server>
AnonAuthen
启用/禁用匿名用户和本地用户。
仅经身份验证的用户:1;仅匿名:0;两者:2
AnonCreatDirs
匿名用户可以创建目录。
值:YES/NO
AnonReadOnly
匿名用户可以上载。
值:YES/NO
AnonMaxRate
允许匿名客户端使用的最大数据传输速率。
KB/秒
AntiWarez
禁止下载已上载但未经本地管理员验证的文件。
值:YES/NO
Banner
指定包含当某人连接到服务器时所显示文本的文件名。
CertFile
用于 SSL 加密连接的 DSA 证书
此选项指定用于 SSL 加密连接的 DSA 证书的位置。
ChrootEnable
如果启用,则本地用户登录后,默认会将他们放置到其主目录中的
chroot
jail 内。警告:此选项会影响安全性。值:YES/NO
EnableUpload
如果启用,则 FTP 用户可以上载。
要允许匿名用户上载,请启用
AnonReadOnly
。值:YES/NOFTPUser
定义匿名 FTP 用户。
FtpDirAnon
匿名用户的 FTP 目录。
指定匿名 FTP 用户使用的目录。
FtpDirLocal
经身份验证的用户的 FTP 目录。
指定经过身份验证的 FTP 用户使用的目录。
LocalMaxRate
指定允许经身份验证的本地用户使用的最大数据传输速率。
KB/秒
MaxClientsNumber
允许连接的最大客户端数。
MaxClientsPerIP
定义一个 IP 的最大客户端数。
此元素用于限制允许从单个源互联网地址连接的客户端数。
MaxIdleTime
两个 FTP 命令之间远程客户端的最大等待时间(超时)。
分钟
PasMaxPort
用于被动连接答复的端口范围最大值。
PassiveMode
需设置为 YES。PasMinPort
用于被动连接答复的端口范围最小值。
PassiveMode
需设置为 YES。PassiveMode
启用被动模式
值:YES/NO
SSL
安全性设置
禁用 TLS/SSL:0;接受 TLS/SSL:1;拒绝非 SSL/TLS 连接:2
SSLEnable
如果启用,则允许 SSL 连接。
值:YES/NO
SSLv2
如果启用,则允许 SSL 版本 2 连接。
值:YES/NO
SSLv3
如果启用,则允许 SSL 版本 3 连接。
值:YES/NO
StartDaemon
如何启动 FTP 守护程序。
手动:0;引导时:1;通过 systemd 套接字:2
TLS
如果启用,则允许 TLS 连接。
值:YES/NO
Umask
文件创建掩码,采用“(文件的 umask):(目录的 umask)”格式。
例如,如果您存有怀疑,请将其设置为
177:077
。UmaskAnon
为匿名用户设置的文件创建 umask 的值。
要指定八进制值,请记得添加“0”前缀,否则会将该值视为十进制整数。
UmaskLocal
经身份验证的用户的 Umask。
要指定八进制值,请记得添加“0”前缀,否则会将该值视为十进制整数。
VerboseLogging
如果启用,则记录所有 FTP 请求和响应。
值:YES/NO
VirtualUser
使用虚拟用户可以在不影响系统帐户的情况下管理 FTP 帐户。
值:YES/NO
需要指定正确的防火墙设置才能让 FTP 服务器正常运行。
4.26 TFTP 服务器 #
配置 TFTP 互联网服务器设置。
使用此选项可为服务器启用 TFTP(普通文件传送协议)。将使用 systemd
套接字启动该服务器。
注意:TFTP 和 FTP 不同。
<tftp-server> <start_tftpd config:type="boolean">true</start_tftpd> <tftp_directory>/tftpboot</tftp_directory> </tftp-server>
- start_tftpd
启用 TFTP 服务器服务。值:
true
/false
。- tftp_directory
引导映像目录:指定所处理文件所在的目录。
值一般为
/tftpboot
。如果不存在,将创建该目录。服务器使用该目录作为其根目录(使用-s
选项)。
4.27 首次引导工作流程 #
在完成安装后运行的 YaST 首次引导实用程序(YaST 初始系统配置)可让您配置全新安装的系统。在安装后首次进行引导时,该实用程序会指导用户完成一系列步骤,让他们能够更轻松地配置系统。YaST 首次引导默认不会运行,需要经过配置后才会运行。
<firstboot> <firstboot_enabled config:type="boolean">true</firstboot_enabled> </firstboot>
4.28 安全性设置 #
使用此模块的功能可以更改目标系统上的本地安全性设置。本地安全性设置包括引导配置、登录设置、口令设置、用户添加设置和文件权限。
安全性设置自动配置类似于在运行中的系统上可用的安全性模块中的自定义设置
。此功能允许您创建自定义的配置。
有关以下示例中的设置的含义和可能值,请参见参考信息。
<security> <console_shutdown>ignore</console_shutdown> <displaymanager_remote_access>no</displaymanager_remote_access> <fail_delay>3</fail_delay> <faillog_enab>yes</faillog_enab> <gid_max>60000</gid_max> <gid_min>101</gid_min> <gdm_shutdown>root</gdm_shutdown> <lastlog_enab>yes</lastlog_enab> <encryption>md5</encryption> <obscure_checks_enab>no</obscure_checks_enab> <pass_max_days>99999</pass_max_days> <pass_max_len>8</pass_max_len> <pass_min_days>1</pass_min_days> <pass_min_len>6</pass_min_len> <pass_warn_age>14</pass_warn_age> <passwd_use_cracklib>yes</passwd_use_cracklib> <permission_security>secure</permission_security> <run_updatedb_as>nobody</run_updatedb_as> <uid_max>60000</uid_max> <uid_min>500</uid_min> <selinux_mode>permissive</selinux_mode> <lsm_select>selinux</lsm_select> </security>
4.28.1 口令设置选项 #
更改各项口令设置。这些设置主要储存在 /etc/login.defs
文件中。
使用此资源可激活当前支持的加密方法之一。如果未设置,将配置 DES
。
Linux 默认方法 DES
适用于所有网络环境,但是存在八个字符的口令长度限制。MD5
允许更长的口令,因此可提供更高的安全性,但某些网络协议不支持此方法,并且在 NIS 中使用时可能会出现问题。还支持 Blowfish
。
此外,还可设置系统以检查口令合理性和长度等。
4.28.2 引导设置 #
使用安全性资源可以更改各项引导设置。
- 如何解释 Ctrl–Alt–Del?
当控制台端的某人按下 Ctrl–Alt–Del 组合键时,系统通常会重引导。有时需要忽略此事件,例如,当系统既是工作站又是服务器时。
- GDM 的关机行为
配置允许其从 GDM 关闭计算机的用户列表。
4.28.3 登录设置 #
更改各项登录设置。这些设置主要储存在 /etc/login.defs
文件中。
4.28.4 新用户设置(useradd
设置) #
设置允许的最小和最大用户和组 ID。
4.28.5 Linux 安全模块 (LSM) 设置 #
在 SUSE Linux Enterprise 15.4 及更高版本中,安装控制文件中包含一个新选项 <lsm_select>
,用于配置安装后默认激活以下哪个 Linux 安全模块 (LSM):AppArmor、SELinux,或者不激活。
- selinux_mode
可选。配置 SELinux 模式。值:
permissive
、enforcing
和disabled
。- lsm_select
可选。安装期间要选择的主要 Linux 安全模块。值:
selinux
、apparmor
或none
。
4.29 Linux 审计框架 (LAF) #
此模块允许配置审计守护程序以及为审计子系统添加规则。
<audit-laf> <auditd> <flush>INCREMENTAL</flush> <freq>20</freq> <log_file>/var/log/audit/audit.log</log_file> <log_format>RAW</log_format> <max_log_file>5</max_log_file> <max_log_file_action>ROTATE</max_log_file_action> <name_format>NONE</name_format> <num_logs>4</num_logs> </auditd> <rules/> </audit-laf>
auditd/flush
描述如何将数据写入磁盘。
如果设置为
INCREMENTAL
,“频率”参数将告知要在写入多少条记录后向磁盘发出显式刷新命令。NONE
表示不采取特殊措施来刷新数据,DATA
表示将数据部分保持同步,SYNC
表示将数据和元数据保持完全同步。auditd/freq
此参数告知要在写入多少条记录后向磁盘发出显式刷新命令。
参数
flush
需设置为INCREMENTAL
。auditd/log_file
日志文件的完整路径名。
auditd/log_fomat
需要记录多少信息。
设置为
RAW
会记录所有数据(完全按照内核发送数据的格式储存数据),设置为NOLOG
会丢弃所有审计信息,而不是将其写入磁盘(不影响已发送到调度程序的数据)。auditd/max_log_file
需要记录多少信息。
单位:MB
auditd/num_logs
日志文件数。
max_log_file_action
需设置为ROTATE
auditd/max_log_file_action
达到日志容量时所执行的操作。
如果操作设置为
ROTATE
,“日志文件数”将指定要保留的文件数。如果设置为SYSLOG
,审计守护程序会向系统日志写入警告。如果设置为SUSPEND
,守护程序将停止向磁盘写入记录。IGNORE
表示不执行任何操作,KEEP_LOGS
类似于ROTATE
,但不会覆盖日志文件。auditd/name_format
“计算机名称格式”描述如何将计算机名称写入日志文件。
如果设置
USER
,则会使用用户定义的名称。NONE
表示不插入计算机名称。HOSTNAME
使用“gethostname”系统调用返回的名称。FQD
使用完全限定的域名。rules
auditctl 的规则
您可以手动编辑规则,但我们仅建议由高级用户执行这种操作。有关所有选项的详细信息,请参见
man auditctl
。
4.30 用户和组 #
4.30.1 用户 #
可以在 <users>
部分定义用户列表。要能成功登录,请确保已设置 root
用户,或者已将 rootpassword
指定为 linuxrc
选项。
<users config:type="list"> <user> <username>root</username> <user_password>password</user_password> <encrypted config:type="boolean">false</encrypted> </user> <user> <username>tux</username> <user_password>password</user_password> <encrypted config:type="boolean">false</encrypted> </user> </users>
以下示例演示了一种更复杂的方案。将应用 /etc/default/useradd
中的系统范围默认设置,例如外壳,或主目录的父目录。
<users config:type="list"> <user> <username>root</username> <user_password>password</user_password> <uid>1001</uid> <gid>100</gid> <encrypted config:type="boolean">false</encrypted> <fullname>Root User</fullname> <authorized_keys config:type="list"> <listentry>command="/opt/login.sh" ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQDKLt1vnW2vTJpBp3VK91rFsBvpY97NljsVLdgUrlPbZ/L51FerQQ+djQ/ivDASQjO+567nMGqfYGFA/De1EGMMEoeShza67qjNi14L1HBGgVojaNajMR/NI2d1kDyvsgRy7D7FT5UGGUNT0dlcSD3b85zwgHeYLidgcGIoKeRi7HpVDOOTyhwUv4sq3ubrPCWARgPeOLdVFa9clC8PTZdxSeKp4jpNjIHEyREPin2Un1luCIPWrOYyym7aRJEPopCEqBA9HvfwpbuwBI5F0uIWZgSQLfpwW86599fBo/PvMDa96DpxH1VlzJlAIHQsMkMHbsCazPNC0++Kp5ZVERiH root@example.net</listentry> </authorized_keys> </user> <user> <username>tux</username> <user_password>password</user_password> <uid>1002</uid> <gid>100</gid> <encrypted config:type="boolean">false</encrypted> <fullname>Plain User</fullname> <home>/Users/plain</home> <password_settings> <max>120</max> <inact>5</inact> </password_settings> </user> </users>
authorized_keys
文件
如果配置文件在 authorized_keys
部分为用户定义了一组 SSH 授权密钥,则会重写现有的 $HOME/.ssh/authorized_keys
文件。如果该文件不存在,将使用指定的内容创建该文件。不在 AutoYaST 控制文件中指定相应的部分即可避免重写现有的 authorized_keys
文件。
rootpassword
和 root 用户选项
可以在 linuxrc
中指定 rootpassword
,并为 root
用户设置用户部分。如果此部分缺少口令,则会使用 linuxrc
中的口令。配置文件中的口令优先于 linuxrc
口令。
uid
)
Linux 系统上的每个用户都有一个数字用户 ID。您可以使用 uid
手动在 AutoYaST 控制文件中指定这样的用户 ID,也可以使用 uid
让系统自动选择用户 ID。
用户 ID 应在整个系统中唯一。否则,某些应用程序(例如登录管理器 gdm
)可能不再会如预期般工作。
通过 AutoYaST 控制文件添加用户时,强烈建议不要混合使用用户定义的 ID 和自动提供的 ID。否则无法保证 ID 唯一。为通过 AutoYaST 控制文件添加的所有用户指定 ID,或者让系统为所有用户选择 ID。
username
文本
<username>lukesw</username>
必要。应是有效的用户名。如果您不确定,请查看
man 8 useradd
。fullname
文本
<fullname>Tux Torvalds</fullname>
可选。用户的全名。
forename
文本
<forname>Tux</forename>
可选。用户的名字。
surname
文本
<surname>Skywalker</surname>
可选。用户的姓氏。
uid
数字
<uid>1001</uid>
可选。用户 ID。此 ID 应唯一,且必须是非负数。如果未指定,AutoYaST 将自动选择一个用户 ID。有关更多信息,另请参见注意:指定用户 ID (
uid
)。gid
数字
<gid>100</gid>
可选。初始组 ID。此 ID 必须唯一且为非负数。此外,它必须引用现有的组。
home
路径
<home>/home/luke</home>
可选。用户主目录的绝对路径。默认将使用
/home/username
(例如,alice
的主目录将是/home/alice
)。home_btrfs_subvolume
布尔
<home_btrfs_subvolume config:type="boolean">true</home_btrfs_subvolume>
可选。在 Btrfs 子卷中生成主目录。默认已禁用。
shell
路径
<shell>/usr/bin/zsh</shell>
可选。
/bin/bash
是默认值。如果您选择其他软件,请确保该软件已安装(将对应的软件包添加到software
部分)。user_password
文本
<user_password>some-password</user_password>
可选。如果您输入感叹号 (
!
),将生成随机口令。可以写入纯文本(不建议)或加密形式的用户口令。要创建加密的口令,请使用mkpasswd
。输入/etc/shadow
(第二列)中写入的口令。要在配置文件中启用或禁用加密的口令,请参见encrypted
参数。encrypted
布尔
<encrypted config:type="boolean">true</encrypted>
可选。如果未指定,则视为
false
。指示是否加密配置文件中的用户口令。AutoYaST 支持标准加密算法(请参见man 3 crypt
)。password_settings
密码设置
<password_settings> <expire/> <max>60</max> <warn>7</warn> </password_settings>
可选。可以自定义某些口令设置:
expire
(采用YYYY-MM-DD
格式的帐户失效日期)、flag
(/etc/shadow
标志)、inact
(口令失效多少天后禁用帐户)、max
(口令保持有效的最长天数)、min
(口令失效后的宽限期天数,在此期间用户仍可更改口令)和warn
(在口令失效之前的多少天开始发出口令更改提醒)。authorized_keys
授权密钥的列表
<authorized_keys config:type="list"> <listentry>ssh-rsa ...</listentry> </authorized_keys>
要写入到
$HOME/.ssh/authorized_keys
的授权密钥列表。请参见以下示例。
4.30.2 用户默认值 #
配置文件可为新用户指定一组默认值,例如口令失效日期、初始组、主目录前缀等。除了将这些设置用作配置文件中定义的用户的默认值以外,AutoYaST 还会将这些设置写入 /etc/default/useradd
或要从中读取 useradd
的任何其他适当文件。
group
文本
<group>100</group>
可选。默认的初始登录组。
home
路径
<home>/home</home>
可选。用户的主目录前缀。
expire
日期
<expire>2017-12-31</expire>
可选。默认的口令失效日期,采用
YYYY-MM-DD
格式。inactive
数字
<inactive>3</inactive>
可选。在多少天后禁用已失效的帐户。
shell
路径
<shell>/usr/bin/fish</shell>
默认登录外壳。
/bin/bash
是默认值。如果您选择其他软件,请确保该软件已安装(将对应的软件包添加到software
部分)。umask
文件创建模式掩码
<umask>022</umask>
为主目录设置文件创建模式掩码。默认情况下,
useradd
将使用022
。有关更多信息,请查看man 8 useradd
和man 1 umask
。
4.30.3 组 #
可按以下示例中所示,在 <groups>
中定义组列表。
<groups config:type="list"> <group> <gid>100</gid> <groupname>users</groupname> <userlist>bob,alice</userlist> </group> </groups>
groupname
文本
<groupname>users</groupname>
必要。应是有效的组名。如果您不确定,请查看
man 8 groupadd
。gid
数字
<gid>100</gid>
可选。组 ID。此 ID 必须唯一且为非负数。
userlist
用户列表
<userlist>bob,alice</userlist>
可选。属于该组的用户列表。必须用逗号分隔用户名。
4.30.4 登录设置 #
可以通过 AutoYaST 配置文件启用两项特殊登录设置:自动登录和无口令登录。默认已禁用这两种登录方式。
<login_settings> <autologin_user>vagrant</autologin_user> <password_less_login config:type="boolean">true</password_less_login> </login_settings>
password_less_login
布尔
<password_less_login config:type="boolean">true</password_less_login>
可选。启用无口令登录。此设置仅影响图形登录。
autologin_user
文本
<autologin_user>alice</autologin_user>
可选。为给定的用户启用自动登录。
4.31 自定义用户脚本 #
通过将脚本添加到自动安装过程,您可以根据自己的需求自定义安装,并实现对不同安装阶段的控制。
在自动安装过程中,可以在不同的时间点执行五种类型的脚本:
所有脚本需位于 <scripts> 部分。
pre-scripts
(初期,在任何其他操作尚未真正发生之前)postpartitioning-scripts
(在分区并挂载到/mnt
之后,但在 RPM 安装之前)chroot-scripts
(在安装软件包之后,首次引导之前)post-scripts
(在首次引导已安装系统期间,未运行任何服务)init-scripts
(在首次引导已安装的系统期间,所有服务已启动并正在运行)
4.31.1 安装前脚本 #
在 YaST 对系统进行任何实际更改之前执行(进行分区和软件包安装之前,但在硬件检测之后)。
您可以使用安装前脚本来修改控制文件,并让 AutoYaST 重新读取控制文件。在 /tmp/profile/autoinst.xml
中找到您的控制文件。调整该文件,并将修改后的版本储存在 /tmp/profile/modified.xml
中。完成安装前脚本后,AutoYaST 将读取修改后的文件。
还可以修改安装前脚本中的储存设备。例如,您可以创建新的分区,或更改某些技术(例如多路径)的配置。执行所有安装前脚本后,AutoYaST 始终会再次检查储存设备。
安装前脚本于早期安装阶段执行。这意味着,如果您请求确认安装,则会先执行安装前脚本,然后再显示确认屏幕 (profile/install/general/mode/confirm
)。
要在安装前脚本中调用 Zypper,需要设置环境变量 ZYPP_LOCKFILE_ROOT="/var/run/autoyast",以免与正在运行的 YaST 进程冲突。
必须按如下所示放置安装前脚本元素:
<scripts> <pre-scripts config:type="list"> <script> ... </script> </pre-scripts> </scripts>
4.31.2 分区后脚本 #
在 YaST 已完成分区并已写入 /etc/fstab
之后执行。空系统已挂载到 /mnt
。
必须按如下所示放置分区后脚本元素:
<scripts> <postpartitioning-scripts config:type="list"> <script> ... </script> </postpartitioning-scripts> </scripts>
4.31.3 Chroot 环境脚本 #
Chroot 脚本是在首次重引导计算机之前执行的。您可以在安装 chroot 进入已安装系统并配置引导加载程序之前执行 chroot 脚本,也可以在 chroot 进入已安装系统之后(请查看 chrooted
参数来确定该状态)执行脚本。
必须按如下所示放置 Chroot 环境脚本元素:
<scripts> <chroot-scripts config:type="list"> <script> ... </script> </chroot-scripts> </scripts>
4.31.4 安装后脚本 #
这些脚本是在 AutoYaST 已完成系统配置并已首次引导系统之后执行的。
必须按如下所示放置安装后脚本元素:
<scripts> <post-scripts config:type="list"> <script> ... </script> </post-scripts> </scripts>
4.31.5 Init 脚本 #
当 YaST 已完成,于已初始化网络之后的初始引导过程中会执行这些脚本。这些最终脚本是使用 /usr/lib/YaST2/bin/autoyast-initscripts.sh
执行的,并且只会执行一次。Init 脚本是使用标记 init-scripts 配置的。
必须按如下所示放置 Init 脚本元素:
<scripts> <init-scripts config:type="list"> <script> ... </script> </init-scripts> </scripts>
Init 脚本与其他脚本类型不同,因为它们不是由 YaST 执行,而是在 YaST 已完成后执行。因此,它们的 XML 表示不同于其他脚本类型。
location
定义从中提取脚本的位置。位置可以与配置文件的位置相同(HTTP、FTP、NFS 等)。
<location>http://10.10.0.1/myInitScript.sh</location>
必须定义 <location> 或 <source>。
source
脚本本身(源代码),封装在 CDATA 标记中。如果您不想将整个外壳脚本放入 XML 配置文件,请使用位置参数。
<source> <![CDATA[echo "Testing the init script" >/tmp/init_out.txt]]></source>
必须定义 <location> 或 <source>。
filename
脚本的文件名。此文件将储存在
/tmp
下的临时目录中。<filename>mynitScript5.sh</filename>
如果您只有一个 init 脚本,则此元素是可选的。在这种情况下,将使用默认名称 (
init-scripts
)。如果您指定了多个 init 脚本,则必须为每个脚本设置唯一的名称。rerun
正常情况下,一个脚本只运行一次,即使您使用
ayast_setup
多次运行 XML 文件也是如此。将此布尔值设置为true
可更改此默认行为。<rerun config:type="boolean">true</rerun>
可选。默认值为
false
(脚本只运行一次)。
手动将脚本添加到控制文件时,需将脚本包含在 CDATA 元素中,以避免与文件语法以及控制文件中定义的其他标记产生混淆。
4.31.6 脚本 XML 表示 #
下面所述的大多数 XML 元素都可用于上述所有脚本类型,但 init 脚本除外,此类脚本的定义可能只包含这些元素的一部分。有关此类脚本的更多信息,请参见第 4.31.5 节 “Init 脚本”。
debug
元素已弃用,在将来的版本中可能会将其去除。为适应此情况,请在 interpreter
中使用解释器特定的调试参数。例如,不要使用 <interpreter>shell</interpreter>,而是使用 <interpreter>/bin/sh -x</interpreter>,其效果等同于启用 debug
标志。
location
定义从中提取脚本的位置。位置可以与控制文件的位置相同(HTTP、FTP、NFS 等)。此外,也可以使用相对 URL 来定义控制文件所在目录的相对路径,语法为
relurl://script.sh
。<location>http://10.10.0.1/myPreScript.sh</location>
必须定义
location
或source
。source
脚本本身(源代码),封装在 CDATA 标记中。如果您不想将整个外壳脚本放入 XML 控制文件,请引用位置参数。
<source> <![CDATA[ echo "Testing the pre script" > /tmp/pre-script_out.txt ]]> </source>
必须定义
location
或source
。interpreter
指定必须为脚本使用的解释器。可以指定给定环境中任何可用的解释器。您可以提供解释器的完整路径,包括参数。
debug
标志支持的关键字解释器“shell”、“perl”和“python”也已弃用。<interpreter>/bin/bash -x</interpreter>
可选;默认值为
shell
。file name
脚本的文件名。此文件将储存在
/tmp
下的临时目录中。<filename>myPreScript5.sh</filename>
可选;默认值为脚本的类型(在本例中为 pre-scripts)。如果您有多个脚本,应该为每个脚本定义不同的名称。如果未定义
filename
,但定义了location
,将会使用该位置路径中的文件名。feedback
如果此布尔值为
true
,则会在弹出窗口中显示脚本的输出和错误消息(STDOUT 和 STDERR)。用户需要通过“确定”按钮确认这些消息。<feedback config:type="boolean">true</feedback>
可选;默认值为
false
。feedback_type
可以是
message
、warning
或error
。在 <report> 部分设置这些弹出窗口的超时。<feedback_type>warning</feedback_type>
可选;如果未指定,将使用始终阻止弹出窗口。
debug
如果此元素为
true
,将记录外壳脚本的每一行。将在打开警告的情况下运行 Perl 脚本。这仅适用于弃用的关键字interpreter
。对于其他语言,请在interpreter
值中以参数形式提供解释器的路径,例如“<interpreter>ruby -w</interpreter>”。<debug config:type="boolean">true</debug>
可选;默认值为
true
。notification
将会根据脚本在后台运行的时间长短在弹出窗口中显示此文本。
<notification>Please wait while script is running...</notification>
可选;如果未配置,则不显示通知弹出窗口。
param-list
可以指定提供给所要调用的脚本的参数。您可以指定多个
param
项。在脚本命令行上使用单个空格字符串联这些项。如果必须指定任何外壳引用(例如,为了保护嵌入的空格),则需要包含此元素。<param-list config:type="list"> <param>par1</param> <param>par2 par3</param> <param>"par4.1 par4.2"</param> </param-list>
可选;如果未配置,则不会将任何参数传递给脚本。
rerun
一个脚本只运行一次。即使您使用
ayast
_setup 多次运行 XML 文件,该脚本也只运行一次。将此布尔值设置为true
可更改此默认行为。<rerun config:type="boolean">true</rerun>
可选;默认值为
false
,表示脚本只运行一次。chrooted
在安装期间,新系统将挂载到
/mnt
。如果此参数设置为false
,AutoYaST 将不运行chroot
,并且在此阶段不会安装引导加载程序。如果该参数设置为true
,则 AutoYaST 会执行chroot
进入/mnt
并安装引导加载程序。结果是,您不再需要使用/mnt
前缀就能更改新安装系统中的任何设置。<chrooted config:type="boolean">true</chrooted>
可选;默认值为
false
。此选项仅适用于 chroot 环境脚本。
4.31.7 脚本示例 #
<?xml version="1.0"?> <!DOCTYPE profile> <profile xmlns="http://www.suse.com/1.0/yast2ns" xmlns:config="http://www.suse.com/1.0/configns"> <scripts> <chroot-scripts config:type="list"> <script> <chrooted config:type="boolean">true</chrooted> <filename>chroot-post.sh</filename> <interpreter>shell</interpreter> <source><![CDATA[ echo "Testing chroot (chrooted) scripts" ls ]]> </source> </script> <script> <filename>chroot-pre.sh</filename> <interpreter>/bin/bash -x</interpreter> <source><![CDATA[ echo "Testing chroot scripts" df cd /mnt ls ]]> </source> </script> </chroot-scripts> <post-scripts config:type="list"> <script> <filename>post.sh</filename> <interpreter>shell</interpreter> <source><![CDATA[ echo "Running Post-install script" systemctl start portmap mount -a 192.168.1.1:/local /mnt cp /mnt/test.sh /tmp umount /mnt ]]> </source> </script> <script> <filename>post.pl</filename> <interpreter>perl</interpreter> <source><![CDATA[ print "Running Post-install script"; ]]> </source> </script> </post-scripts> <pre-scripts config:type="list"> <script> <interpreter>shell</interpreter> <location>http://192.168.1.1/profiles/scripts/prescripts.sh</location> </script> <script> <filename>pre.sh</filename> <interpreter>shell</interpreter> <source><![CDATA[ echo "Running pre-install script" ]]> </source> </script> </pre-scripts> <postpartitioning-scripts config:type="list"> <script> <filename>postpart.sh</filename> <interpreter>shell</interpreter> <debug config:type="boolean">false</debug> <feedback config:type="boolean">true</feedback> <source><![CDATA[ touch /mnt/testfile echo Hi ]]> </source> </script> </postpartitioning-scripts> </scripts> </profile>
完成安装后,可以在 /var/adm/autoinstall
目录中找到脚本和输出日志。脚本位于 scripts
子目录中,输出日志位于 log
目录中。
日志中包含执行脚本时产生的输出,包括标准输出和标准错误输出的组合。
如果脚本以非零退出代码结束,一条包含日志内容的警告将会显示,除非提供了 feedback
选项。
4.32 系统变量 (sysconfig) #
使用 sysconfig 资源可以直接在 sysconfig 软件源 (/etc/sysconfig
) 中定义配置变量。使用 sysconfig 变量可以完全按照您的需求微调许多系统组件和环境变量。
以下示例演示如何使用 sysconfig 资源设置变量。
<sysconfig config:type="list" > <sysconfig_entry> <sysconfig_key>XNTPD_INITIAL_NTPDATE</sysconfig_key> <sysconfig_path>/etc/sysconfig/xntp</sysconfig_path> <sysconfig_value>ntp.host.com</sysconfig_value> </sysconfig_entry> <sysconfig_entry> <sysconfig_key>HTTP_PROXY</sysconfig_key> <sysconfig_path>/etc/sysconfig/proxy</sysconfig_path> <sysconfig_value>proxy.host.com:3128</sysconfig_value> </sysconfig_entry> <sysconfig_entry> <sysconfig_key>FTP_PROXY</sysconfig_key> <sysconfig_path>/etc/sysconfig/proxy</sysconfig_path> <sysconfig_value>proxy.host.com:3128</sysconfig_value> </sysconfig_entry> </sysconfig>
可以提供相对路径和绝对路径。如果未指定绝对路径,则会将其视为 /etc/sysconfig
目录下的某个 sysconfig 文件。
4.33 添加完整配置 #
对于许多应用程序和服务,您可能都需要将配置文件复制到已安装系统上的相应位置。例如,如果您正在安装 Web 服务器,可能会有一个服务器配置文件 (httpd.conf
)。
使用此资源您可以通过指定已安装系统上的最终路径,将该文件嵌入控制文件中。YaST 会将此文件复制到指定的位置。
使用此功能需安装 autoyast2 软件包。如果缺少该软件包,AutoYaST 会自动予以安装。
您可以指定要从中检索文件的 file_location
。此位置也可以是网络上的某个位置(例如 HTTP 服务器):<file_location>http://my.server.site/issue</file_location>
。
您也可以使用 relurl://
前缀指定本地文件,例如:<file_location>relurl://path/to/file.conf</file_location>
。
您可以通过指定以斜线结尾的 file_path
来创建目录。
<files config:type="list"> <file> <file_path>/etc/apache2/httpd.conf</file_path> <file_contents> <![CDATA[ some content ]]> </file_contents> </file> <file> <file_path>/mydir/a/b/c/</file_path> <!-- create directory --> </file> </files>
下面演示了一个更高级的示例。此配置将使用 file_contents
中提供的内容创建一个文件,并更改该文件的权限和所有权。将文件复制到系统后,将执行一个脚本。此脚本可用于修改该文件,并使其准备好在客户端环境中使用。
<files config:type="list"> <file> <file_path>/etc/someconf.conf</file_path> <file_contents> <![CDATA[ some content ]]> </file_contents> <file_owner>tux.users</file_owner> <file_permissions>444</file_permissions> <file_script> <interpreter>shell</interpreter> <source> <![CDATA[ #!/bin/sh echo "Testing file scripts" >> /etc/someconf.conf df cd /mnt ls ]]> </source> </file_script> </file> </files>
4.34 安装期间要求用户提供值 #
在安装期间,您可以选择让用户决定控制文件特定部分的值。如果您使用此功能,则安装期间会显示一个弹出窗口请求用户输入控制文件特定部分。如果您想要进行全自动化安装,但应由用户设置本地帐户的口令,则您可以通过在控制文件中使用 ask
指令实现此目的。
下面列出的元素必须放在以下 XML 结构中:
<general> <ask-list config:type="list"> <ask> ... </ask> </ask-list> </general>
question
您要询问用户的问题。
<question>Enter the LDAP server</question>
默认值是元素的路径(该路径通常看起来很奇怪,因此我们建议输入问题)。
default
为用户设置预先选择。将使用此值填充文本输入。将为复选框提供 true 或 false,在选项中会预先选择给定的值。
<default>dc=suse,dc=de</default>
可选。
help
在问题左侧显示的可选帮助文本。
<help>Enter the LDAP server address.</help>
可选。
title
在问题上方显示的可选标题。
<title>LDAP server</title>
可选。
type
要更改的元素类型。可能的值为
symbol
、boolean
、string
和integer
。分区部分中的文件系统为符号,而用户配置中的encrypted
元素为布尔值。如果在控制文件中查看config:type="...."
属性,可以看到该元素的类型。还可以使用static_text
作为类型。static_text
是一段文本,不需要任何用户输入,并可显示帮助文本中不包含的信息。<type>symbol</type>
可选。默认值为
string
。如果 type 为symbol
,则您还必须提供 selection 元素(参见下文)。password
如果此布尔值设置为
true
,将弹出口令对话框而不是简单的文本输入。仅当type
为 string 时,将此项设置为true
才有意义。<password config:type="boolean">true</password>
可选。默认设置为
false
。pathlist
path
元素的列表。path 是逗号分隔的元素列表,用于描述您要更改的元素的路径。例如,可以在控制文件的<ldap><ldap_server>
部分中找到 LDAP server 元素。因此,要更改该值,需将路径设置为ldap,ldap_server
。<pathlist config:type="list"> <path>networking,dns,hostname</path> <path>...</path> </pathlist>
要更改控制文件中第一个用户的口令,需将路径设置为
users,0,user_password
。0
表示控制文件中 <users config:type="list"> 用户列表内的第一个用户。1
是第二个用户,依此类推。<users config:type="list"> <user> <username>root</username> <user_password>password to change</user_password> <encrypted config:type="boolean">false</encrypted> </user> <user> <username>tux</username> <user_password>password to change</user_password> <encrypted config:type="boolean">false</encrypted> </user> </users>
此信息是可选的,但您至少应该提供
path
或file
。file
您可将问题的答案储存在文件中,以供稍后在某个脚本中使用。如果您在
stage=initial
阶段提问,并希望在第 2 阶段使用答案,则需要在chrooted=false
的情况下运行的 chroot 脚本中复制答案文件。使用命令:cp /tmp/my_answer /mnt/tmp/
。原因是第 1 阶段的/tmp
位于 RAM 磁盘中,在重引导后将会丢失,但安装的系统已挂载到/mnt/
。<file>/tmp/answer_hostname</file>
此信息是可选的,但您至少应该提供
path
或file
。stage
Stage 用于配置弹出问题的安装阶段。您可将此值设置为
cont
或initial
。initial
表示在运行安装前脚本后的较短时间内,在安装的初期显示弹出窗口。cont
表示在第一次引导系统时于完成首次重引导后显示包含问题的对话框。您在initial
阶段所回答问题的答案将写入到硬盘上的控制文件。如果您在initial
阶段输入明文口令,则应会了解这一点。当然,在cont
阶段要求使用文件系统没有意义。硬盘在该阶段已经分区,因此问题无效。<stage>cont</stage>
可选。默认值为
initial
。selection
selection 元素包含
entry
元素的列表。每个 entry 表示可供用户选择的一个可能选项。用户无法在文本框中输入值,但可以从值列表中选择值。<selection config:type="list"> <entry> <value> btrfs </value> <label> Btrfs File System </label> </entry> <entry> <value> ext3 </value> <label> Extended3 File System </label> </entry> </selection>
对于
type=string
此元素为可选的,对于type=boolean
此元素不可用,对于type=symbol
此元素是必需的。dialog
您可以在每个对话框询问多个问题。为此,请使用整数指定 dialog-id。具有相同 dialog-id 的所有问题同属于一个对话框。对话框也按 ID 排序。
<dialog config:type="integer">3</dialog>
可选。
element
您可以在每个对话框中包含多个问题。为此,需要使用整数指定
element-id
。对话框中的问题按 ID 排序。<element config:type="integer">1</element>
可选(请参见 dialog)。
width
您可以增加对话框的默认宽度。如果每个对话框有多个宽度规范,则将使用最大的值。该数字大致相当于字符数。
<width config:type="integer">50</width>
可选。
height
您可以增加对话框的默认高度。如果每个对话框有多个高度规范,则将使用最大的值。该数字大致相当于行数。
<height config:type="integer">15</height>
可选。
frametitle
您可以在每个对话框中包含多个问题。对话框中的每个问题都有一个框架,该框架可以具有框架标题(每个问题的小标题)。您可将多个元素放入一个框架中。这些元素需使用相同的框架标题。
<frametitle>User data</frametitle>
可选;默认不使用框架标题。
script
您可以在回答问题后运行脚本。(有关脚本的详细说明,请参见第 4.34.1 节 “默认值脚本”。)
<script>...</script>
可选;默认为无脚本。
ok_label
您可以更改
按钮上的标签。以指定对话框标签的最后一个元素为准。<ok_label>Finish</ok_label>
可选。
back_label
您可以更改
按钮上的标签。以指定对话框标签的最后一个元素为准。<back_label>change values</back_label>
可选。
timeout
您可在此处指定一个用作超时(以秒为单位)的整数。如果用户在超时之前未回答问题,则会使用默认值回答。当用户触摸或更改对话框中的任一控件时,将关闭超时,并需要通过
来确认对话框中的操作。<timeout config:type="integer">30</timeout>
可选;缺失值将被解释为
0
,即关闭超时。default_value_script
您可以运行脚本来设置问题的默认值(有关默认值脚本的详细说明,请参见第 4.34.1 节 “默认值脚本”)。如果您可以
计算
默认值(特别是与timeout
选项结合使用时),此功能将十分有用。<default_value_script>...</default_value_script>
可选;默认为无脚本。
4.34.1 默认值脚本 #
您可以运行脚本来设置问题的默认值。如果您可以计算
默认值(特别是与 timeout
选项结合使用时),此功能将十分有用。
通过在以下 XML 结构中添加第 4.31.6 节 “脚本 XML 表示”中所述的元素来定义脚本。
<general> <ask-list config:type="list"> <ask> <default_value_script> ... </default_value_script> </ask> </ask-list> </general>
echo
到 STDOUT 的任何内容都将用作询问对话框的默认值。如果您的脚本包含非 0 退出代码,则会使用常规 default
元素。使用 echo -n
抑制 \n
时请小心,应回显合理的值而非布尔值“okay”(请使用“true”)。
4.34.2 脚本 #
您可以在回答问题后运行脚本。
下面列出的元素必须放在以下 XML 结构中:
<general> <ask-list config:type="list"> <ask> <script> ... </script> </ask> </ask-list> </general>
除了第 4.31.6 节 “脚本 XML 表示”中列出的元素之外,<ask>
元素中的脚本还支持以下选项:
filename
脚本的文件名。
<filename>my_ask_script.sh</filename>
默认值为 ask_script.sh
environment
一个布尔值,用于将问题答案的值作为环境变量传递给脚本。该变量名为
VAL
。<environment config:type="boolean">true</environment>
可选。默认为
false
。feedback
一个布尔值,用于打开脚本执行的反馈。STDOUT 将显示在弹出窗口中,执行脚本后,必须予以确认。
<feedback config:type="boolean">true</feedback>
可选,默认值为
false
。rerun_on_error
在脚本收到退出代码 0(零)之前,将对话框保持在打开状态。您可以使用此功能来验证用户的输入。该脚本应该列显有意义的错误消息并返回一个非零代码。请注意,您还应将
feedback
选项设为true
,以使用户可以读取来自脚本的错误消息。可选,默认值为false
。
脚本可能会创建 /tmp/next_dialog
文件,其中包含要显示的以下对话框的 ID。-1 值会终止该序列。
下面提供了 ask
功能的用法示例。
<general> <ask-list config:type="list"> <ask> <pathlist config:type="list"> <path>ldap,ldap_server</path> </pathlist> <stage>cont</stage> <help>Choose your server depending on your department</help> <selection config:type="list"> <entry> <value>ldap1.mydom.de</value> <label>LDAP for development</label> </entry> <entry> <value>ldap2.mydom.de</value> <label>LDAP for sales</label> </entry> </selection> <default>ldap2.mydom.de</default> <default_value_script> <source> <![CDATA[ echo -n "ldap1.mydom.de" ]]> </source> </default_value_script> </ask> <ask> <pathlist config:type="list"> <path>networking,dns,hostname</path> </pathlist> <question>Enter Hostname</question> <stage>initial</stage> <default>enter your hostname here</default> </ask> <ask> <pathlist config:type="list"> <path>partitioning,0,partitions,0,filesystem</path> </pathlist> <question>File System</question> <type>symbol</type> <selection config:type="list"> <entry> <value config:type="symbol">ext4</value> <label>default File System (recommended)</label> </entry> <entry> <value config:type="symbol">ext3</value> <label>Fallback File System</label> </entry> </selection> </ask> </ask-list> </general>
以下示例演示了如何在不同的 AutoYaST 控制文件之间进行选择。完成询问对话框后,AutoYaST 将再次读取 modified.xml
文件。这样,您便可以提取全新的控制文件。
<general> <ask-list config:type="list"> <ask> <selection config:type="list"> <entry> <value>part1.xml</value> <label>Simple partitioning</label> </entry> <entry> <value>part2.xml</value> <label>encrypted /tmp</label> </entry> <entry> <value>part3.xml</value> <label>LVM</label> </entry> </selection> <title>XML Profile</title> <question>Choose a profile</question> <stage>initial</stage> <default>part1.xml</default> <script> <filename>fetch.sh</filename> <environment config:type="boolean">true</environment> <source> <![CDATA[ wget http://10.10.0.162/$VAL -O /tmp/profile/modified.xml 2>/dev/null ]]> </source> <debug config:type="boolean">false</debug> <feedback config:type="boolean">false</feedback> </script> </ask>tion> </ask-list> </general>
您可以使用如下脚本校验问题的答案:
<general> <ask-list config:type="list"> <ask> <script> <filename>my.sh</filename> <rerun_on_error config:type="boolean">true</rerun_on_error> <environment config:type="boolean">true</environment> <source><![CDATA[ if [ "$VAL" = "myhost" ]; then echo "Illegal Hostname!"; exit 1; fi exit 0 ]]> </source> <debug config:type="boolean">false</debug> <feedback config:type="boolean">true</feedback> </script> <dialog config:type="integer">0</dialog> <element config:type="integer">0</element> <pathlist config:type="list"> <path>networking,dns,hostname</path> </pathlist> <question>Enter Hostname</question> <default>enter your hostname here</default> </ask> </ask-list> </general>
4.35 内核转储 #
此功能在 AArch64 上或 RAM 小于 1 GB 的系统上不可用。
利用 Kdump,如果整个内核崩溃,系统可以创建崩溃转储文件。崩溃转储文件包含系统崩溃时的内存内容。日后,支持人员或(内核)开发人员可以分析此类核心文件,以找出系统崩溃的原因。Kdump 最适合用于您无法在其中轻松再现这种崩溃情况,但必须解决相应问题的服务器。
但是,Kdump 也有一个弊端。启用 Kdump 时需要为 Kdump 额外预留 64 MB 到 128 MB 的系统 RAM,以备在发生系统崩溃以及需要生成转储时使用。
本节仅介绍如何使用 AutoYaST 设置 Kdump,而涉及 Kdump 的工作原理。有关细节,请参见 kdump(7) 手册页。
以下示例演示了 Kdump 一般配置。
<kdump> <!-- memory reservation --> <add_crash_kernel config:type="boolean">true</add_crash_kernel> <crash_kernel>256M-:64M</crash_kernel> <general> <!-- dump target settings --> <KDUMP_SAVEDIR>ftp://stravinsky.suse.de/incoming/dumps</KDUMP_SAVEDIR> <KDUMP_COPY_KERNEL>true</KDUMP_COPY_KERNEL> <KDUMP_FREE_DISK_SIZE>64</KDUMP_FREE_DISK_SIZE> <KDUMP_KEEP_OLD_DUMPS>5</KDUMP_KEEP_OLD_DUMPS> <!-- filtering and compression --> <KDUMP_DUMPFORMAT>compressed</KDUMP_DUMPFORMAT> <KDUMP_DUMPLEVEL>1</KDUMP_DUMPLEVEL> <!-- notification --> <KDUMP_NOTIFICATION_TO>tux@example.com</KDUMP_NOTIFICATION_TO> <KDUMP_NOTIFICATION_CC>spam@example.com devnull@example.com</KDUMP_NOTIFICATION_CC> <KDUMP_SMTP_SERVER>mail.example.com</KDUMP_SMTP_SERVER> <KDUMP_SMTP_USER></KDUMP_SMTP_USER> <KDUMP_SMTP_PASSWORD></KDUMP_SMTP_PASSWORD> <!-- kdump kernel --> <KDUMP_KERNELVER></KDUMP_KERNELVER> <KDUMP_COMMANDLINE></KDUMP_COMMANDLINE> <KDUMP_COMMANDLINE_APPEND></KDUMP_COMMANDLINE_APPEND> <!-- expert settings --> <KDUMP_IMMEDIATE_REBOOT>yes</KDUMP_IMMEDIATE_REBOOT> <KDUMP_VERBOSE>15</KDUMP_VERBOSE> <KEXEC_OPTIONS></KEXEC_OPTIONS> </general> </kdump>
Kdump 默认处于启用状态。下面的配置展示了如何禁用该功能。
<kdump> <add_crash_kernel config:type="boolean">false</add_crash_kernel> </kdump>
4.35.1 内存预留 #
第一步是在引导时为 Kdump 预留内存。由于必须在引导过程的早期预留内存,因此,配置是通过名为 crashkernel
的内核命令行参数完成的。预留的内存将用于装载第二个内核,如此当第一个内核崩溃时,不需要重引导便可执行第二个内核。这第二个内核具有特殊的 initrd,其中包含通过网络保存转储或将转储保存到磁盘、发送通知电子邮件以及最终重引导所需的全部程序。
要为 Kdump 预留内存,请指定 amount
(例如 64M
表示预留 RAM 中的 64 MB 内存)和 offset
。语法为 crashkernel=AMOUNT@OFFSET
。内核可以自动检测正确的偏移量(Xen 超级管理程序除外,在其中需要指定 16M
作为偏移量)。需要预留的内存量取决于体系结构和主内存。有关为 Kdump 预留的内存量的建议,请参见第 18.7.1 节 “Kdump 的手动配置”。
您还可以使用扩展的命令行语法来根据系统 RAM 指定预留的内存量。如果您为多个安装共享一个 AutoYaST 控制文件,或者您经常在一台计算机上去除或安装内存,则这种做法很有用。语法是:
BEGIN_RANGE_1-END_RANGE_1:AMOUNT_1,BEGIN_RANGE_2-END_RANGE_2:AMOUNT_2@OFFSET
BEGIN_RANGE_1
是第一个内存范围的起始(例如:0M
),END_RANGE_1
是第一个内存范围的结束(应假定为 infinity
时可为空),依此类推。例如,256M-2G:64M,2G-:128M
会在系统的 RAM 介于 256 MB 到 2 GB 之间时预留 64 MB 崩溃内核内存,并在系统的 RAM 为 2 GB 以上时预留 128 MB 崩溃内核内存。
另一方面,可为 crashkernel
参数指定多个值。例如,如果您需要预留不同的低内存段和高内存段,可使用诸如 72M,low
和 256M,high
的值:
<kdump> <!-- memory reservation (high and low) --> <add_crash_kernel config:type="boolean">true</add_crash_kernel> <crash_kernel config:type="list"> <listentry>72M,low</listentry> <listentry>256M,high</listentry> </crash_kernel> </kdump>
下面的列表显示了预留内存所需的设置:
add_crash_kernel
如果应预留内存并已启用 Kdump,请设置为
true
。<add_crash_kernel config:type="boolean">true</add_crash_kernel>
必要
crash_kernel
使用上述 crashkernel 命令行语法。
<crash_kernel>256M:64M</crash_kernel>
还支持值列表。
<crash_kernel config:type="list"> <listentry>72M,low</listentry> <listentry>256M,high</listentry> </crash_kernel>
必要
4.35.2 转储保存 #
本节介绍崩溃转储的储存位置及储存方式。
4.35.2.1 目标 #
元素 KDUMP_SAVEDIR
指定要将转储保存到的 URL。可能的方法如下:
使用
file
可保存到本地磁盘;使用
ftp
可保存到 FTP 服务器(不加密);使用
sftp
可保存到 SSH2 SFTP 服务器;使用
nfs
可保存到 NFS 位置;使用
cifs
可将转储保存到 Samba 或 Microsoft Windows 中的 CIFS/SMP 导出。
有关细节,请参见 kdump(5) 手册页。两个示例:file:///var/crash
(符合 FHS 的默认位置)和 ftp://user:password@host:port/incoming/dumps
。将创建一个名称中包含时戳的子目录,并将转储保存到该子目录。
将转储保存到本地磁盘时,可以使用 KDUMP_KEEP_OLD_DUMPS
自动删除旧转储。请将此参数设置为应保留的旧转储数。如果目标分区最终的可用磁盘空间少于 KDUMP_FREE_DISK_SIZE
中指定的值,则不会保存转储。
要将整个内核和调试信息(如果已安装)保存到同一个目录,请将 KDUMP_COPY_KERNEL
设置为 true
。您将在一个目录中获得分析转储所需的全部信息(内核模块及其调试信息除外)。
4.35.2.2 过滤和压缩 #
内核转储未压缩且未过滤。其大小可能与您的系统 RAM 相当。要缩小文件,请在事后压缩转储文件。在打开转储之前需将其解压缩。
要使用页压缩(压缩每个页并允许使用 crash(8) 调试工具进行动态解压缩),请将 KDUMP_DUMPFORMAT
设置为 compressed
(默认值)。
您可能不想要保存所有内存页,例如,那些以零填充的页。要过滤转储,请设置 KDUMP_DUMPLEVEL
。0 会生成完整转储,31 为最小转储。手册页 kdump(5) 和 makedumpfile(8) 列出了每个值会保存哪些页。
4.35.2.3 摘要 #
KDUMP_SAVEDIR
一个 URL,指定要将转储和相关文件保存到的目标。
<KDUMP_SAVEDIR>file:///var/crash/</KDUMP_SAVEDIR>
必要
KDUMP_COPY_KERNEL
如果不仅要将转储保存到
KDUMP_SAVEDIR
,还要将内核及其调试信息(如果已安装)保存到该目标,请设置为true
。<KDUMP_COPY_KERNEL>false</KDUMP_COPY_KERNEL>
可选
KDUMP_FREE_DISK_SIZE
保存转储后必须保留的可用磁盘空间,以 MB 为单位。如果可用空间不足,将不保存转储。
<KDUMP_FREE_DISK_SIZE>64</KDUMP_FREE_DISK_SIZE>
可选
KDUMP_KEEP_OLD_DUMPS
当
KDUMP_SAVEDIR
指向本地目录时要保留(不删除)的转储数。如果您不希望自动删除任何转储,请指定 0;如果要删除除当前转储外的其他所有转储,请指定 -1。<KDUMP_KEEP_OLD_DUMPS>4</KDUMP_KEEP_OLD_DUMPS>
可选
4.35.3 电子邮件通知 #
配置发生计算机崩溃以及保存转储时要发出的电子邮件通知。
由于 Kdump 在 initrd 中运行,本地邮件服务器无法发送通知电子邮件。需要指定一台 SMTP 服务器(参见下文)。
您需要在 KDUMP_NOTIFICATION_TO
中提供一个确切地址。可以在 KDUMP_NOTIFICATION_CC
中指定更多地址。在这两种情况下只能使用电子邮件地址,而不能使用实名。
指定 KDUMP_SMTP_SERVER
以及(如果服务器需要身份验证)KDUMP_SMTP_USER
和 KDUMP_SMTP_PASSWORD
。我们不提供对 TLS/SSL 的支持,但将来可能会添加此项支持。
KDUMP_NOTIFICATION_TO
应将电子邮件发送到的一个确切电子邮件地址。可以在
KDUMP_NOTIFICATION_CC
中指定其他收件人。<KDUMP_NOTIFICATION_TO >tux@example.com</KDUMP_NOTIFICATION_TO>
可选(如果为空,则禁用通知)
KDUMP_NOTIFICATION_CC
在通知电子邮件的抄送行中指定的零个、一个或多个收件人。
<KDUMP_NOTIFICATION_CC >wilber@example.com geeko@example.com</KDUMP_NOTIFICATION_CC>
可选
KDUMP_SMTP_SERVER
用于递送邮件的 SMTP 服务器的主机名。支持 SMTP 身份验证(请参见
KDUMP_SMTP_USER
和KDUMP_SMTP_PASSWORD
),但不支持 TLS/SSL。<KDUMP_SMTP_SERVER>email.suse.de</KDUMP_SMTP_SERVER>
可选(如果为空,则禁用通知)
KDUMP_SMTP_USER
与
KDUMP_SMTP_PASSWORD
一起使用的、用于 SMTP 身份验证的用户名。<KDUMP_SMTP_USER>bwalle</KDUMP_SMTP_USER>
可选
KDUMP_SMTP_PASSWORD
与
KDUMP_SMTP_USER
一起使用的、用于 SMTP 身份验证的口令。<KDUMP_SMTP_PASSWORD>geheim</KDUMP_SMTP_PASSWORD>
可选
4.35.4 Kdump 内核设置 #
如前所述,会引导一个特殊内核来保存转储。如果您不想使用自动检测机制来找出使用的内核(请参见 kdump(5) 手册页,其中介绍了用于查找内核的算法),可以在 KDUMP_KERNELVER
中指定自定义内核的版本。如果您将它设置为 foo
,则会使用 /boot/vmlinuz-foo
或 /boot/vmlinux-foo
(在包含 vmlinuz
文件的平台上会遵循此顺序)中的内核。
您可以指定用于引导 Kdump 内核的命令行。通常会使用引导命令行,减少与 Kdump 不相关的设置(例如 crashkernel
参数),添加 Kdump 所需的一些设置(请参见手册页 kdump(5))。要指定其他参数,请使用 KDUMP_COMMANDLINE_APPEND
。如果您完全清除自己所执行的操作并想要指定整个命令行,请设置 KDUMP_COMMANDLINE
。
KDUMP_KERNELVER
用于 Kdump 的内核的版本字符串。将其留空会使用自动检测机制(强烈建议)。
<KDUMP_KERNELVER >2.6.27-default</KDUMP_KERNELVER>
可选(如果为空则使用自动检测)
KDUMP_COMMANDLINE_APPEND
Kdump 内核的其他命令行参数。
<KDUMP_COMMANDLINE_APPEND >console=ttyS0,57600</KDUMP_COMMANDLINE_APPEND>
可选
KDUMP_Command Line
重写自动生成的 Kdump 命令行。须谨慎使用该功能。通常
KDUMP_COMMANDLINE_APPEND
应已足够。<KDUMP_COMMANDLINE_APPEND >root=/dev/sda5 maxcpus=1 irqpoll</KDUMP_COMMANDLINE>
可选
4.35.5 专家设置 #
KDUMP_IMMEDIATE_REBOOT
如果在保存转储后应自动重引导系统,则为
true
,否则为false
。默认设置为自动重引导系统。<KDUMP_IMMEDIATE_REBOOT >true</KDUMP_IMMEDIATE_REBOOT>
可选
KDUMP_VERBOSE
用于指定 Kdump 过程详细程度的位掩码。有关细节,请阅读 kdump(5)。
<KDUMP_VERBOSE>3</KDUMP_VERBOSE>
可选
KEXEC_OPTIONS
装载 Kdump 内核时要传递给 kexec 的其他选项。通常为空。
<KEXEC_OPTIONS>--noio</KEXEC_OPTIONS>
可选
4.36 DNS 服务器 #
可以通过添加 dns-server
资源来配置 Bind DNS 服务器。该资源的三个较直接属性可以使用值 1(启用属性)或 0(禁用属性)。
属性 |
值 |
说明 |
---|---|---|
|
0/1 |
必须将 DNS 服务器监禁在 chroot 中。 |
|
0/1 |
启用 Bind(系统启动时执行)。 |
|
0/1 |
在 LDAP 而不是本机配置文件中储存设置。 |
<dns-server> <chroot>0</chroot> <start_service>1</start_service> <use_ldap>0</use_ldap> </dns-server>
除了这些基本设置外,还可以使用三个类型列表属性来微调服务配置。
列表 |
说明 |
---|---|
|
DNS 服务器日志记录选项。 |
|
Bind 选项,例如要使用的文件和目录、转发器列表,以及其他配置设置。 |
|
服务器已知的 DNS 区域列表,包括所有设置、记录和 SOA 记录。 |
<dns-server> <logging config:type="list"> <listentry> <key>channel</key> <value>log_syslog { syslog; }</value> </listentry> </logging> <options config:type="list"> <option> <key>forwarders</key> <value>{ 10.10.0.1; }</value> </option> </options> <zones config:type="list"> <listentry> <is_new>1</is_new> <modified>1</modified> <options config:type="list"/> <records config:type="list"> <listentry> <key>mydom.uwe.</key> <type>MX</type> <value>0 mail.mydom.uwe.</value> </listentry> <listentry> <key>mydom.uwe.</key> <type>NS</type> <value>ns.mydom.uwe.</value> </listentry> </records> <soa> <expiry>1w</expiry> <mail>root.aaa.aaa.cc.</mail> <minimum>1d</minimum> <refresh>3h</refresh> <retry>1h</retry> <serial>2005082300</serial> <server>aaa.aaa.cc.</server> <zone>@</zone> </soa> <soa_modified>1</soa_modified> <ttl>2d</ttl> <type>master</type> <update_actions config:type="list"> <listentry> <key>mydom.uwe.</key> <operation>add</operation> <type>NS</type> <value>ns.mydom.uwe.</value> </listentry> </update_actions> <zone>mydom.uwe</zone> </listentry> </zones> </dns-server>
4.37 DHCP 服务器 #
使用 dhcp-server
资源可以通过以下六个属性来配置 DHCP 服务器的所有设置。
元素 |
值 |
说明 |
---|---|---|
|
0/1 |
值 1 表示必须将 DHCP 服务器监禁在 chroot 中。 |
|
0/1 |
将此元素设置为 1 会启用 DHCP 服务器(即,在系统启动时运行该服务器)。 |
|
0/1 |
如果设置为 1,则会在 LDAP 而不是本机配置文件中储存设置。 |
|
文本 |
包含启动时要传递给 DHCP 服务器可执行文件的参数的字符串。例如,使用“-p 1234”可监听非标准 1234 端口。有关所有可能选项,请查阅 dhcpd 手册页。如果保留空白,将使用默认值。 |
|
列表 |
DHCP 服务器将在其中操作的网卡的列表。有关确切的格式,请参见以下示例。 |
|
列表 |
用于配置 DHCP 服务器行为的设置的列表。配置是在一个树形结构中定义的,根表示全局选项,其中嵌套子网和主机。 |
<dhcp-server> <allowed_interfaces config:type="list"> <allowed_interface>eth0</allowed_interface> </allowed_interfaces> <chroot>0</chroot> <other_options>-p 9000</other_options> <start_service>1</start_service> <use_ldap>0</use_ldap> <settings config:type="list"> <settings_entry> <children config:type="list"/> <directives config:type="list"> <listentry> <key>fixed-address</key> <type>directive</type> <value>192.168.0.10</value> </listentry> <listentry> <key>hardware</key> <type>directive</type> <value>ethernet d4:00:00:bf:00:00</value> </listentry> </directives> <id>static10</id> <options config:type="list"/> <parent_id>192.168.0.0 netmask 255.255.255.0</parent_id> <parent_type>subnet</parent_type> <type>host</type> </settings_entry> <settings_entry> <children config:type="list"> <child> <id>static10</id> <type>host</type> </child> </children> <directives config:type="list"> <listentry> <key>range</key> <type>directive</type> <value>dynamic-bootp 192.168.0.100 192.168.0.150</value> </listentry> <listentry> <key>default-lease-time</key> <type>directive</type> <value>14400</value> </listentry> <listentry> <key>max-lease-time</key> <type>directive</type> <value>86400</value> </listentry> </directives> <id>192.168.0.0 netmask 255.255.255.0</id> <options config:type="list"/> <parent_id/> <parent_type/> <type>subnet</type> </settings_entry> <settings_entry> <children config:type="list"> <child> <id>192.168.0.0 netmask 255.255.255.0</id> <type>subnet</type> </child> </children> <directives config:type="list"> <listentry> <key>ddns-update-style</key> <type>directive</type> <value>none</value> </listentry> <listentry> <key>default-lease-time</key> <type>directive</type> <value>14400</value> </listentry> </directives> <id/> <options config:type="list"/> <parent_id/> <parent_type/> <type/> </settings_entry> </settings> </dhcp-server>
4.38 防火墙配置 #
从 firewalld
SUSE Linux Enterprise Server15 GA
开始,SuSEfirewall2 已被 取代。使用 SuSEfirewall2 属性的配置文件将被转换为 firewalld
配置文件。但是,并非所有配置文件属性都可转换。有关 firewalld
的细节,请参见第 24.4 节 “firewalld
”。
系统仅部分支持使用基于 SuSEfirewall2 的配置文件,因为许多选项在 firewalld
中无效,并且某些缺失的配置可能会影响网络安全性。
4.38.1 一般防火墙配置 #
在 firewalld
中,一般配置只会公开少量的属性,大部分配置都是按区域进行。
属性 |
值 |
说明 |
---|---|---|
|
布尔 |
是否在应用配置后立即启动 |
|
布尔 |
是否应在每次系统启动时启动 |
|
区域名 |
默认区域适用于未显式指派的任何设置。 |
|
要记录的丢包类型 |
启用记录所选类型的丢包。值: |
|
区域标识符 |
用于标识区域。如果区域未知,将创建一个新区域。 |
|
区域的简短摘要 |
简要概述区域的用途。对于已存在的区域,将忽略此属性。如果未指定,则使用名称。 |
|
区域的说明 |
描述区域的用途。对于已存在的区域,将忽略此属性。如果未指定,则使用名称。 |
|
默认操作 |
定义当没有匹配的规则时要在区域中执行的默认操作。可能的值为 |
4.38.2 防火墙区域配置 #
firewalld
的配置基于用于定义连接信任级别、接口或源地址的多个区域的存在性。可通过多种方式优化每个区域的行为,不过,并非所有属性都已公开。
属性 |
值 |
说明 |
---|---|---|
|
接口名称列表 |
指派到此区域的接口名称列表。接口或源只能属于一个区域。 |
|
服务列表 |
可在此区域中访问的服务列表。 |
|
端口列表 |
要在指派区域中打开的单个端口或端口范围的列表。 |
|
协议列表 |
要在指派区域中打开的或者可在其中访问的协议列表。 |
|
启用掩蔽 |
将在指派区域中启用或禁用网络地址转换 (NAT)。 |
4.38.3 应用 firewalld
配置文件的安装阶段 #
从 SUSE Linux Enterprise Server 15 SP3 开始,通常在安装的第一个阶段结束时应用 firewalld
配置文件(要了解有关安装阶段的信息,请参见第 1.2 节 “概述和概念”)。但某些情况下是在第二个阶段应用配置文件。下面的列表指出了在第一个或第二个阶段应用 firewalld
配置文件的情况。
您运行的 AutoYaST 包含
firewalld
部分,并且您不是通过 SSH 或 VNC 安装 SLE 的。在第一个阶段配置防火墙。您运行的 AutoYaST 包含
firewalld
部分,您是通过 SSH 或 VNC 安装 SLE 的,并且不需要第二个阶段。在第一个阶段配置防火墙。您运行的 AutoYaST 包含
firewalld
部分,您是通过 SSH 或 VNC 安装 SLE 的,并且需要第二个阶段。在第二个阶段配置防火墙。您运行的 AutoYaST 不含
firewalld
部分。在第一个阶段根据默认产品建议配置防火墙。您运行的 AutoYaST 包含或不含 firewall 部分,并使用需要连接网络的自定义脚本。在第一个阶段根据配置文件或产品建议配置防火墙,并且必须调整防火墙配置,以便自定义脚本能够根据需要连接网络。
4.38.4 完整示例 #
下面是 firewall 部分的完整示例,其中包括一般属性和区域特定属性。
<firewall> <enable_firewall config:type="boolean">true</enable_firewall> <log_denied_packets>all</log_denied_packets> <default_zone>external</default_zone> <zones config:type="list"> <zone> <name>public</name> <interfaces config:type="list"> <interface>eth0</interface> </interfaces> <services config:type="list"> <service>ssh</service> <service>dhcp</service> <service>dhcpv6</service> <service>samba</service> <service>vnc-server</service> </services> <ports config:type="list"> <port>21/udp</port> <port>22/udp</port> <port>80/tcp</port> <port>443/tcp</port> <port>8080/tcp</port> </ports> </zone> <zone> <name>dmz</name> <interfaces config:type="list"> <interface>eth1</interface> </interfaces> </zone> </zones> </firewall>
4.39 其他硬件和系统组件 #
除了网络身份验证和安全性等核心组件配置外,AutoYaST 还提供多种硬件和系统配置选项,就如同手动安装以及交互式安装的任何系统上默认提供的选项一样。例如,您可以配置打印机、声音设备、电视卡,以及在 YaST 中具有相应模块的任何其他硬件组件。
添加到 YaST 的任何新配置选项将在 AutoYaST 中自动提供。
4.39.1 打印机 #
AutoYaST 对打印的支持仅限于用于定义如何在客户端上使用 CUPS 进行网络打印的基本设置。
AutoYaST 不支持设置本地打印队列。新式打印机通常是通过 USB 连接的。CUPS 通过类似于 usb://ACME/FunPrinter?serial=1a2b3c
的型号特定设备 URI 访问 USB 打印机。通常无法提前预测正确的 USB 设备 URI,因为此 URI 是在运行时由 CUPS 后端 usb
确定的。因此,无法使用 AutoYaST 设置本地打印队列。
有关如何在客户端工作站上使用 CUPS 通过网络进行打印的基础知识:
在客户端工作站应用程序中,将打印作业提交到 CUPS 守护程序进程 (cupsd
)。cupsd
会将打印作业转发到网络中的 CUPS 打印服务器,打印作业将在该服务器中进行处理。该服务器会将打印机特定的数据发送到打印机设备。
如果网络中只有一台 CPUS 打印服务器,则无需在每个客户端工作站上运行 CUPS 守护程序。更简单的做法是在 /etc/cups/client.conf
中指定 CUPS 服务器并直接访问该服务器(只能设置一个 CUPS 服务器项)。在这种情况下,客户端工作站上运行的应用程序会直接将打印作业提交到指定的 CUPS 打印服务器。
例 4.75 “打印机配置”演示了 printer
配置部分。_conf_content
项一字不差地包含了 cupsd
cupsd 配置文件 /etc/cups/cupsd.conf
的整个内容。client_conf_content
项一字不差地包含了 /etc/cups/client.conf
的整个内容。printer
部分包含 cupsd
配置,但未指定是否应运行 cupsd。
<printer> <client_conf_content> <file_contents><![CDATA[ ... verbatim content of /etc/cups/client.conf ... ]]></file_contents> </client_conf_content> <cupsd_conf_content> <file_contents><![CDATA[ ... verbatim content of /etc/cups/cupsd.conf ... ]]></file_contents> </cupsd_conf_content> </printer>
/etc/cups/cups-files.conf
在版本 1.6 中,CUPS 配置文件已分为两个文件:cupsd.conf
和 cups-files.conf
。从 SUSE Linux Enterprise Server 15 SP4 开始,AutoYaST 仅支持修改 cupsd.conf
,因为 cups-files.conf
中的默认设置便足以满足一般的打印设置。
4.39.2 声音设备 #
下面演示了使用配置系统创建的声音配置示例。
<sound> <autoinstall config:type="boolean">true</autoinstall> <modules_conf config:type="list"> <module_conf> <alias>snd-card-0</alias> <model>M5451, ALI</model> <module>snd-ali5451</module> <options> <snd_enable>1</snd_enable> <snd_index>0</snd_index> <snd_pcm_channels>32</snd_pcm_channels> </options> </module_conf> </modules_conf> <volume_settings config:type="list"> <listentry> <Master config:type="integer">75</Master> </listentry> </volume_settings> </sound>
4.40 导入 SSH 密钥和配置 #
YaST 允许从先前的安装导入 SSH 密钥和服务器配置。还可以通过 AutoYaST 配置文件控制此功能的行为。
<ssh_import> <import config:type="boolean">true</import> <copy_config config:type="boolean">true</copy_config> <device>/dev/sda2</device> </ssh_import>
属性 |
值 |
说明 |
---|---|---|
|
true/false |
将导入 SSH 密钥。如果设置为 |
|
true/false |
同时还会导入 SSH 服务器配置。如果 |
|
分区 |
要从中导入密钥和配置的分区。如果未设置,则使用包含最近访问的密钥的分区。 |
4.41 配置管理 #
AutoYaST 允许将一部分配置委派给某个配置管理工具(例如 Salt)。AutoYaST 负责处理基本系统安装(分区、网络设置等),其余配置任务可委派给其他工具。
虽然本文档中提及了 Puppet,但只有 Salt 才受官方支持。不过,我们欢迎您报告在使用 Puppet 过程中发现的任何问题。
AutoYaST 支持两种不同的方法:
使用配置管理服务器。在这种情况下,AutoYaST 将设置一个配置管理工具。此工具会连接到主服务器以获取配置系统的指令。
从其他位置(例如 HTTP 服务器,或 USB 记忆棒等闪存盘)获取配置,并以独立模式运行配置管理工具。
4.41.1 连接到配置管理服务器 #
当配置管理服务器(Salt 中的主服务器,以及 Puppet jargon)已准备就绪时,此方法特别有用。在这种情况下,最困难的环节可能是设置适当的身份验证机制。
Salt 和 Puppet 都支持以下身份验证方法:
即时手动身份验证。当 AutoYaST 启动客户端时,会生成一个新的身份验证请求。管理员可在服务器上手动接受此请求。AutoYaST 将重试连接。如果同时已接受密钥,则 AutoYaST 会继续安装。
使用预置种子密钥。请参见所选配置管理系统的文档来了解如何生成此类密钥。使用
keys_url
选项告知 AutoYaST 要在何处查找密钥。
在以下配置示例中,AutoYaST 将启动客户端来生成身份验证请求。它最多尝试连接三次,两次尝试之间等待 15 秒。
<configuration_management> <type>salt</type> <master>my-salt-server.example.net</master> <auth_attempts config:type="integer">3</auth_attempts> <auth_time_out config:type="integer">15</auth_time_out> </configuration_management>
但是,在以下示例中,AutoYaST 将从闪存盘(例如 USB 记忆棒)检索密钥,并使用这些密钥连接到主服务器。
<configuration_management> <type>salt</type> <master>my-salt-server.example.net</master> <keys_url>usb:/</keys_url> </configuration_management>
下表汇总了这些方案支持的选项。
属性 |
值 |
说明 |
---|---|---|
|
字符串 |
配置管理名称。目前只有 |
|
字符串 |
配置管理服务器的主机名或 IP 地址。 |
|
整数 |
尝试连接服务器的最大次数。默认值为三次尝试。 |
|
整数 |
尝试连接服务器的间隔时间(以秒为单位)。默认值为 15 秒。 |
|
所用密钥的 URL |
包含 |
|
True/False |
安装后在客户端启用配置管理服务。默认值为 |
4.41.2 以独立模式运行 #
对于简单的方案,不必要部署配置管理服务器。可以改用独立(或无主服务器)模式的 Salt 或 Puppet。
由于没有服务器,AutoYaST 需要知道从何处获取配置。请将配置置于 TAR 存档中并将其储存在任何位置(例如闪存盘、HTTP/HTTPS 服务器或 NFS/SMB 共享上)。
该 TAR 存档的布局必须与预期相同,即放在 Salt 服务器中的 /srv
下。这意味着,您需要将 Salt 状态放入 salt
目录,并将公式放入单独的 formulas
目录。
此外,还可以创建一个 pillar
目录用于包含 pillar 数据。或者,可以使用 pillar_url
选项在单独的 TAR 存档中提供这些数据。
<configuration_management> <type>salt</type> <states_url>my-salt-server.example.net</states_url> <pillar_url>my-salt-server.example.net</pillar_url> </configuration_management>
属性 |
值 |
说明 |
---|---|---|
|
字符串 |
配置管理名称。目前只有 |
|
URL |
Salt 状态 TAR 存档的位置。此存档可以包含公式和 pillar。文件必须位于 |
|
URL |
包含 pillar 的 TAR 存档的位置。 |
|
URL |
Puppet 模块的位置。 |
4.41.3 SUSE Manager Salt 公式支持 #
AutoYaST 以独立模式运行时,可提供 SUSE Manager Salt 公式支持。如果在状态 TAR 存档中找到了公式,AutoYaST 会显示一个屏幕,让用户选择和配置所要应用的公式。
请记住,此功能会导致 AutoYaST 无法执行无人照管的安装,因为 AutoYaST 在此情况下会等待用户的输入。