晋太元中,武陵人捕鱼为业。缘溪行,忘路之远近。忽逢桃花林,夹岸数百步,中无杂树,芳草鲜美,落英缤纷。渔人甚异之,复前行,欲穷其林。 林尽水源,便得一山,山有小口,仿佛若有光。便舍船,从口入。初极狭,才通人。复行数十步,豁然开朗。土地平旷,屋舍俨然,有良田、美池、桑竹之属。阡陌交通,鸡犬相闻。其中往来种作,男女衣着,悉如外人。黄发垂髫,并怡然自乐。 见渔人,乃大惊,问所从来。具答之。便要还家,设酒杀鸡作食。村中闻有此人,咸来问讯。自云先世避秦时乱,率妻子邑人来此绝境,不复出焉,遂与外人间隔。问今是何世,乃不知有汉,无论魏晋。此人一一为具言所闻,皆叹惋。余人各复延至其家,皆出酒食。停数日,辞去。此中人语云:“不足为外人道也。”(间隔 一作:隔绝) 既出,得其船,便扶向路,处处志之。及郡下,诣太守,说如此。太守即遣人随其往,寻向所志,遂迷,不复得路。 南阳刘子骥,高尚士也,闻之,欣然规往。未果,寻病终。后遂无问津者。
|
Server : Apache System : Linux srv.rainic.com 4.18.0-553.47.1.el8_10.x86_64 #1 SMP Wed Apr 2 05:45:37 EDT 2025 x86_64 User : rainic ( 1014) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /usr/libexec/cloud-init/ |
Upload File : |
#!/bin/sh
# This file is part of cloud-init. See LICENSE file for license information.
# This script is meant to "kvmify" an image. Its not meant to be
# terribly robust, or a good idea to ever run in a "real image".
# its' only intended method of invocation is from the kernel as 'init'
# in which case it will then invoke /sbin/init after it is done
# init=/path/to/kvmify-init
KEY="xupdate"
UMOUNT=""
RMDIR=""
MARK=/var/lib/cloud/sem/uncloud-init.once
ROOT_RW=""
doexec() {
if [ -n "$ROOT_RW" ]; then
mkdir -p "${MARK%/*}";
date > "${MARK}";
fi
cleanup;
log "invoking /sbin/init $*"
exec /sbin/init "$@";
}
log() { echo "::${0##*/}:" "$@"; }
cleanup() {
[ -z "${UMOUNT}" ] || { umount "${UMOUNT}" && unset UMOUNT; }
[ -z "${RMDIR}" ] || { rm -Rf "${RMDIR}" && unset RMDIR; }
[ -z "${ROOT_RW}" ] || { mount -o remount,ro / ; unset ROOT_RW; }
}
updateFrom() {
local dev=$1 fmt=$2
local mp="";
[ "${fmt}" = "tar" -o "${fmt}" = "mnt" ] ||
{ log FAIL "unknown format ${fmt}"; return 1; }
log INFO "updating from ${dev} format ${fmt}"
[ ! -e "${dev}" -a -e "/dev/${dev}" ] && dev="/dev/${dev}"
[ -e "${dev}" ] || { echo "no file $dev"; return 2; }
mp=$(mktemp -d "${TEMPDIR:-/tmp}/update.XXXXXX") &&
RMDIR="${mp}" ||
{ log FAIL "failed to mktemp"; return 1; }
if [ "$fmt" = "tar" ]; then
dd "if=${dev}" | ( tar -C "${mp}" -xf - ) ||
{ log FAIL "failed to extract ${dev}"; return 1; }
elif [ "$fmt" = "mnt" ]; then
mount -o ro "${dev}" "${mp}" && UMOUNT=${mp} ||
{ log FAIL "failed mount ${mp}"; return 1; }
else
log FAIL "unknown format ${fmt}"; return 1;
fi
if [ -d "${mp}/updates" ]; then
rsync -av "${mp}/updates/" "/" ||
{ log FAIL "failed rsync updates/ /"; return 1; }
fi
if [ -f "${mp}/updates.tar" ]; then
tar -C / -xvf "${mp}/updates.tar" ||
{ log FAIL "failed tar -C / -xvf ${mp}/updates.tar"; return 1; }
fi
script="${mp}/updates.script"
if [ -f "${script}" -a -x "${script}" ]; then
MP_DIR=${mp} "${mp}/updates.script" ||
{ log FAIL "failed to run updates.script"; return 1; }
fi
}
fail() { { [ $# -eq 0 ] && log "FAILING" ; } || log "$@"; exit 1; }
[ -s "$MARK" ] && { log "already updated" ; doexec "$@"; }
mount -o remount,rw / || fail "failed to mount rw"
ROOT_RW=1
if [ ! -e /proc/cmdline ]; then
mount -t proc /proc /proc
read cmdline < /proc/cmdline
umount /proc
else
read cmdline < /proc/cmdline
fi
ubuntu_pass=""
for x in ${cmdline}; do
case "$x" in
${KEY}=*)
val=${x#${KEY}=}
dev=${val%:*}
[ "${dev}" = "${val}" ] && fmt="" || fmt=${val#${dev}:}
log "update from ${dev},${fmt}"
updateFrom "${dev}" "${fmt}" || fail "update failed"
log "end update ${dev},${fmt}"
;;
ubuntu-pass=*|ubuntu_pass=*) ubuntu_pass=${x#*=};;
helpmount) helpmount=1;;
root=*) rootspec=${x#root=};;
esac
done
if [ "${ubuntu_pass}" = "R" -o "${ubuntu_pass}" = "random" ]; then
ubuntu_pass=$(python -c 'import string, random;
random.seed(); print "".join(random.sample(string.letters+string.digits, 8))')
log "settting ubuntu pass = ${ubuntu_pass}"
printf "\n===\nubuntu_pass = %s\n===\n" "${ubuntu_pass}" >/dev/ttyS0
fi
[ -z "${ubuntu_pass}" ] ||
printf "ubuntu:%s\n" "${ubuntu_pass}" > /root/ubuntu-user-pass
if [ -e /root/ubuntu-user-pass ]; then
log "changing ubuntu user's password!"
chpasswd < /root/ubuntu-user-pass ||
log "FAIL: failed changing pass"
fi
cp /etc/init/tty2.conf /etc/init/ttyS0.conf &&
sed -i s,tty2,ttyS0,g /etc/init/ttyS0.conf 2>/dev/null &&
log "enabled console on ttyS0"
pa=PasswordAuthentication
sed -i "s,${pa} no,${pa} yes," /etc/ssh/sshd_config 2>/dev/null &&
log "enabled passwd auth in ssh" ||
log "failed to enable passwd ssh"
grep -q vga16fb /etc/modprobe.d/blacklist.conf || {
echo "blacklist vga16fb" >> /etc/modprobe.d/blacklist.conf &&
log "blacklisted vga16fb"
}
#lstr="${rootspec}"
#if ! grep -q "^${lstr}[[:space:]]" /etc/fstab; then
# log "changing / in /etc/ftab to agree with cmdline (${lstr}) (bug 509841)"
# sed -i "s,^\([^[[:space:]#]\+\)\([[:space:]]\+\)/\([[:space:]]\+\),${lstr}\2/\3," /etc/fstab
#fi
doexec "$@"