配置定制版鏡像便于初始化配置實例
如果您的Linux鏡像不在ECS支持的操作系統(tǒng)版本中且不能通過安裝cloud-init完成實例初始化配置,阿里云會將該鏡像當(dāng)作無法識別的操作系統(tǒng)。因此在導(dǎo)入鏡像前,您需要自行在鏡像中添加解析腳本,用于實例初次啟動時完成自動化配置。
為便于區(qū)分,如果您導(dǎo)入的Linux系統(tǒng)鏡像不在ECS支持的操作系統(tǒng)版本中,該操作系統(tǒng)平臺鏡像為非標(biāo)準(zhǔn)平臺鏡像。非標(biāo)準(zhǔn)平臺鏡像雖然來自標(biāo)準(zhǔn)操作系統(tǒng)平臺,但該類鏡像屬于系統(tǒng)關(guān)鍵性配置文件、系統(tǒng)基礎(chǔ)環(huán)境和應(yīng)用方面沒有遵守標(biāo)準(zhǔn)平臺要求的鏡像。導(dǎo)入非標(biāo)準(zhǔn)平臺鏡像時支持選擇的操作系統(tǒng)版本以及配置說明如下:
Others Linux:ECS統(tǒng)一標(biāo)識為其他系統(tǒng)類型。如果導(dǎo)入Others Linux平臺鏡像,ECS不會對所創(chuàng)建的實例做任何處理。創(chuàng)建實例后,需登錄ECS實例自行配置IP、路由和密碼等。
Customized Linux:定制版鏡像。導(dǎo)入Customized Linux鏡像前,需按照本文進(jìn)行配置。
前提條件
需確保您的鏡像滿足如下條件:
第一個分區(qū)(通常是/dev/sda1或/dev/vda1)必須具備寫權(quán)限。
第一個分區(qū)的文件類型只能是FAT32、EXT2、EXT3、EXT4或UFS。
說明您可以通過
blkid /dev/sdXn
(其中sdXn是第一個分區(qū)名稱,例如/sda1)命令查看分區(qū)的文件系統(tǒng)類型。虛擬文件的大小必須大于5 GiB。
說明您可以通過
df -h /dev/sdXn
(其中sdXn是第一個分區(qū)名稱,例如/sda1)命令查看指定分區(qū)的空間。
操作步驟
使用root用戶登錄您制作鏡像的虛擬機(jī)。
在鏡像的第一個分區(qū)的根目錄下新建目錄,目錄名稱必須為
aliyun_custom_image
。mkdir /aliyun_custom_image
使用Customized Linux鏡像創(chuàng)建的ECS實例初次啟動時,阿里云會在
aliyun_custom_image
目錄的os.conf
文件中寫入實例的主機(jī)名、用戶密碼、DNS服務(wù)器等相關(guān)信息。如果不存在os.conf
文件,則系統(tǒng)會自動創(chuàng)建。os.conf
文件內(nèi)容示例:hostname=<yourHostName> password=<yourPassword> eth0_ip_addr=10.0.0.2 eth0_mac_addr=00:xx:xx:xx:xx:23 eth0_netmask=255.255.255.0 eth0_gateway=10.0.0.1 eth0_route="0.0.0.0/0 10.0.0.1" dns_nameserver="7.7.X.X 8.8.8.8"
示例中各參數(shù)說明如下表所示,請您根據(jù)實際環(huán)境配置。
參數(shù)名稱
參數(shù)說明
hostname
主機(jī)名
password
root用戶的密碼
eth0_ip_addr
eth0網(wǎng)卡的IP地址
eth0_mac_addr
eth0網(wǎng)卡的MAC地址
eth0_netmask
eth0網(wǎng)卡的子網(wǎng)掩碼
eth0_gateway
eth0網(wǎng)卡的默認(rèn)網(wǎng)關(guān)的IP地址
eth0_route
eth0內(nèi)網(wǎng)的路由列表,默認(rèn)用空格分隔
dns_nameserver
DNS地址列表,默認(rèn)用空格分隔
在鏡像中創(chuàng)建一份解析腳本(例如腳本名稱為
customized-config.service
),用以讀取和解析os.conf
文件的系統(tǒng)配置。該解析腳本用于ECS實例首次啟動時進(jìn)行自動化配置,例如設(shè)置主機(jī)名、root用戶密碼、DNS服務(wù)器以及網(wǎng)絡(luò)配置等。
腳本內(nèi)容示例:
#!/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 exists 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 interface_cfg="/etc/sysconfig/network-scripts/ifcfg-${interface}" cat << EOF > $interface_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
設(shè)置腳本開機(jī)自啟動。
以下命令以Ubuntu為例,請您根據(jù)實際操作系統(tǒng)選擇開機(jī)自啟動命令。
systemctl daemon-reload systemctl customized-config.service
說明基于Customized Linux鏡像創(chuàng)建的ECS實例新制作自定義鏡像時,鏡像中也會包含開機(jī)啟動腳本。阿里云會在實例第一次啟動時執(zhí)行解析腳本運(yùn)行
os.conf
的相關(guān)配置。
相關(guān)文檔
鏡像配置完成后,您可以在導(dǎo)入自定義鏡像時選擇操作系統(tǒng)版本為Customized Linux。更多信息,請參見導(dǎo)入自定義鏡像。