በሊኑክስ ውስጥ የተጠቃሚ ሁነታን እንዴት መጠቀም እንደሚቻል

የተርጓሚው መግቢያ፡- ወደ ህይወታችን ከገቡት ግዙፍ ኮንቴይነሮች ዳራ አንጻር፣ አንድ ጊዜ በየትኞቹ ቴክኖሎጂዎች እንደጀመረ ለማወቅ በጣም አስደሳች እና ጠቃሚ ሊሆን ይችላል። አንዳንዶቹን እስከ ዛሬ ድረስ በጥቅም ላይ ሊውሉ ይችላሉ, ነገር ግን ሁሉም እንደዚህ አይነት ዘዴዎችን አያስታውሱም (ወይንም በፈጣን እድገታቸው ወቅት ያልተያዙ መሆናቸውን ያውቃል). ከእነዚህ ቴክኖሎጂዎች አንዱ የተጠቃሚ ሁነታ ሊኑክስ ነው። የኦሪጂናል ፀሐፊው ከቀድሞዎቹ እድገቶች መካከል የትኛው አሁንም እንደሚሰራ እና እንደማይሰራ በማሰብ ብዙ ቁፋሮዎችን አድርጓል እና እንደ አንድ ደረጃ በደረጃ መመሪያ በ 2k19 ውስጥ እራስዎን የሆምብሪው ዩኤምኤል እንዴት ማግኘት እንደሚችሉ አንድ ነገር አሰባስቧል። እና አዎ፣ የዋናውን ልጥፍ ደራሲ ወደ ሀብር ጋብዘናል። ካዴይ, ስለዚህ ማንኛውም ጥያቄ ካለዎት - በአስተያየቶቹ ውስጥ በእንግሊዝኛ ይጠይቁ.

በሊኑክስ ውስጥ የተጠቃሚ ሁነታን እንዴት መጠቀም እንደሚቻል

በሊኑክስ ውስጥ ያለው የተጠቃሚ ሁኔታ በእውነቱ የሊኑክስ ከርነል ወደብ ለራሱ ነው። ይህ ሁነታ ሙሉ የሊኑክስ ከርነል እንደ ተጠቃሚ ሂደት እንዲያሄዱ ያስችልዎታል እና አሽከርካሪዎችን ለመፈተሽ በገንቢዎች በብዛት ይጠቀማሉ። ነገር ግን ይህ ሁነታ እንደ አጠቃላይ የማግለል መሳሪያ ጠቃሚ ነው, የእሱ መርህ ከቨርቹዋል ማሽኖች አሠራር ጋር ተመሳሳይ ነው. ይህ ሁነታ ከዶከር የበለጠ ማግለል ይሰጣል፣ ነገር ግን እንደ KVM ወይም Virtual Box ካሉ ሙሉ ቨርቹዋል ማሽን ያነሰ ነው።

በአጠቃላይ የተጠቃሚ ሁነታ ለመጠቀም ያልተለመደ እና አስቸጋሪ መሳሪያ ሊመስል ይችላል, ነገር ግን አሁንም አጠቃቀሞች አሉት. ከሁሉም በላይ ይህ ከጥቅም ውጪ የሆነ ተጠቃሚ የሚሰራ ሙሉ የሊኑክስ ከርነል ነው። ይህ ባህሪ የማይታመን ኮድ በአስተናጋጁ ማሽን ላይ ምንም አይነት ስጋት ሳይፈጥር እንዲሰራ ያስችለዋል። እና ይህ ሙሉ-ፍሬድ ከርነል ስለሆነ, ሂደቶቹ ከአስተናጋጅ ማሽኑ ተለይተዋል, ማለትም በተጠቃሚ ሁኔታ ውስጥ የሚሰሩ ሂደቶች ለአስተናጋጁ አይታዩም።. ይህ እንደ ተለመደው የዶከር ኮንቴይነር አይደለም, በዚህ ጊዜ አስተናጋጁ ማሽን ሁልጊዜ በማጠራቀሚያው ውስጥ ያሉትን ሂደቶች ያያል. ከአንዱ አገልጋይዬ ይህን የ pstree ቁራጭ ይመልከቱ፡

containerd─┬─containerd-shim─┬─tini─┬─dnsd───19*[{dnsd}]
           │                 │      └─s6-svscan───s6-supervise
           │                 └─10*[{containerd-shim}]
           ├─containerd-shim─┬─tini─┬─aerial───21*[{aerial}]
           │                 │      └─s6-svscan───s6-supervise
           │                 └─10*[{containerd-shim}]
           ├─containerd-shim─┬─tini─┬─s6-svscan───s6-supervise
           │                 │      └─surl
           │                 └─9*[{containerd-shim}]
           ├─containerd-shim─┬─tini─┬─h───13*[{h}]
           │                 │      └─s6-svscan───s6-supervise
           │                 └─10*[{containerd-shim}]
           ├─containerd-shim─┬─goproxy───14*[{goproxy}]
           │                 └─9*[{containerd-shim}]
           └─32*[{containerd}]

እና ይህንን በተጠቃሚ ሁኔታ ውስጥ ካለው የሊኑክስ ከርነል pstree ጋር ያወዳድሩ።

linux─┬─5*[linux]
      └─slirp

ከዶከር ኮንቴይነሮች ጋር በሚሰሩበት ጊዜ በእንግዳው ውስጥ የሚሰሩ ሂደቶችን ስም ከአስተናጋጁ ማየት እችላለሁ። በሊኑክስ ተጠቃሚ ሁነታ ይህ አይቻልም። ምን ማለት ነው? ይህ ማለት በሊኑክስ ኦዲቲንግ ንዑስ ሲስተም ውስጥ የሚሰሩ የክትትል መሳሪያዎች ማለት ነው። አያዩም በእንግዳ ስርዓት ውስጥ የሚሰሩ ሂደቶች. ነገር ግን በአንዳንድ ሁኔታዎች, ይህ ባህሪ ሁለት አፍ ያለው ጎራዴ ሊሆን ይችላል.

በአጠቃላይ ከዚህ በታች ያለው ሙሉው ልኡክ ጽሁፍ የተፈለገውን ውጤት ለማግኘት የጥናት እና ግምታዊ ሙከራዎች ስብስብ ነው። ይህንን ለማድረግ የተለያዩ ጥንታዊ መሳሪያዎችን መጠቀም፣ የከርነል ምንጮችን ማንበብ፣ ገና አንደኛ ደረጃ ትምህርት ቤት በነበርኩበት ጊዜ የተፃፈ ኮድን በጥልቅ ማረም እና እንዲሁም የሚያስፈልገኝን መሳሪያ ለማግኘት ልዩ ሁለትዮሽ በመጠቀም ከ Heroku ግንባታዎች ጋር ቲንከር ማድረግ ነበረብኝ። . ይህ ሁሉ ሥራ በእኔ IRC ላይ ያሉ ሰዎች አስማት ብለው እንዲጠሩኝ አድርጓቸዋል። ይህ ልጥፍ አንድ ሰው በአዲሶቹ የከርነሎች እና የስርዓተ ክወና ስሪቶች ተመሳሳይ ነገር እንዲሞክር እንደ አስተማማኝ ሰነድ እንደሚያገለግል ተስፋ አደርጋለሁ።

በደንብ ማድረግ

የሊኑክስ ተጠቃሚ ሁነታን ማዋቀር በበርካታ ደረጃዎች ይከናወናል-

  • በአስተናጋጁ ላይ ጥገኛዎችን መትከል;
  • የሊኑክስ ኮርነልን ማውረድ;
  • የከርነል ግንባታ ውቅር;
  • የከርነል ስብስብ;
  • ሁለትዮሽ መጫኛ;
  • የእንግዳ ፋይል ስርዓቱን ማዋቀር;
  • የከርነል ማስነሻ መለኪያዎች ምርጫ;
  • የእንግዳ አውታር ማዘጋጀት;
  • የእንግዳውን ኮርነል መጀመር.

እራስህ ለማድረግ ከወሰንክ በአንዳንድ ኡቡንቱ ወይም ዴቢያን በሚመስል ስርዓት ውስጥ የተገለጹትን ነገሮች ሁሉ እንደምታደርግ እገምታለሁ። ከላይ የተጠቀሱትን ሁሉ በምወደው ስርጭት - አልፓይን ለመተግበር ሞከርኩ ፣ ግን ምንም አልመጣም ፣ ምክንያቱም የሊኑክስ ከርነል በተጠቃሚ ሁኔታ ውስጥ ለአሽከርካሪዎች ጠንካራ አስገዳጅ glibc-isms ስላለው ይመስላል። ችግሩን በመጨረሻ ከተረዳሁ በኋላ ይህንን ወደላይ ሪፖርት ለማድረግ እቅድ አለኝ።

በአስተናጋጁ ላይ ጥገኛዎችን መጫን

ኡቡንቱ የሊኑክስ ከርነልን ለመገንባት ቢያንስ የሚከተሉትን ፓኬጆች ይፈልጋል (ንፁህ ጭነት ከወሰድን)

- 'build-essential'
- 'flex'
- 'bison'
- 'xz-utils'
- 'wget'
- 'ca-certificates'
- 'bc'
- 'linux-headers'

በሚከተለው ትዕዛዝ (እንደ ስርወ ወይም በ sudo) ሊጭኗቸው ይችላሉ:

apt-get -y install build-essential flex bison xz-utils wget ca-certificates bc 
                   linux-headers-$(uname -r)

የሊኑክስ ከርነል ሜኑ ማዋቀር ፕሮግራምን ማስኬድ መጫን እንደሚያስፈልግ ልብ ይበሉ libncurses-dev. እባክዎ በሚከተለው ትዕዛዝ መጫኑን ያረጋግጡ (እንደ ስርወ ወይም ከሱዶ)፡

apt-get -y install libncurses-dev

የከርነል አውርድ

የት እንደሚወርድ ይወስኑ እና ከዚያ ከርነሉን ይገንቡ። ለዚህ ክወና ወደ 1,3 ጂቢ የሃርድ ዲስክ ቦታ መመደብ ያስፈልግዎታል, ስለዚህ እንዳለዎት ያረጋግጡ.

ወደ ይሂዱ በኋላ kernel.org እና የቅርብ ጊዜውን የተረጋጋ ከርነል ለማውረድ ዩአርኤሉን ያግኙ። ይህ በሚጽፍበት ጊዜ፡- https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.1.16.tar.xz

ይህንን ፋይል በመጠቀም ያውርዱ 'wget':

wget https://cdn.kernel.org/pub/linux/kernel/v5.x/linux-5.1.16.tar.xz

እና በ ጋር ያውጡት 'tar':

tar xJf linux-5.1.16.tar.xz

አሁን ታርቦውን ስንከፍት የተፈጠረውን ማውጫ አስገባን፦

cd linux-5.1.16

የከርነል ግንባታ ማዋቀር

የከርነል ግንባታ ስርዓት ስብስብ ነው Makefiles с ብዙ ሂደቱን በራስ-ሰር ለማድረግ ብጁ መሳሪያዎች እና ስክሪፕቶች። በመጀመሪያ በይነተገናኝ ማዋቀር ፕሮግራሙን ይክፈቱ፡-

make ARCH=um menuconfig

በከፊል ይገነባል እና የንግግር ሳጥን ያሳየዎታል። መቼ'[Select]', የ Space ወይም Enter ቁልፎችን በመጠቀም ማዋቀር ይችላሉ. መስኮቱን እንደተለመደው በቁልፍ ሰሌዳው ቀስቶች "ወደላይ" እና "ወደታች" ይሂዱ እና አባሎችን ይምረጡ - "ግራ" ወይም "ቀኝ".

የእይታ አመልካች —> ማለት በንዑስ ሜኑ ውስጥ ኖት ማለት ነው፣ በ Enter ቁልፉ የሚደረስ። መውጫው ግልጽ በሆነ መንገድ ነው '[Exit]'.

በ' ውስጥ የሚከተሉትን አማራጮች ያካትቱ[Select]' እና ከእነሱ ቀጥሎ '[*]' እንዳላቸው ያረጋግጡ፡-

UML-specific Options:
  - Host filesystem
Networking support (enable this to get the submenu to show up):
  - Networking options:
    - TCP/IP Networking
UML Network devices:
  - Virtual network device
  - SLiRP transport

ያ ብቻ ነው፣ በተከታታይ 'ን በመምረጥ ከዚህ መስኮት መውጣት ይችላሉ።[Exit]' . ውቅሩን በመጨረሻው ላይ እንዲያስቀምጡ መጠየቁን ያረጋግጡ እና ' ን ይምረጡ።[Yes]'.

ይህን ልጥፍ ካነበቡ በኋላ በከርነል ግንባታ አማራጮች እንዲጫወቱ እመክራለሁ። በእነዚህ ሙከራዎች የዝቅተኛ ደረጃ የከርነል መካኒኮችን ስራ እና የተለያዩ ባንዲራዎች በስብሰባ ላይ ያላቸውን ተፅእኖ ከመረዳት አንፃር ብዙ መማር ይችላሉ።

ከርነል መገንባት

የሊኑክስ ከርነል ብዙ ነገሮችን የሚሰራ ትልቅ ፕሮግራም ነው። በአሮጌ ሃርድዌር ላይ እንደዚህ ያለ አነስተኛ ውቅር ቢኖርም ፣ ለመገንባት ብዙ ጊዜ ሊወስድ ይችላል። ስለዚህ ከርነሉን በሚከተለው ትዕዛዝ ይገንቡ።

make ARCH=um -j$(nproc)

ለምንድነው? ይህ ትዕዛዝ ገንቢያችን በግንባታ ሂደት ውስጥ ያሉትን ሁሉንም የሲፒዩ ኮርሶች እና ክሮች እንዲጠቀም ይነግረዋል። ቡድን $(nproc) በግንባታው መጨረሻ ላይ የትዕዛዙን ውጤት ይተካል። nprocአካል የሆነው coreutils በመደበኛ የኡቡንቱ ግንባታ።

ከተወሰነ ጊዜ በኋላ የእኛ አስኳል ወደ ተፈጻሚነት ያለው ፋይል ይሰበሰባል ./linux.

ሁለትዮሽ መጫን

በሊኑክስ ውስጥ ያለው የተጠቃሚ ሁነታ መደበኛ ሁለትዮሽ ስለሚፈጥር እንደ ማንኛውም ሌላ መገልገያ መጫን ይችላሉ። እንዴት እንዳደረግኩት እነሆ፡-

mkdir -p ~/bin
cp linux ~/bin/linux

መሆኑን ማረጋገጥም ተገቢ ነው። ~/bin በእርስዎ ውስጥ ነው። $PATH:

export PATH=$PATH:$HOME/bin

የእንግዳ ፋይል ስርዓቱን በማቀናበር ላይ

ለእንግዳ ፋይል ስርዓት ማውጫ ይፍጠሩ፡

mkdir -p $HOME/prefix/uml-demo
cd $HOME/prefix

alpinelinux.org እና ውስጥ ይክፈቱ የማውረድ ክፍል ትክክለኛውን የማውረድ አገናኝ ያግኙ MINI ROOT FILESYSTEM. ይህ ዘገባ እስከተጠናቀረበት ጊዜ ድረስ፡-

http://dl-cdn.alpinelinux.org/alpine/v3.10/releases/x86_64/alpine-minirootfs-3.10.0-x86_64.tar.gz

wgetን በመጠቀም ይህን ታርቦል ያውርዱ፡-

wget -O alpine-rootfs.tgz http://dl-cdn.alpinelinux.org/alpine/v3.10/releases/x86_64/alpine-minirootfs-3.10.0-x86_64.tar.gz

አሁን የእንግዳ ፋይል ስርዓቱን ማውጫ ያስገቡ እና ማህደሩን ያውጡ፡

cd uml-demo
tar xf ../alpine-rootfs.tgz

የተገለጹት ድርጊቶች ትንሽ የፋይል ስርዓት አብነት ይፈጥራሉ. በስርአቱ ባህሪ ምክንያት በአልፕይን ኤፒኬ ማኔጀር በኩል ፓኬጆችን መጫን እጅግ በጣም ከባድ ይሆናል። ግን ይህ FS አጠቃላይ ሀሳቡን ለመገምገም በቂ ይሆናል.

መሳሪያም እንፈልጋለን ቲኒ የማህደረ ትውስታ ፍጆታን ለመግታት የዞምቢ ሂደቶች የእኛ እንግዳ አስኳል.

wget -O tini https://github.com/krallin/tini/releases/download/v0.18.0/tini-static
chmod +x tini

የከርነል ትዕዛዝ መስመር መፍጠር

የሊኑክስ ከርነል፣ ልክ እንደሌሎች ፕሮግራሞች፣ ቁልፉን በመግለጽ ሊደረስባቸው የሚችሉ የትዕዛዝ መስመር ክርክሮች አሉት። --help.

እራሱ - እርዳታ

linux --help
User Mode Linux v5.1.16
        available at http://user-mode-linux.sourceforge.net/

--showconfig
    Prints the config file that this UML binary was generated from.

iomem=<name>,<file>
    Configure <file> as an IO memory region named <name>.

mem=<Amount of desired ram>
    This controls how much "physical" memory the kernel allocates
    for the system. The size is specified as a number followed by
    one of 'k', 'K', 'm', 'M', which have the obvious meanings.
    This is not related to the amount of memory in the host.  It can
    be more, and the excess, if it's ever used, will just be swapped out.
        Example: mem=64M

--help
    Prints this message.

debug
    this flag is not needed to run gdb on UML in skas mode

root=<file containing the root fs>
    This is actually used by the generic kernel in exactly the same
    way as in any other kernel. If you configure a number of block
    devices and want to boot off something other than ubd0, you
    would use something like:
        root=/dev/ubd5

--version
    Prints the version number of the kernel.

umid=<name>
    This is used to assign a unique identity to this UML machine and
    is used for naming the pid file and management console socket.

con[0-9]*=<channel description>
    Attach a console or serial line to a host channel.  See
    http://user-mode-linux.sourceforge.net/old/input.html for a complete
    description of this switch.

eth[0-9]+=<transport>,<options>
    Configure a network device.
    
aio=2.4
    This is used to force UML to use 2.4-style AIO even when 2.6 AIO is
    available.  2.4 AIO is a single thread that handles one request at a
    time, synchronously.  2.6 AIO is a thread which uses the 2.6 AIO
    interface to handle an arbitrary number of pending requests.  2.6 AIO
    is not available in tt mode, on 2.4 hosts, or when UML is built with
    /usr/include/linux/aio_abi.h not available.  Many distributions don't
    include aio_abi.h, so you will need to copy it from a kernel tree to
    your /usr/include/linux in order to build an AIO-capable UML

nosysemu
    Turns off syscall emulation patch for ptrace (SYSEMU).
    SYSEMU is a performance-patch introduced by Laurent Vivier. It changes
    behaviour of ptrace() and helps reduce host context switch rates.
    To make it work, you need a kernel patch for your host, too.
    See http://perso.wanadoo.fr/laurent.vivier/UML/ for further
    information.

uml_dir=<directory>
    The location to place the pid and umid files.

quiet
    Turns off information messages during boot.

hostfs=<root dir>,<flags>,...
    This is used to set hostfs parameters.  The root directory argument
    is used to confine all hostfs mounts to within the specified directory
    tree on the host.  If this isn't specified, then a user inside UML can
    mount anything on the host that's accessible to the user that's running
    it.
    The only flag currently supported is 'append', which specifies that all
    files opened by hostfs will be opened in append mode.

ይህ ፓነል የማስነሻውን ዋና መለኪያዎች ያጎላል. ከርነሉን በትንሹ በሚፈለገው የአማራጭ ስብስብ እናስኬድ።

linux 
  root=/dev/root 
  rootfstype=hostfs 
  rootflags=$HOME/prefix/uml-demo 
  rw 
  mem=64M 
  init=/bin/sh

ከላይ ያሉት መስመሮች ለከርነላችን የሚከተለውን ይነግሩታል፡

  • የስር ፋይል ስርዓቱ አስመሳይ መሳሪያ ነው እንበል /dev/root.
  • ይምረጡ አስተናጋጆች እንደ ስርወ ፋይል ስርዓት ነጂ።
  • በስር መሳሪያው ላይ የፈጠርነውን የእንግዳ ፋይል ስርዓትን ይጫኑ።
  • እና አዎ፣ በንባብ-መፃፍ ሁነታ።
  • 64 ሜባ ራም ብቻ ይጠቀሙ (ለመጠቀም ባቀዱት ላይ በመመስረት በጣም ያነሰ መጠቀም ይችላሉ፣ነገር ግን 64 ሜባ በጣም ጥሩው መጠን ይመስላል)።
  • ኮርነሉ በራስ-ሰር ይጀምራል /bin/sh እንዴት init- ሂደት.

ይህንን ትዕዛዝ ያሂዱ እና የሚከተለውን የሆነ ነገር ማግኘት አለብዎት:

አንድ ተጨማሪ ሉህ

Core dump limits :
        soft - 0
        hard - NONE
Checking that ptrace can change system call numbers...OK
Checking syscall emulation patch for ptrace...OK
Checking advanced syscall emulation patch for ptrace...OK
Checking environment variables for a tempdir...none found
Checking if /dev/shm is on tmpfs...OK
Checking PROT_EXEC mmap in /dev/shm...OK
Adding 32137216 bytes to physical memory to account for exec-shield gap
Linux version 5.1.16 (cadey@kahless) (gcc version 7.4.0 (Ubuntu 7.4.0-1ubuntu1~18.04.1)) #30 Sun Jul 7 18:57:19 UTC 2019
Built 1 zonelists, mobility grouping on.  Total pages: 23898
Kernel command line: root=/dev/root rootflags=/home/cadey/dl/uml/alpine rootfstype=hostfs rw mem=64M init=/bin/sh
Dentry cache hash table entries: 16384 (order: 5, 131072 bytes)
Inode-cache hash table entries: 8192 (order: 4, 65536 bytes)
Memory: 59584K/96920K available (2692K kernel code, 708K rwdata, 588K rodata, 104K init, 244K bss, 37336K reserved, 0K cma-reserved)
SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
NR_IRQS: 15
clocksource: timer: mask: 0xffffffffffffffff max_cycles: 0x1cd42e205, max_idle_ns: 881590404426 ns
Calibrating delay loop... 7479.29 BogoMIPS (lpj=37396480)
pid_max: default: 32768 minimum: 301
Mount-cache hash table entries: 512 (order: 0, 4096 bytes)
Mountpoint-cache hash table entries: 512 (order: 0, 4096 bytes)
Checking that host ptys support output SIGIO...Yes
Checking that host ptys support SIGIO on close...No, enabling workaround
devtmpfs: initialized
random: get_random_bytes called from setup_net+0x48/0x1e0 with crng_init=0
Using 2.6 host AIO
clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 19112604462750000 ns
futex hash table entries: 256 (order: 0, 6144 bytes)
NET: Registered protocol family 16
clocksource: Switched to clocksource timer
NET: Registered protocol family 2
tcp_listen_portaddr_hash hash table entries: 256 (order: 0, 4096 bytes)
TCP established hash table entries: 1024 (order: 1, 8192 bytes)
TCP bind hash table entries: 1024 (order: 1, 8192 bytes)
TCP: Hash tables configured (established 1024 bind 1024)
UDP hash table entries: 256 (order: 1, 8192 bytes)
UDP-Lite hash table entries: 256 (order: 1, 8192 bytes)
NET: Registered protocol family 1
console [stderr0] disabled
mconsole (version 2) initialized on /home/cadey/.uml/tEwIjm/mconsole
Checking host MADV_REMOVE support...OK
workingset: timestamp_bits=62 max_order=14 bucket_order=0
Block layer SCSI generic (bsg) driver version 0.4 loaded (major 254)
io scheduler noop registered (default)
io scheduler bfq registered
loop: module loaded
NET: Registered protocol family 17
Initialized stdio console driver
Using a channel type which is configured out of UML
setup_one_line failed for device 1 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 2 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 3 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 4 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 5 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 6 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 7 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 8 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 9 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 10 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 11 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 12 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 13 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 14 : Configuration failed
Using a channel type which is configured out of UML
setup_one_line failed for device 15 : Configuration failed
Console initialized on /dev/tty0
console [tty0] enabled
console [mc-1] enabled
Failed to initialize ubd device 0 :Couldn't determine size of device's file
VFS: Mounted root (hostfs filesystem) on device 0:11.
devtmpfs: mounted
This architecture does not have kernel memory protection.
Run /bin/sh as init process
/bin/sh: can't access tty; job control turned off
random: fast init done
/ # 

ከላይ ያሉት መጠቀሚያዎች ይሰጡናል ቢያንስ የእንግዳ ስርዓት, ያለ ነገሮች /proc ወይም የተመደበ የአስተናጋጅ ስም። ለምሳሌ፣ የሚከተሉትን ትዕዛዞች ይሞክሩ።

- uname -av
- cat /proc/self/pid
- hostname

ከእንግዳው ለመውጣት ይተይቡ exit ወይም መቆጣጠሪያ-መን ይጫኑ. ይህ በከርነል ፍርሃት የተከተለውን ዛጎሉን ይገድለዋል፡-

/ # exit
Kernel panic - not syncing: Attempted to kill init! exitcode=0x00000000
fish: “./linux root=/dev/root rootflag…” terminated by signal SIGABRT (Abort)

የሊኑክስ ከርነል የማስጀመሪያው ሂደት ሁል ጊዜ የሚሰራ ነው ብሎ ስለሚያስብ ይህ የከርነል ፍርሃት ገጥሞናል። ያለሱ, ስርዓቱ ከአሁን በኋላ ሊሠራ እና ሊበላሽ አይችልም. ነገር ግን ይህ የተጠቃሚ-ሁነታ ሂደት ስለሆነ ውጤቱ ራሱ ይልካል SIGABRT, ይህም ውጤትን ያመጣል.

የእንግዳ አውታረ መረብ ማዋቀር

እና ነገሮች መበላሸት የሚጀምሩት እዚህ ላይ ነው። በተጠቃሚ ሁነታ ሊኑክስ ውስጥ ያለው አውታረ መረብ የተገደበ "የተጠቃሚ ሁነታ" ጽንሰ-ሀሳብ መፈራረስ የሚጀምርበት ነው። ከሁሉም በላይ, ብዙውን ጊዜ በስርዓት ደረጃ, አውታረ መረቡ ውስን ነው ልዩ መብት የአፈፃፀም ሁነታዎች ለሁላችንም ለመረዳት ለሚቻሉ ምክንያቶች.

ማስታወሻ. በ .: በ UML ውስጥ ከአውታረ መረብ ጋር ለመስራት ስለ ተለያዩ አማራጮች የበለጠ ማንበብ ይችላሉ። እዚህ.

ጉዞ ወደ ስላይድ

ሆኖም፣ አንድ ጥንታዊ እና የማይደገፍ መሳሪያ የሚባል አለ። ማንሸራተትሊኑክስ በየትኛው የተጠቃሚ ሁኔታ ከአውታረ መረቡ ጋር መገናኘት ይችላል። ልክ እንደ የተጠቃሚ ደረጃ TCP/IP ቁልል ይሰራል እና ለማሄድ ምንም አይነት የስርዓት ፈቃዶችን አይፈልግም። ይህ መሳሪያ ነበር በ1995 ተለቋል, እና የቅርብ ጊዜ ዝማኔው ቀኑ ነው የ 2006 ዓመት. Slirp በጣም አርጅቷል። ድጋፍ እና ማሻሻያ በሌለበት ጊዜ, አቀናባሪዎች እስካሁን ድረስ ሄደዋል, አሁን ይህ መሳሪያ ብቻ ሊገለጽ ይችላል ኮድ መበስበስ.

ስለዚህ Slirpን ከኡቡንቱ ማከማቻዎች እናውርድና እሱን ለማስኬድ እንሞክር፡-

sudo apt-get install slirp
/usr/bin/slirp
Slirp v1.0.17 (BETA)

Copyright (c) 1995,1996 Danny Gasparovski and others.
All rights reserved.
This program is copyrighted, free software.
Please read the file COPYRIGHT that came with the Slirp
package for the terms and conditions of the copyright.

IP address of Slirp host: 127.0.0.1
IP address of your DNS(s): 1.1.1.1, 10.77.0.7
Your address is 10.0.2.15
(or anything else you want)

Type five zeroes (0) to exit.

[autodetect SLIP/CSLIP, MTU 1500, MRU 1500, 115200 baud]

SLiRP Ready ...
fish: “/usr/bin/slirp” terminated by signal SIGSEGV (Address boundary error)

ወይ አማልክት። የስላይድ አራሚ እንጫን እና እዚህ ምን እየተፈጠረ እንዳለ ለማወቅ እንችል እንደሆነ እንይ።

sudo apt-get install gdb slirp-dbgsym
gdb /usr/bin/slirp
GNU gdb (Ubuntu 8.1-0ubuntu3) 8.1.0.20180409-git
Copyright (C) 2018 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "x86_64-linux-gnu".
Type "show configuration" for configuration details.
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
Find the GDB manual and other documentation resources online at:
<http://www.gnu.org/software/gdb/documentation/>.
For help, type "help".
Type "apropos word" to search for commands related to "word"...
Reading symbols from /usr/bin/slirp...Reading symbols from /usr/lib/debug/.build-id/c6/2e75b69581a1ad85f72ac32c0d7af913d4861f.debug...done.
done.
(gdb) run
Starting program: /usr/bin/slirp
Slirp v1.0.17 (BETA)

Copyright (c) 1995,1996 Danny Gasparovski and others.
All rights reserved.
This program is copyrighted, free software.
Please read the file COPYRIGHT that came with the Slirp
package for the terms and conditions of the copyright.

IP address of Slirp host: 127.0.0.1
IP address of your DNS(s): 1.1.1.1, 10.77.0.7
Your address is 10.0.2.15
(or anything else you want)

Type five zeroes (0) to exit.

[autodetect SLIP/CSLIP, MTU 1500, MRU 1500, 115200 baud]

SLiRP Ready ...

Program received signal SIGSEGV, Segmentation fault.
                                                    ip_slowtimo () at ip_input.c:457
457     ip_input.c: No such file or directory.

ስህተቱ በውስጣችን ይመታል። ይህ መስመር. ቁልልውን እንይ፣ ምናልባት አንድ ነገር እዚያ ይረዳናል፡

(gdb) bt full
#0  ip_slowtimo () at ip_input.c:457
        fp = 0x55784a40
#1  0x000055555556a57c in main_loop () at ./main.c:980
        so = <optimized out>
        so_next = <optimized out>
        timeout = {tv_sec = 0, tv_usec = 0}
        ret = 0
        nfds = 0
        ttyp = <optimized out>
        ttyp2 = <optimized out>
        best_time = <optimized out>
        tmp_time = <optimized out>
#2  0x000055555555b116 in main (argc=1, argv=0x7fffffffdc58) at ./main.c:95
No locals.

እዚህ ላይ ብልሽቱ የሚከሰተው በዋናው ሉፕ ጅምር ወቅት መንሸራተት የጊዜ ማብቂያዎችን ለመፈተሽ ሲሞክር መሆኑን እናያለን። በዚህ ጊዜ, ለማረም መሞከርን መተው ነበረብኝ. ነገር ግን Slirp የተሰራው ከዓይነት ስራዎች እንደሆነ እንይ። ማህደሩን በቀጥታ ከጣቢያው ላይ እንደገና አውርጄዋለሁ Sourceforgeበትእዛዝ መስመሩ በኩል የሆነ ነገር ከዚያ መጎተት ህመም ነውና።

cd ~/dl
wget https://xena.greedo.xeserv.us/files/slirp-1.0.16.tar.gz
tar xf slirp-1.0.16.tar.gz
cd slirp-1.0.16/src
./configure --prefix=$HOME/prefix/slirp
make

እዚህ ጋር ስለ ያልተገለጹ አብሮገነብ ተግባራት ማለትም ስለ ውጤቱ ሁለትዮሽ ፋይል ማገናኘት አለመቻል ማንቂያዎችን እናያለን። እ.ኤ.አ. በ 2006 እና በዚህ ነጥብ መካከል gcc በመካከለኛ የተጠናቀሩ ፋይሎች ውስጥ አብሮ በተሰራ ተግባር ውስጥ ጥቅም ላይ የሚውሉ ምልክቶችን ማምረት ያቆመ ይመስላል። ቁልፍ ቃሉን ለመተካት እንሞክር inline በባዶ አስተያየት እና ውጤቱን ይመልከቱ-

vi slirp.h
:6
a
<enter>
#define inline /**/
<escape>
:wq
make

አይደለም. ይሄም አይሰራም። ለእነዚህ ተግባራት አሁንም ምልክቶችን ማግኘት አልተቻለም።

በዚህ ጊዜ ተስፋ ቆርጬ Githubን ማየት ጀመርኩ። የሄሮኩ ግንባታ ፓኬጆች. የኔ ፅንሰ-ሀሳብ አንዳንድ የ Heroku የግንባታ ፓኬጅ የሚያስፈልገኝን ሁለትዮሽ ይይዛል የሚል ነበር። በመጨረሻ ፍለጋው መራኝ። እዚ’ጋ. አውርጄ አወጣሁ uml.tar.gz እና የሚከተለውን አገኘ:

total 6136
-rwxr-xr-x 1 cadey cadey   79744 Dec 10  2017 ifconfig*
-rwxr-xr-x 1 cadey cadey     373 Dec 13  2017 init*
-rwxr-xr-x 1 cadey cadey  149688 Dec 10  2017 insmod*
-rwxr-xr-x 1 cadey cadey   66600 Dec 10  2017 route*
-rwxr-xr-x 1 cadey cadey  181056 Jun 26  2015 slirp*
-rwxr-xr-x 1 cadey cadey 5786592 Dec 15  2017 uml*
-rwxr-xr-x 1 cadey cadey     211 Dec 13  2017 uml_run*

ይህ ተንሸራታች ሁለትዮሽ ነው! እሱ ይሰራል?

./slirp
Slirp v1.0.17 (BETA) FULL_BOLT

Copyright (c) 1995,1996 Danny Gasparovski and others.
All rights reserved.
This program is copyrighted, free software.
Please read the file COPYRIGHT that came with the Slirp
package for the terms and conditions of the copyright.

IP address of Slirp host: 127.0.0.1
IP address of your DNS(s): 1.1.1.1, 10.77.0.7
Your address is 10.0.2.15
(or anything else you want)

Type five zeroes (0) to exit.

[autodetect SLIP/CSLIP, MTU 1500, MRU 1500]

SLiRP Ready ...

አይበላሽም - ስለዚህ መስራት አለበት! ይህንን ሁለትዮሽ ወደ ውስጥ እንትከል ~/bin/slirp:

cp slirp ~/bin/slirp

የጥቅል ፈጣሪው ካስወገደው፣ I መስታወት ሠራ.

የአውታረ መረብ ውቅር

አሁን ኔትወርክን በእንግዳችን ከርነል ላይ እናዋቅር። የማስጀመሪያ አማራጮችን ያዘምኑ:

linux 
  root=/dev/root 
  rootfstype=hostfs 
  rootflags=$HOME/prefix/uml-demo 
  rw 
  mem=64M 
  eth0=slirp,,$HOME/bin/slirp 
  init=/bin/sh

አሁን አውታረ መረቡን እናብራ፡-

mount -t proc proc proc/
mount -t sysfs sys sys/

ifconfig eth0 10.0.2.14 netmask 255.255.255.240 broadcast 10.0.2.15
route add default gw 10.0.2.2

የመጀመሪያዎቹ ሁለት ውቅር ትዕዛዞች /proc и /sys ለሥራ አስፈላጊ ifconfigከ Slirp ጋር ለመገናኘት የአውታረ መረብ በይነገጽን የሚያዘጋጅ። ቡድን route ሁሉም ትራፊክ በስላይድ ዋሻ ውስጥ እንዲላክ ለማስገደድ የከርነል ማዞሪያ ጠረጴዛውን ያዘጋጃል። ይህንን በዲ ኤን ኤስ ጥያቄ እንፈትሽ፡

nslookup google.com 8.8.8.8
Server:    8.8.8.8
Address 1: 8.8.8.8 dns.google

Name:      google.com
Address 1: 172.217.12.206 lga25s63-in-f14.1e100.net
Address 2: 2607:f8b0:4006:81b::200e lga25s63-in-x0e.1e100.net

!Аботает!

ማስታወሻ በ.፡ በግልጽ እንደሚታየው፣ ዋናው ልጥፍ በዴስክቶፕ ላይ የተጻፈው ባለገመድ የኔትወርክ ካርድ ወይም ሌላ ተጨማሪ አሽከርካሪዎችን የማይፈልግ ውቅር ነው። ከኢንቴል ዋይፋይ 8265 ባለው ላፕቶፕ ላይ ኔትወርኩን ሲጨምር ስህተት ይከሰታል

/ # ifconfig eth0 10.0.2.14 netmask 255.255.255.240 broadcast 10.0.2.15
slirp_tramp failed - errno = 2
ifconfig: ioctl 0x8914 failed: No such file or directory
/ #

በግልጽ ለማየት እንደሚቻለው, ኮርነሉ ከአውታረ መረብ ካርድ ነጂ ጋር መገናኘት አይችልም. Firmware ን ወደ ከርነል ለማጠናቀር የተደረገ ሙከራ፣ በሚያሳዝን ሁኔታ፣ ሁኔታውን አላስተካከለም። በሚታተምበት ጊዜ በዚህ ውቅር ውስጥ መፍትሄ ማግኘት አልተቻለም። በቀላል አወቃቀሮች (ለምሳሌ በቨርቹዋልቦክስ ውስጥ) በይነገጹ በትክክል ይነሳል።

አቅጣጫውን በሚከተለው የሼል ስክሪፕት እናስቀምጠው፡

#!/bin/sh
# init.sh

mount -t proc proc proc/
mount -t sysfs sys sys/
ifconfig eth0 10.0.2.14 netmask 255.255.255.240 broadcast 10.0.2.15
route add default gw 10.0.2.2

echo "networking set up"

exec /tini /bin/sh

እና ሊተገበር እንደሚችል ምልክት ያድርጉበት፡-

chmod +x init.sh

እና ከዚያ በከርነል ትዕዛዝ መስመር ላይ ለውጦችን እናደርጋለን-

linux 
  root=/dev/root 
  rootfstype=hostfs 
  rootflags=$HOME/prefix/uml-demo 
  rw 
  mem=64M 
  eth0=slirp,,$HOME/bin/slirp 
  init=/init.sh

እና እንድገመው፡-

SLiRP Ready ...
networking set up
/bin/sh: can't access tty; job control turned off

nslookup google.com 8.8.8.8
Server:    8.8.8.8
Address 1: 8.8.8.8 dns.google

Name:      google.com
Address 1: 172.217.12.206 lga25s63-in-f14.1e100.net
Address 2: 2607:f8b0:4004:800::200e iad30s09-in-x0e.1e100.net

አውታረ መረቡ የተረጋጋ ነው!

ዶከር ፋይል

ይህን ሁሉ ለመፈተሽ ቀላል ለማድረግ, ሰብስቤያለሁ Dockerfileየተገለጹትን አብዛኛዎቹን እርምጃዎች በራስ ሰር የሚያሰራ እና የሚሰራ ውቅር ሊሰጥዎ ይገባል። እኔም አለኝ አስቀድሞ የተዋቀረ ከርነል, በፖስታው ውስጥ የተገለጹትን ሁሉ የያዘው. ግን እዚህ ዝቅተኛውን መቼት ብቻ እንደገለጽኩ መረዳት አስፈላጊ ነው.

ይህ ልጥፍ የእንግዳ አስኳል እንዴት እንደሚያሳድጉ እንዲረዱ እንደረዳዎት ተስፋ አደርጋለሁ። የሆነ አይነት ጭራቅ ሆኖ ተገኘ፣ነገር ግን ህትመቱ የተፀነሰው በዚህ ቤተሰብ ዘመናዊ ስርዓተ ክወና ስሪቶች በሊኑክስ ውስጥ የተጠቃሚ ሁነታን ስለመገንባት፣ መጫን እና ማዋቀር ላይ እንደ አጠቃላይ መመሪያ ነው። የሚቀጥሉት እርምጃዎች አገልግሎቶችን እና ሌሎች ሶፍትዌሮችን በእንግዶች ስርዓት ውስጥ መጫንን ማካተት አለባቸው። የዶከር ኮንቴይነሮች ምስሎች በይፋ የሚታወቁ ታርቦሎች ስለሆኑ ምስሉን በ በኩል ማውጣት መቻል አለቦት docker export, እና ከዚያ በእንግዳው የከርነል ፋይል ስርዓት ስር የመጫኛ መንገዱን ይወስኑ። ደህና, ከዚያ የሼል ስክሪፕቱን ያስፈጽሙ.

ልዩ ምስጋና ለ Rkeene ከ # ሎብስተርስ በፍሪኖድ። የሱ እርዳታ Slirpን ሳያስተካክል፣ እስከዚህ ድረስ አልደርስም ነበር። የእሱ Slackware ስርዓት በተንሸራታች እንዴት በትክክል እንደሚሰራ አላውቅም፣ ነገር ግን የኔ ኡቡንቱ እና አልፓይን ስርዓቴ መንሸራተትን አልተቀበለም እና የሁለትዮሽ Rkeene ሀሳብ አቀረበልኝ። ግን ይበቃኛል ቢያንስ የሆነ ነገር ይጠቅመኛል።

ምንጭ: hab.com

አስተያየት ያክሉ