Elbrus OS ရှိ Veeam မှ Linux အရန်သိမ်းခြင်း။ အစားထိုးတင်သွင်းခြင်း ['?' | '။' | '!']

ဟယ်လို။
Habre တွင် မကြာသေးမီက ဆောင်းပါးများ လက်တွေ့တွင် အစားထိုးတင်သွင်းခြင်း။ အပိုင်း ၁။ ရွေးချယ်စရာများ и တေးဂီတသည် အကြာကြီးမဖွင့်ထားဘဲ ... သို့မဟုတ် Elbrus OS သည် မည်သည့်အခါမျှ အလကားမဖြစ်ခဲ့ပါ။ ငါ့ကို လျစ်လျူရှုထားခဲ့တာမဟုတ်ဘူး။ အရန်လုပ်ဆောင်မှု၏ ဆက်စပ်မှုတွင် ဤပြဿနာကို လေ့လာရန် ဆုံးဖြတ်ခဲ့သည်။ ထိုမှတပါး၊ ဤဆောင်းပါးတွင် Veeam ဆော့ဖ်ဝဲ ထုတ်ကုန်များကို ဖော်ပြထားပြီး၊ ဆိုလိုသည်မှာ သွင်းကုန်အစားထိုးခြင်းကိစ္စတွင် ပြဿနာသည် အထူးသက်ဆိုင်နိုင်သည်။

Elbrus OS ရှိ Veeam မှ Linux အရန်သိမ်းခြင်း။ အစားထိုးတင်သွင်းခြင်း ['?' | '။' | '!']
မူရင်းပုံအရင်းအမြစ်

ပထမဦးစွာ၊ Elbrus OS ကို ဒေါင်းလုဒ်လုပ်ရန် ဆုံးဖြတ်ခဲ့သည်၊ သို့မဟုတ် x86_64 ဗိသုကာလက်ရာအတွက် ရရှိနိုင်သော ဖြန့်ဖြူးမှုသာဖြစ်ပြီး၊ ၎င်းသည် မည်သို့အလုပ်လုပ်သည်ကိုကြည့်ပါ၊ ၎င်းတွင် Linux အတွက် Veeam Agent ကို ထည့်သွင်းရန် ကြိုးစားရန် ဆုံးဖြတ်ခဲ့သည်။ ဒီထဲက ဘာထွက်လာလဲ သိချင်ရင် ကြောင်ကို ကြည့်လိုက်ပါ။

ဒီတော့ တစ်ယောက်ယောက်က မသိရင် သိမ်ငယ်စိတ်လေး ရှိတယ်။ "Elbrus" က ဒီလိုပါပဲ။ Processor ကို တိကျသော အမိန့်ပေးစနစ်ဖြင့် ၎င်းအပြင် Elbrus OS ဆော့ဖ်ဝဲလည်း ပါရှိသည်။ လူကြိုက်များသောယုံကြည်ချက်နှင့်ဆန့်ကျင်ဘက် - Elbrus OS ကိုလည်ပတ်ရန်အတွက် Elbrus ပရိုဆက်ဆာအပေါ်အခြေခံထားသောဟာ့ဒ်ဝဲစနစ်ရှိရန်မလိုအပ်ပါ။ x86 အတွက် "PDK "Elbrus" ရှိသည် - တကယ်တော့၊ ၎င်းသည် တပ်ဆင်ဒစ်ပုံစံဖြင့် အများသူငှာ ဒိုမိန်းတွင် ပေါ်လာသည်။ စကားမစပ်၊ "PDK - ပလပ်ဖောင်းဖွံ့ဖြိုးတိုးတက်ရေးကိရိယာ၊ ဆော့ဖ်ဝဲဆော့ဖ်ဝဲကိရိယာအစုံ" အောက်ခြေမှတ်စုပါရှိသည် - ကောင်းသည်၊ ဆိုလိုသည်မှာထိုနေရာတွင်အနည်းဆုံး compiler တစ်ခုရှိသည်။

နောက်ဆုတ်ခိုင်းလိုက်သေး။ အမှန်မှာ MSVS နှင့် Baguette RTOS ကဲ့သို့သော ပြည်တွင်းဆော့ဖ်ဝဲလ်များနှင့် တစ်ချိန်က ကိုင်တွယ်ခဲ့ဖူးသည်။ MCST မှ ပရိုဆက်ဆာ အပါအဝင် အိမ်တွင်း အစိတ်အပိုင်းများနှင့် အလုပ်လုပ်ရာတွင် အတွေ့အကြုံရှိခဲ့သည်။ ထို့ကြောင့် ဤနယ်ပယ်တွင် တိကျသေချာမှုတစ်ခုရှိကြောင်း ကျွန်ုပ်တာဝန်အပြည့်ဖြင့်ပြောနိုင်ပြီး ဆောင်းပါးတွင် ၎င်းကိုမထိမိစေရန် ကြိုးစားပါမည်။ တကယ်လုပ်ချင်တဲ့အခါ tag [TBD] ကို တင်မယ်။ ဒါကြောင့် ပြတ်ပြတ်သားသား လှည့်စားပြီး ရိုင်းစိုင်းတဲ့ ညည်းညူသံတွေ မပါဘဲနဲ့ ကြိုးစားသွားမှာပါ။ နောက်ဆုံးတွင် ရုရှားကာကွယ်ရေးလုပ်ငန်းနှင့် အစိုးရအေဂျင်စီများကို နားလည်ရန် လိုအပ်သည်။ နိုင်ငံကြီး - အသေးစားဘတ်ဂျက်။ [TBD]။

သုညအဆင့် - ဒေါင်းလုဒ်လုပ်ပါ။ Elbrus OS ကို ရရှိနိုင်ပြီဖြစ်တယ်ဆိုတဲ့ သတင်းဟာ ပဲ့တင်ထပ်နေတာကြောင့် ဖြန့်ချီရေးဆာဗာ ကျဆင်းသွားခဲ့တာ မှတ်သားစရာပါပဲ။ [TBD] ထိုနေရာသို့ ပြောင်းရွှေ့ရန် စဉ်းစားခဲ့သော Yandex နှင့် အင်ဂျင်နီယာကို ကျေးဇူးတင်ပါသည်။ ဒါကြောင့် ဒေါင်းလုဒ်အမြန်နှုန်းက ကောင်းပါတယ်။

ပထမအဆင့် - တပ်ဆင်ခြင်း။ အခမဲ့အသုံးပြုနိုင်သည့် ပထမဆုံး hypervisor တွင် ၎င်းကို ထည့်သွင်းခဲ့သည်။ ကျွန်ုပ်သည် core နှစ်ချောင်း၊ RAM နှစ်ဂစ်၊ ဗီဒီယိုအတွက် 32 MB (ဂရပ်ဖစ်သွင်ပြင်တစ်ခုရှိမည်ဟု ကျွန်တော်ထင်သည်)။ ဒစ်ခ်သည် ပုံမှန်အတိုင်း - 32 GB ဖြစ်သည်။
တပ်ဆင်မှုကို စတင်ခဲ့တယ်။ တပ်ဆင်မှု ညွှန်ကြားချက်များကို ကျွန်ုပ် မသုံးထားသောကြောင့် ၎င်းနှင့် ပတ်သက်၍ မှတ်ချက် မပေးနိုင်ပါ။ TUI တပ်ဆင်မှု အင်တာဖေ့စ်သည် အလွန်သေးငယ်သည်။

Elbrus OS ရှိ Veeam မှ Linux အရန်သိမ်းခြင်း။ အစားထိုးတင်သွင်းခြင်း ['?' | '။' | '!']
ကောင်းပြီ၊ ငါတို့ကမောက်မပါဘဲလုပ်နိုင်တယ်။

ဒုတိယအစမ်းတွင် ကျွန်ုပ်သည် နောက်ထပ်ဝင်းဒိုးတစ်ခုကို စီမံထားသည်။ ဒစ်ခ်မှ ထည့်သွင်းသောအခါတွင် မူရင်းစက်ပစ္စည်း sr0 [TBD] ကို အဘယ်ကြောင့် မရွေးချယ်ရသနည်း။
CD-ROM အရင်းအမြစ်ကို ရွေးပြီး ရှေ့ဆက်ပါ။

Elbrus OS ရှိ Veeam မှ Linux အရန်သိမ်းခြင်း။ အစားထိုးတင်သွင်းခြင်း ['?' | '။' | '!']

အချိန်ဇုန်ကို ရွေးနေစဉ်တွင်၊ စနစ်သည် init boot လုပ်ငန်းစဉ်ကို အသုံးပြုကြောင်း ရုတ်တရက် သိလိုက်ရပြီး ကျွန်ုပ်သည် TTY0 မှ အလုပ်လုပ်ပါသည်။

Elbrus OS ရှိ Veeam မှ Linux အရန်သိမ်းခြင်း။ အစားထိုးတင်သွင်းခြင်း ['?' | '။' | '!']

အိုကေ၊ ထို့နောက် “Elbrus” ကို အသိုင်းအဝိုင်းတစ်ခုအဖြစ် အမျိုးအစားခွဲကြပါစို့ ယုံကြည်သူဟောင်းများ[TBD]။ မူအရ၊ ၎င်းသည် ကောင်းမွန်သည်- အရာအားလုံးကို ဇာတ်ညွှန်းရေးသားထားသောကြောင့် ဒေါင်းလုဒ်လုပ်ခြင်းလုပ်ငန်းစဉ် မည်သို့အလုပ်လုပ်သည်ကို သိရန် အရင်းအမြစ်ကုဒ်ကိုတောင်းရန် မလိုအပ်ပါ။

ကျန်တာတွေက အရေးမကြီးပါဘူး- အရာအားလုံးကို ထည့်ထားပြီး သဘောတူပါတယ်။ လမ်းတစ်လျှောက်တွင်၊ kernel ကို 3.14.79-13.84 ကိုအသုံးပြုကြောင်းတွေ့ရှိခဲ့သည်။ ဟမ်၊ Debian 7 တွင် 3.2 [TBD] ရှိသည်။

ထို့နောက်၊ default disk partitioning ကိုရွေးချယ်ပြီး... သတိပေးချက်တစ်ခုတွေ့သည်-

Elbrus OS ရှိ Veeam မှ Linux အရန်သိမ်းခြင်း။ အစားထိုးတင်သွင်းခြင်း ['?' | '။' | '!']

ဟမ်း၊ တစ်နည်းနည်းနဲ့ အလိုအလျောက် အပိုင်းခွဲခြင်းဟာ 32 ဂစ်ဒစ်နဲ့ ကောင်းကောင်းမဖြေရှင်းနိုင်ခဲ့ပါဘူး။ ငါဒစ်ကိုမပြောင်းခဲ့ပါ၊ "all-in-one" စတိုင်ဖြင့် manual disk partitioning ဖြင့်ရှာဖွေမှုကိုပြီးမြောက်ခဲ့သည်။ ext3 ကို install လုပ်ခဲ့ရတယ် ၊ /boot က ext4 မှာ မရှိနိုင်လို့ပါ။
စနစ်သည် အဖြစ်အပျက်မရှိဘဲ ပေါ်လာသည်။

ဒုတိယခြေထောက် - အခြားရွေးချယ်စရာများကိုရှာဖွေပါ။
ဒုတိယဒစ်၏ အကြောင်းအရာများကို စူးစမ်းလေ့လာပြီးနောက်၊ ဤအရာသည် အပိုပါရှိသော သိုလှောင်မှုတစ်ခုဖြစ်ကြောင်း ကျွန်ုပ်သဘောပေါက်လိုက်ပါသည်။ အထုပ်များတွင်။ ပြီးတော့ /etc/apt/sources.list ကိုကြည့်ရင်း၊ အဲဒါကို /mnt/cdrom မှာ တပ်ဆင်ဖို့ လိုအပ်တယ်ဆိုတာ ကျွန်တော် သဘောပေါက်သွားတယ်။ ဒါပေမယ့် /etc/os-release မတွေ့ဘူး။ ဒါပေမယ့် contents 3.0-rc36 နဲ့ /etc/mcst-version ရှိတယ်။ 3.0 သည် ဗားရှင်းဖြစ်နိုင်သည် - ၎င်းသည် အံကိုက်ဖြစ်ပုံရသော်လည်း rc36? ယေဘူယျအားဖြင့်၊ ပြင်ပဆော့ဖ်ဝဲသည် ဤဖြန့်ဖြူးမှုကို ရှေးရိုးနည်းလမ်းဖြင့် အသိအမှတ်ပြုနိုင်မည်မဟုတ်ပေ။

root partition တွင်၊ /mcst directory သည် ကျွန်ုပ်မျက်လုံးကို ဖမ်းစားလိုက်ပြီး ထိုနေရာတွင် နစ်မြုပ်နေသော နှလုံးသားဖြင့် /mcst/backup ကို ရှာဖွေတွေ့ရှိခဲ့သည်။ ဆိုလိုသည်မှာ၊ အရန်ကိရိယာတစ်ခုရှိသည်၊ ၎င်းသည်စနစ်တွင်တည်ဆောက်ထားသည်။ “ကောင်းလိုက်တာ” “ဒါက ဘယ်လိုအလုပ်လုပ်လဲဆိုတာ ကြည့်ရအောင်။”

ဖိုင်ကူးယူခြင်းကို ပံ့ပိုးပေးသည့် 4Kb bash script /mcst/bin/backup ရှိကြောင်း တွေ့ရှိရပါသည်။ မူရင်းအားဖြင့် - /mcst/backup directory သို့။ ရင်းမြစ်ကုဒ်တွင် rsync အမိန့်ကို မြင်တွေ့ရမည်ဟု မျှော်လင့်ထားသော်လည်း ၎င်းသည် ပုံသေဖွဲ့စည်းပုံတွင် မရှိပါ။ ဇာတ်ညွှန်းသည် ဖိုင်များကို ရိုးရှင်းစွာ ကူးယူသည်။ command သည် ဤကဲ့သို့ ဖြစ်သည်-

cp -rpdx <file backup> <file>

ဖိုင်တစ်ခုလုံး /mcst/bin/backup ကဒီမှာပါ။ဒီဇာတ်ညွှန်းတစ်ခုတည်းနဲ့ အပြည့်အ၀နားလည်ဖို့ မလုံလောက်ဘူးလို့ ချက်ချင်းသတိပေးပါတယ်။ ၎င်းသည် လုပ်ဆောင်ချက်များ၏ စာကြည့်တိုက်ကဲ့သို့ အရာတစ်ခုဖြစ်သည့် /mcst/bin/source မှ လုပ်ဆောင်ချက်များကို ထုတ်ယူသည်။ (44KB) မပါဝင်ပါဘူး။

#!/bin/bash

unalias -a

set +vx

source $(dirname $0)/source
[[ $? != 0 ]] && exit 1

OPTIONS="hvcdrRil:L:"

usage()
{
	echo "Usage: $PROG_NAME [-$OPTIONS] [backup]"
	echo "    h            - this help"
	echo "    v vv vvv     - verbose, very verbose, extremly verbose"
	echo "    c            - create backup"
	echo "    d            - diffs backup and system"
	echo "    r            - recovery system"
	echo "    R            - remove backup"
	echo "    i            - prompt before backup removing"
	echo "    l list       - additional backup files list"
	echo "    L list       - global backup files list"
	echo "    backup       - backup directory, default /mcst/backup/backup"
}

init_prog()
{
	typeset flg=0

	while getopts $OPTIONS opt
	do
		case $opt in
		h ) usage; exit 0;;
		v ) (( verbose = verbose + 1 )); set_verbose;;
		c ) flg=1; c_flg=1;;
		d ) flg=1; d_flg=1;;
		r ) flg=1; r_flg=1;;
		R ) flg=1; R_flg=1;;
		i ) i_flg=1;;
		l ) l_flg=1; list_arg="$list_arg $OPTARG";;
		L ) L_flg=1; LIST_arg="$LIST_arg $OPTARG";;
		* ) usage "Invalid option"; exit 1;;
		esac
	done

	set_verbose

	check_su

	init_variables

	shift $((OPTIND-1))

	if (( $# > 1 ))
	then
		echo_fatal "invalid arguments number, exp 0|1, act $#"
		exit 1
	fi

	[[ $# = 1 ]] && BACKUP=$1

	echo "Backup directory is $BACKUP"

	if [[ $L_flg = 1 ]]
	then
		backup_list="$LIST_arg"
	elif [[ $c_flg != 1 && $R_flg != 1 ]]
	then
		get_output_cmd "cat $BACKUP/$BACKUP_LIST_NAME"
		backup_list="$output_cmd"
	else
		get_output_cmd "get_backup_list"
		backup_list="$output_cmd"
	fi

	if [[ $l_flg = 1 ]]
	then
		backup_list="$backup_list $list_arg"
	fi

	if [[ $flg = 0 ]]
	then
		if [[ -d $BACKUP ]]
		then
			ls -laR $BACKUP
		else
			echo_info "Cannot access $BACKUP"	
		fi
		echo "backup_list=$backup_list"
		exit 0
	fi

###	echo "Backup list: $backup_list"
}

create_file()
{
	typeset f=$1 fr=$2
	typeset fb

	[[ -z $fr ]] && fr=$f

	fb=${f#/}

	fb=$BACKUP/$fb

	xcmd="rm -rf $fb"
	set_cmd "$xcmd"
	run_cmd

	xcmd="mkdir -p $fb"
	set_cmd "$xcmd"
	run_cmd

	if [[ -a $fr ]]
	then
		xcmd="cp -rpdx $fr $fb/file"
		set_cmd "$xcmd"
		run_cmd

		xcmd="touch $fb/create"
		set_cmd "$xcmd"
		run_cmd
	else
		xcmd="touch $fb/delete"
		set_cmd "$xcmd"
		run_cmd
	fi
}

diff_file()
{
	typeset f=$1
	typeset fb

	fb=${f#/}

	fb=$BACKUP/$fb

	if [[ -f $fb/delete ]]
	then
		echo_info "$f absent"
	elif [[ -f $fb/create ]]
	then
#		echo "state: create $f"

		if [[ ! -a $f ]]
		then
			echo_info "cannot access $f"
		else
			xcmd="diff -r $f $fb/file"
			echo "$xcmd"
			set_cmd "$xcmd" "" "0 1 2"
			run_cmd
		fi
	else
		echo_fatal "wrong $f backup"
		exit 1
	fi
}

recovery_file()
{
	typeset f=$1
	typeset fb

	fb=${f#/}

	fb=$BACKUP/$fb

	if [[ ! -a $fb ]]
	then
		echo_fatal "cannot access $fb"
		exit 1
	fi

	xcmd="rm -rf $f"
	set_cmd "$xcmd"
	run_cmd

	if [[ -f $fb/delete ]]
	then
		:
	elif [[ -f $fb/create ]]
	then
		xcmd="cp -rpdx $fb/file $f"
		set_cmd "$xcmd"
		run_cmd
	else
		echo_fatal "wrong $fb backup"
		exit 1
	fi
}

remove_backup()
{
	echo "Remove backup"

	if [[ ! -d $BACKUP ]]
	then
		echo_info "Cannot access $BACKUP"
		return
	fi

	if [[ ! -f $BACKUP/$BACKUP_LIST_NAME ]]
	then
		echo_fatal "$BACKUP_LIST_NAME absent, remove backup manually"
		exit 0
	fi

	answer=
	if [[ $i_flg = 1 ]]
	then
		echo -n "Remove $BACKUP directory (yes/...)?"
		read answer
	else
		answer=yes
	fi
	if [[ $answer = yes ]]
	then
		xcmd="rm -rf $BACKUP"
		set_cmd "$xcmd"
		run_cmd
	fi
}

recovery_backup()
{
	echo "Recovery system from $BACKUP" 

	for f in $backup_list
	do
		get_output_cmd "get_mount_point $f"
		mnt=$output_cmd
		get_output_cmd "is_ro_mounted $mnt"
		mnt=$output_cmd
		if [[ ! -z $mnt ]]
		then
			remount_rw_fs $mnt
		fi 
		recovery_file $f
		if [[ ! -z $mnt ]]
		then
			remount_ro_fs $mnt
		fi 
	done

	echo "The system is ready, reboot the system manually" 
}

create_backup()
{
		echo "Create backup"

		xcmd="mkdir -pm0777 $BACKUP"
		set_cmd "$xcmd"
		run_cmd

		for v in $backup_list
		do
			f=${v%%:*}
			backup_list2="$backup_list2 $f"
			fr=${v#*:}
			create_file $f $fr
		done
		echo "$backup_list2" >$BACKUP/$BACKUP_LIST_NAME
}

diff_backup()
{
	echo "Diffs system and backup" 

	if [[ ! -d $BACKUP ]]
	then
		echo_fatal "cannot access $BACKUP"
		exit 1
	fi

	for f in $backup_list
	do
		diff_file $f
	done
}

main()
{
	typeset f mnt mnt_list answer

	if [[ $R_flg = 1 ]]
	then
		remove_backup
	fi

	if [[ $r_flg = 1 ]]
	then
		recovery_backup
	fi

	if [[ $c_flg = 1 ]]
	then
		create_backup
	fi

	if [[ $d_flg = 1 ]]
	then
		diff_backup
	fi
}

init_prog "$@"

main

exit 0

သို့ပေမယ့် တစ်ခုခုကို နားမလည်ခဲ့ဘူးလား? မှတ်ချက်များတွင် တစ်ယောက်ယောက်က ရှင်းပြနိုင်သည်- ဤ script သည် လုံခြုံပြီး ယုံကြည်စိတ်ချရသော ဒေတာအရန်ကူးခြင်းကို မည်သို့သေချာစေသနည်း။ [TBD]

rsync ကို add-on တွင် ထည့်သွင်းထားသည်။ သိုလှောင်မှုများ။ ဗားရှင်း 3.1.3 ။ rsync ကိုအသုံးပြုခြင်းသည် /mcst/bin/backup အပလီကေးရှင်းအတွက် ပိုမိုကောင်းမွန်သော အခြားရွေးချယ်စရာတစ်ခု ဖြစ်နေဆဲဟု ကျွန်တော်ထင်ပါတယ်။

နောက်တစ်ခုကတော့ အသစ်တစ်ခုတင်ဖို့ ဆုံးဖြတ်လိုက်တယ်။ Linux အတွက် Veeam အေးဂျင့်. တစ်စုံတစ်ယောက်သည် "Veeam နှင့် သွင်းကုန်အစားထိုးခြင်းတို့သည် ၎င်းနှင့် မည်သို့သက်ဆိုင်သနည်း" ဟု မေးလိမ့်မည်။ ဟုတ်ကဲ့၊ ၎င်းသည် မှတ်ပုံတင်စာရင်းတွင် မပါရှိသော်လည်း ၎င်းကို FSTEC မှ အသိအမှတ်ပြုထားပြီး၊ ဆိုလိုသည်မှာ အခြားရွေးချယ်စရာများမရှိလျှင် ၎င်းကို အသုံးပြုနိုင်သည်။ ဆယ့်ငါးမိနစ်ကြာမှ အခြားရွေးချယ်စရာများ မှတ်ပုံတင်"အရန်သိမ်းခြင်း" ဟူသောစကားလုံးအတွက် လင့်ခ် 3 ခုကို ကျွန်ုပ်ရှာတွေ့နိုင်ပါသည် ("အရန်" ဟူသောစကားလုံးအတွက် ကျွန်ုပ်၏မေးခွန်းနှင့် မသက်ဆိုင်ပါ)။ ဤပရိုဂရမ်များကို နက်ရှိုင်းစွာခွဲခြမ်းစိတ်ဖြာခြင်းမပြုရသေးပါ၊ ထို့ကြောင့် ၎င်းတို့သည် Linux အသုံးပြုသည့် စက်များကို အရန်သိမ်းရန်အတွက် မည်မျှသင့်လျော်ကြောင်း ဆုံးဖြတ်ရန် မကြိုးစားပါ။ လိုအပ်သူများ မိမိဘာသာ နိဂုံးချုပ်ပြီး comment တွင် မျှဝေပေးပါမည်။

အဆင့်သုံး - Linux အတွက် Veeam Agent တပ်ဆင်ခြင်း။
ထို့ကြောင့်၊ Linux အတွက် Veeam Agent တွင် veeamsnap kernel module (နည်းလမ်းအားဖြင့်၊ source ကဒီမှာပါ။) နှင့် veeam ပက်ကေ့ချ်ပုံစံဖြင့် သီးသန့်အသုံးပြုသူ-အာကာသကုဒ်။

kernel module ကိုထည့်သွင်းရာတွင် ပြဿနာသေးသေးတစ်ခုရှိသည် - ပျောက်ဆုံးနေသော dkms ပက်ကေ့ခ်ျ။ ၎င်းသည် အရင်းအမြစ်မှ kernel modules များကို တည်ဆောက်နိုင်စေမည့် ဝန်ဆောင်မှုတစ်ခုဖြစ်သည်။ စည်းကမ်းအတိုင်း၊ ၎င်းကို deb ဖြန့်ဝေမှုအားလုံးတွင် ရနိုင်သည်။ အဲဒါကို ပြင်ပကုမ္ပဏီ deb repository ကနေ ဒေါင်းလုဒ်လုပ်ခဲ့ရပါတယ်။ ကျွန်ုပ်ကို ပျော်ရွှင်စေသော အရာတစ်ခုမှာ ပက်ကေ့ချ်သည် ဗိသုကာလက်ရာပေါ်တွင် မမူတည်သောကြောင့် ၎င်းသည် မူလပုံစံအတိုင်း လိုက်ဖက်ပါသည်။ ရရှိနိုင်သော ပက်ကေ့ဂျ်များစာရင်းတွင် အဘယ်ကြောင့် မပါဝင်ခဲ့သနည်း၊ သို့မဟုတ် မဖွံ့ဖြိုးသေးသော [TBD]။ MCST မဟုတ်သော kernel modules များကို မည်သူမျှ တည်ဆောက်ပြီး လုပ်ဆောင်ခြင်း မပြုသင့်ဟု ယူဆနိုင်သည်။ linux-headers များရှိသောကြောင့် ဤနေရာတွင် ကွဲလွဲမှုတစ်ခု အမှန်တကယ်ရှိပါသည်။ ဆိုလိုသည်မှာ၊ ဆန္ဒရှိပါက module ကို လက်ဖြင့်စုစည်းနိုင်ပြီး စက်စတင်သောအခါတွင် script တစ်ခုဖြင့်စတင်နိုင်သည်။ MCST [TBD] မှ မကြာခဏ အပ်ဒိတ်များကို မမျှော်လင့်သင့်ပါ။

"အိုကေ၊ မော်ဂျူးကို တပ်ဆင်ပြီးပါပြီ၊ အခက်ခဲဆုံးအပိုင်းကတော့ ပြီးသွားပါပြီ" ဟု ကျွန်တော်ထင်ခဲ့သည်... deb repository အတွက် veeam package သည် amd64 platform အတွက်ဖြစ်ပြီး Elbrus OS တွင် x86_64 [TBD] platform တစ်ခုရှိသည်။ ကွာခြားချက်မှာ နာမည်တွင်သာရှိသော်လည်း၊ ဤခြားနားချက်သည် Elbrus OS နှင့် ကိုက်ညီမှုမရှိသော Third-party deb repositories မှ ပက်ကေ့ဂျ်အားလုံးနီးပါးကို ဖြစ်စေသည်။ ဤစိတ်အနှောက်အယှက်ဖြစ်စေသော နားလည်မှုလွဲမှားမှုကို ရိုးရှင်းစွာ ဖယ်ရှားနိုင်သည်- အထုပ်ကို ဖြုတ်လိုက်ရုံဖြင့် ဗိသုကာပညာဆိုင်ရာ အချက်အလက်များကို ပြုပြင်ပြီး ၎င်းကို ပြန်လည်ပေါင်းစည်းလိုက်ရုံပင်။ ဘယ်လိုလုပ်ရမလဲ အဲဒါကို Googled ပါ။ ချက်ချင်း

mkdir tmp
dpkg-deb -R original.deb tmp
# edit DEBIAN/postinst
dpkg-deb -b tmp fixed.deb

နောက်ပြဿနာတစ်ခုကတော့ မှီခိုမှုပါ။ လိုအပ်သောဖိုင်များ ရှိနေပုံရသော်လည်း ပက်ကေ့ခ်ျများ မရှိပါ။ အထင်အမြင်မှာ ပက်ကေ့ဂျ်များ၏အမည်များသည် ၎င်းတို့၏ "တင်သွင်းထားသော analogues" များနှင့် ကွဲပြားနေခြင်းဖြစ်သည်။ စာကြည့်တိုက်များသည် ကွဲပြားစွာ ထုပ်ပိုးထားသည်ဟု ဆိုနိုင်သည်။ အလွန်အသေးစိတ်မလေ့လာဘဲ၊ မှီခိုမှုအားလုံးကို ဖယ်ရှားလိုက်ပြီး တပ်ဆင်မှုက ရှေ့ကို ဆက်သွားခဲ့သည်။

ထို့နောက် ဝန်ဆောင်မှုစတင်ကုဒ်နှင့်အတူ ပြဿနာများ ပေါ်ပေါက်လာသည်။ script /lib/init/vars.sh ပျောက်ဆုံးနေပါသည်။ အကြောင်းတစ်ခုခုကြောင့် Elbrus သည် ၎င်းမပါဘဲ စီမံခန့်ခွဲသည်၊ ထို့ကြောင့် ကျွန်ုပ်တို့လည်း ၎င်းကို ဖယ်ရှားပါမည်။ ထို့နောက်၊ ကျွန်ုပ်တို့သည် မက်ဆေ့ဂျ်အထွက်လုပ်ဆောင်ချက်ကို အစားထိုးရပါမည်- log_daemon_msg နှင့် log_end_msg လုပ်ဆောင်ချက်များ ပျောက်ဆုံးနေပါသည်။ /lib/lsb/init-functions ဖိုင်တွင် လှည့်ပတ်ကြည့်ရှုပြီးနောက်၊ log_success_msg လုပ်ဆောင်ချက်ကို ကျွန်ုပ်တွေ့ရှိခဲ့သည် - ၎င်းသည် စမ်းသပ်မှုများအတွက် ကျွန်ုပ်တို့အတွက် ကောင်းမွန်ပါလိမ့်မည်။ စကားမစပ်၊ /lib/lsb/init-functions ဖိုင်တွင် “# Source SuSE`s rc functions” သည် [TBD] ဖိုင်၏အစတွင် ရှိနေသည်။

အထုပ်ကို ဖိုင်တစ်ခုဖြင့် ကြမ်းတမ်းစွာ လုပ်ဆောင်ပြီးနောက်၊ NFS မျှဝေမှုတွင် စက်အရန်ကူးယူမှုကို အောင်မြင်စွာ စတင်နိုင်ခဲ့သည်။ အရန်တပ်ခြင်းကိုလည်း အောင်မြင်ခဲ့သည်။ ထို့ကြောင့်၊ Elbrus PDK ဖြင့် စက်ကို အရန်ကူးယူရာတွင် တာဝန်မရှိဘဲ “ထိုအတိုင်းသာ” ဒေါင်းလုဒ်လုပ်ရန်အတွက်၊ Linux အတွက် Veeam Agent သည် ကျိန်းသေသင့်လျော်သည်ဟု ကျွန်တော်ယုံကြည်ပါသည်။ ပြုပြင်မွမ်းမံမှုတွေ အားလုံးပြီးရင် ဖိုင်တစ်ခုနဲ့တောင်။

ဟုတ်ပါတယ်၊ Elbrus OS ဖြန့်ချီရေးကိရိယာကို ပံ့ပိုးပေးသည့်စာရင်းတွင် မပါဝင်သောကြောင့် တရားဝင်ပံ့ပိုးမထားပါ။ ထို့အပြင်၊ Linux အတွက် Veeam Agent ကို QA ဌာနမှ မစမ်းသပ်ရသေးပါ။ ပံ့ပိုးမှု မရှိပါ (အနည်းဆုံး ဆောင်းပါးကို ထုတ်ဝေသည့်အချိန်တွင်)။

ဇွန်လ ၂၉ ရက်၊ ၂၀၁၇ ခုနှစ် အမိန့်အမှတ် ၃၃၄ ကို အကောင်အထည်ဖော်ရန် ကြိုးစားနေသူများအတွက် ဆောင်းပါးသည် အသုံးဝင်မည်ဟု မျှော်လင့်ပါသည်။ မင်းအတွက် ငါ့... [TBD]။

source: www.habr.com

မှတ်ချက် Add