镜像导入进阶:Customized Linux配置说明

本文涉及的产品
轻量应用服务器 2vCPU 1GiB,适用于搭建电商独立站
轻量应用服务器 2vCPU 4GiB,适用于网站搭建
轻量应用服务器 2vCPU 4GiB,适用于搭建容器环境
简介: 一 什么是Customized Linux 当你的镜像操作系统不在阿里云所支持的已有平台类型中时,您需要选择Customized Linux的平台类型。 对于Customized Linux平台类型的镜像,我们把他当作未知的操作系统类型,无法识别操作系统的各种信息,只能利用约定好的方法把实例运行所需要的必要的配置信息传入到实例中,然后实例启动时运行预定义好的脚本来对这些配置信息进行处理。

什么是Customized Linux
当你的镜像操作系统不在阿里云所支持的已有平台类型中时,您需要选择Customized Linux的平台类型。
对于Customized Linux平台类型的镜像,我们把他当作未知的操作系统类型,无法识别操作系统的各种信息,只能利用约定好的方法把实例运行所需要的必要的配置信息传入到实例中,然后实例启动时运行预定义好的脚本来对这些配置信息进行处理。
配置方法及限制条件
1. 配置方法:
a) 在镜像的第一个分区的根目录下创建目录 aliyun_custom_image
b) 使用该镜像所创建的实例启动在时,阿里云会把实例相关配置信息写入到aliyun_custom_image目录的os.conf文件中(如果不存在该文件则会自动创建)
c) 镜像中需要有一个预定义好的启动脚本,该脚本用来解析os.conf的文件的各项配置,并进行相关配置(详见第四、第五章节)。
2. 限制条件
1)定制版镜像的第一个分区必须可以被写入
2)镜像的虚拟文件大小必须大于5G
3)定制版镜像的第一个分区类型支持 FAT32/EXT2/EXT3/EXT4/UFS
os.conf配置文件示例
1. 经典网络实例的os.conf配置文件示例如下:
hostname=iZ23r29djmjZ
password=cXdlcjEyMzQK
eth0_ip_addr=10.171.254.123
eth0_mac_addr=00:8c:fa:5e:14:23
eth0_netmask=255.255.255.0
eth0_gateway=10.171.254.1
eth0_route="10.0.0.0/8 10.171.254.1;172.16.0.0/12 10.171.254.1"
eth1_ip_addr=42.120.74.105
eth1_mac_addr=00:8c:fa:5e:14:24
eth1_netmask=255.255.255.0
eth1_gateway=42.120.74.1
eth1_route="0.0.0.0/0 42.120.74.1"
dns_nameserver="7.7.7.7 8.8.8.8"
其中各个参数的含义:
hostname:  主机名参数
password:  密码参数, base64编码的字符串
eth0_ip_addr: eth0 网卡 ip 地址
eth0_mac_addr: eth0 网卡 mac 地址
eth0_netmask: eth0 网卡掩码
eth0_gateway: eth0 网卡默认网关
eth0_route: eth0 路由列表(内网路由列表),默认用分号分隔
eth1_ip_addr: eth1 网卡 ip 地址
eth1_mac_addr: eth1 网卡 mac 地址
eth1_netmask: eth1 网卡掩码
eth1_gateway: eth1 网卡默认网关
eth1_route: eth1 路由(默认外网路由)列表,默认用分号分隔
dns_nameserver: dns 地址列表,默认用空格分隔
2. VPC网络的实例配置文件示例如下:
hostname=iZ23r29djmjZ
password=cXdlcjEyMzQK
eth0_ip_addr=10.171.254.123
eth0_mac_addr=00:8c:fa:5e:14:23
eth0_netmask=255.255.255.0
eth0_gateway=10.171.254.1
eth0_route="0.0.0.0/0 10.171.254.1"
dns_nameserver="7.7.7.7 8.8.8.8"
其中各个参数的含义:
hostname:  主机名参数
password:  密码参数, base64编码的字符串
eth0_ip_addr: eth0 网卡 ip 地址
eth0_mac_addr: eth0 网卡 mac 地址
eth0_netmask: eth0 网卡掩码
eth0_gateway: eth0 网卡默认网关
eth0_route: eth0 路由列表,默认用分号分隔
dns_nameserver: dns 地址列表,默认用空格分隔

配置解析脚本-注意事项
配置项的相关信息阿里云会在实例创建时写入到第一个分区的aliyun_custom_image目录的os.conf文件中,Customized Linux配置的关键是要在镜像中预定义好脚本,该脚本将从os.conf中读取相关配置信息并执行这些配置。下面是设计该脚本时需要的一些注意事项。
1. 各配置项设值规则:如第三章的配置项所述,VPC与经典网络实例的配置项数量及部分配置项的取值规则都会有不同
2. 开机启动:该脚本需要设置成开机自动运行
3. 配置文件读取路径:镜像在创建IO优化实例/非IO优化实例时,默认为第一个分区所分配的设备名会不一样;所以在脚本中最好可以以uuid或label 来识别第一个分区的设备
4. 用户密码为base64编码的字符串,所以在设置密码时需要进行相关处理
5. 对于VPC及经典的判断:需要在脚本中判断该实例是经典网络/VPC网络,目前最简单的方法是判断配置项中是否存在“eth1_route”或其他eth1相关的配置项
6. VPC及经典网络的配置项不同之处:对于VPC实例,所写入的os.conf中会把默认外网路由配置在eth0_route参数中;对于经典实例,则会把默认路由配置在eth1_route参数中,内网路由配置在eth0_route中;所以需要在脚本中在判断出当前实例的网络类型后进行分别的解析和处理
7. 配置优化:os.conf中的配置对于某个特定实例来说中需要执行一次即可,所以在脚本执行成功了之后最好可以删除掉os.conf配置文件,同时脚本如果没有读取到os.conf配置,则不执行接下来的配置
8. 自定义镜像的处理:根据customized linux实例所创建的自定义镜像,在镜像中也会包含这个开机启动脚本;使用该自定义镜像创建实例时,阿里云会在实例第一次启动时写入os.conf配置,脚本在判断到该配置存在时即可执行相关配置
9. 相关配置修改时的处理:当实例的配置信息通过阿里云的控制台/API发生变更时,阿里云会把相关信息写入到os.conf中,脚本将被再次执行从而下发这些更改。
脚本示例
以下脚本是以CentOS镜像为例的示例脚本,需要注意如下事项:
1. 该脚本仅供参考,具体的脚本还需您根据实际的操作系统类型进行调整
2. 在使用脚本前,请先在镜像中对脚本进行调试,并保证调试通过
3. 该脚本必须配置为开机自动执行,如放到/etc/init.d/目录下
4. 此为示例脚本,实际使用中您可以根据情况进行细化和优化


#!/bin/bash
### BEGIN INIT INFO
# Provides:          os-conf
# Required-Start:    $local_fs $network $named $remote_fs
# Required-Stop:
# Should-Stop:
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: The initial os-conf job, config the system.
### END INIT INFO

first_partition_dir='/boot/'
os_conf_dir=${first_partition_dir}/aliyun_custom_image
os_conf_file=${os_conf_dir}/os.conf

load_os_conf() {
if [[ -f $os_conf_file ]]; then
. $os_conf_file
return 0
else
return 1
fi
}

cleanup() {
# ensure $os_conf_file is deleted, to avoid repeating config system
rm $os_conf_file >& /dev/null
# ensure $os_conf_dir is exitst
mkdir -p $os_conf_dir
}

config_password() {
if [[ -n $password ]]; then
password=$(echo $password | base64 -d)
if [[ $? == 0 && -n $password ]]; then
echo "root:$password" | chpasswd
fi
fi
}

config_hostname() {
if [[ -n $hostname ]]; then
sed -i "s/^HOSTNAME=.*/HOSTNAME=$hostname/" /etc/sysconfig/network
hostname $hostname
fi
}

config_dns() {
if [[ -n $dns_nameserver ]]; then
dns_conf=/etc/resolv.conf
sed -i '/^nameserver.*/d' $dns_conf
for i in $dns_nameserver; do
echo "nameserver $i" >> $dns_conf
done
fi
}

is_classic_network() {
# vpc: eth0
# classic: eth0 eth1
grep -q 'eth1' $os_conf_file
}

config_network() {
/etc/init.d/network stop
config_interface eth0 ${eth0_ip_addr} ${eth0_netmask} ${eth0_mac_addr}
config_route eth0 ${eth0_route}
if is_classic_network ; then
config_interface eth1 ${eth1_ip_addr} ${eth1_netmask} ${eth1_mac_addr}
config_route eth1 ${eth1_route}
fi
/etc/init.d/network start
}

config_interface() {
local interface=$1
local ip=$2
local netmask=$3
local mac=$4
inteface_cfg="/etc/sysconfig/network-scripts/ifcfg-${interface}"
cat << EOF > $inteface_cfg
DEVICE=$interface
IPADDR=$ip
NETMASK=$netmask
HWADDR=$mac
ONBOOT=yes
BOOTPROTO=static
EOF
}

config_default_gateway() {
local gateway=$1
sed -i "s/^GATEWAY=.*/GATEWAY=$gateway/" /etc/sysconfig/network
}

config_route() {
local interface=$1
local route=$2
route_conf=/etc/sysconfig/network-scripts/route-${interface}
> $route_conf
echo $route | sed 's/;/\n/' | \
while read line; do
dst=$(echo $line | awk '{print $1}')
gw=$(echo $line | awk '{print $2}')
if ! grep -q "$dst" $route_conf 2> /dev/null; then
echo "$dst via $gw dev $interface" >> $route_conf
fi
if [[ "$dst" == "0.0.0.0/0" ]]; then
config_default_gateway $gw
fi
done
}

################## sysvinit service portal ####################

start() {
if load_os_conf ; then
config_password
config_network
config_hostname
config_dns
cleanup
return 0
else
echo "not load $os_conf_file"
return 0
fi
}

RETVAL=0

case "$1" in
    start)
        start
        RETVAL=$?
    ;;
    *)
        echo "Usage: $0 {start}"
        RETVAL=3
    ;;
esac

exit $RETVAL

目录
相关文章
|
4月前
|
安全 Linux 开发工具
【Linux】vim使用与配置教程
Vim是一款功能强大的文本编辑器,广泛应用于Linux环境,是开发者和系统管理员的必备工具。本文介绍了Vim的基本操作与简单配置,涵盖命令模式、插入模式和底行模式的使用方法,以及光标定位、复制粘贴、搜索替换等常用技巧。同时,文章还提供了实用的分屏操作和代码注释方法,并分享了通过`.vimrc`文件进行个性化配置(如显示行号、语法高亮、自动缩进等)的技巧,帮助用户提升文本编辑效率。掌握这些内容,能让Vim更好地服务于日常工作与开发需求。
315 3
|
2月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
187 11
|
1月前
|
Linux 网络安全 开发工具
在Linux下配置gitee与Github的远程仓库
注意,git push后,是输入你的账号与密码。这个步骤可以通过特殊设置省去,但是一开始还是不要太省。
83 0
|
3月前
|
安全 Linux 网络安全
在Linux(CentOS和AWS)上安装更新的git2的方法并配置github-ssh
经过以上这些步骤,你现在就能在GitHub上顺利往返,如同海洋中的航海者自由驰骋。欢迎你加入码农的世界,享受这编程的乐趣吧!
132 10
|
4月前
|
Java Linux 应用服务中间件
在Rocky Linux 9上安装JDK并配置环境变量!
本教程介绍在Rocky Linux 9上安装JDK并配置环境变量的完整步骤。首先更新系统,清理旧版本JDK相关包及残留文件,确保环境干净。接着搜索并安装所需版本的JDK(如OpenJDK 17),验证安装是否成功。然后查找JDK安装路径,配置全局环境变量`JAVA_HOME`和`PATH`,最后验证环境变量设置。按照此流程操作,可顺利完成Java开发环境搭建,支持多版本切换(如JDK 8/11/17)。生产环境请谨慎操作,避免影响现有服务。
611 21
|
3月前
|
人工智能 Kubernetes Ubuntu
linux配置IP
linux配置IP
275 1
|
4月前
|
监控 Shell Linux
Android调试终极指南:ADB安装+多设备连接+ANR日志抓取全流程解析,覆盖环境变量配置/多设备调试/ANR日志分析全流程,附Win/Mac/Linux三平台解决方案
ADB(Android Debug Bridge)是安卓开发中的重要工具,用于连接电脑与安卓设备,实现文件传输、应用管理、日志抓取等功能。本文介绍了 ADB 的基本概念、安装配置及常用命令。包括:1) 基本命令如 `adb version` 和 `adb devices`;2) 权限操作如 `adb root` 和 `adb shell`;3) APK 操作如安装、卸载应用;4) 文件传输如 `adb push` 和 `adb pull`;5) 日志记录如 `adb logcat`;6) 系统信息获取如屏幕截图和录屏。通过这些功能,用户可高效调试和管理安卓设备。
|
5月前
|
Linux Shell
问题记录:解决Linux登录故障,/etc/passwd配置受损该怎么操作
修复/etc/passwd文件是解决Linux登录故障的重要步骤。通过进入单用户模式、挂载文件系统、恢复或手动修复/etc/passwd文件,可以有效解决该问题。保持定期备份系统配置文件是预防此类问题的最佳实践。
152 13
|
5月前
|
Linux Shell
问题记录:解决Linux登录故障,/etc/passwd配置受损该怎么操作
修复/etc/passwd文件是解决Linux登录故障的重要步骤。通过进入单用户模式、挂载文件系统、恢复或手动修复/etc/passwd文件,可以有效解决该问题。保持定期备份系统配置文件是预防此类问题的最佳实践。
174 5
|
6月前
|
弹性计算 运维 Ubuntu
os-copilot在Alibaba Cloud Linux镜像下的安装与功能测试
我顺利使用了OS Copilot的 -t -f 功能,我的疑惑是在换行的时候就直接进行提问了,每次只能写一个问题,没法连续换行更有逻辑的输入问题。 我认为 -t 管道 功能有用 ,能解决环境问题的连续性操作。 我认为 -f 管道 功能有用 ,可以单独创建可连续性提问的task问题。 我认为 | 对文件直接理解在新的服务器理解有很大的帮助。 此外,我还有建议 可以在非 co 的环境下也能进行连续性的提问。
158 7

热门文章

最新文章