ලිනක්ස් හි පරිශීලක මාදිලිය භාවිතා කිරීම ආරම්භ කරන්නේ කෙසේද

පරිවර්තකයාගේ හැඳින්වීම: විවිධ වර්ගයේ බහාලුම් අපගේ ජීවිතවලට දැවැන්ත ලෙස ඇතුල් වීමේ පසුබිමට එරෙහිව, එය වරක් ආරම්භ වූ තාක්ෂණයන් මොනවාදැයි සොයා බැලීම තරමක් රසවත් හා ප්රයෝජනවත් විය හැකිය. ඒවායින් සමහරක් අද දක්වාම ප්‍රයෝජනවත් ලෙස භාවිතා කළ හැකි නමුත්, සෑම කෙනෙකුම එවැනි ක්‍රම මතක තබා නොගනී (නැතහොත් ඔවුන්ගේ වේගවත් සංවර්ධනයේදී ඔවුන් හසු නොවූයේ දැයි දනී). එවැනි එක් තාක්ෂණයක් වන්නේ පරිශීලක මාදිලියේ ලිනක්ස් ය. මුල් පිටපතේ කතුවරයා බොහෝ කැණීම් කර, පැරණි වර්ධනයන් තවමත් ක්‍රියාත්මක වන්නේ කුමක්ද සහ නොකරන්නේ කුමක්දැයි සොයා බලා, 2k19 හි Homebrew UML එකක් ලබා ගන්නේ කෙසේද යන්න පිළිබඳ පියවරෙන් පියවර උපදෙස් වැනි දෙයක් එකතු කළේය. ඔව්, අපි මුල් ලිපියේ කතුවරයාට Habr වෙත ආරාධනා කළෙමු කේඩි, එබැවින් ඔබට කිසියම් ප්‍රශ්නයක් ඇත්නම් - අදහස් දැක්වීමේදී ඉංග්‍රීසියෙන් අසන්න.

ලිනක්ස් හි පරිශීලක මාදිලිය භාවිතා කිරීම ආරම්භ කරන්නේ කෙසේද

ලිනක්ස් හි පරිශීලක මාදිලිය, ඇත්ත වශයෙන්ම, ලිනක්ස් කර්නලයේ වරායකි. මෙම මාදිලිය මඟින් ඔබට සම්පූර්ණ ලිනක්ස් කර්නලයක් පරිශීලක ක්‍රියාවලියක් ලෙස ක්‍රියාත්මක කිරීමට ඉඩ ලබා දෙන අතර ධාවක පරීක්ෂා කිරීමට සංවර්ධකයින් විසින් බහුලව භාවිතා කරනු ලැබේ. නමුත් මෙම මාදිලිය සාමාන්‍ය හුදකලා මෙවලමක් ලෙසද ප්‍රයෝජනවත් වේ, එහි මූලධර්මය අථත්‍ය යන්ත්‍රවල ක්‍රියාකාරිත්වයට සමාන වේ. මෙම මාදිලිය ඩොකර්ට වඩා වැඩි හුදකලාවක් සපයයි, නමුත් 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

ඩොකර් කන්ටේනර් සමඟ වැඩ කරන විට, ආගන්තුකයේ ක්‍රියාත්මක වන ක්‍රියාවලීන්ගේ නම් ධාරකයෙන් මට දැක ගත හැකිය. Linux පරිශීලක මාදිලිය සමඟ, මෙය කළ නොහැක. එයින් අදහස් කරන්නේ කුමක් ද? මෙයින් අදහස් කරන්නේ Linux හි විගණන උප පද්ධතිය හරහා ක්‍රියාත්මක වන අධීක්ෂණ මෙවලම් බවයි නොපෙනේ ආගන්තුක පද්ධතිය තුළ ක්‍රියාත්මක වන ක්‍රියාවලි. නමුත් සමහර අවස්ථාවන්හිදී, මෙම අංගය දෙබිඩි කඩුවක් බවට පත්විය හැකිය.

පොදුවේ ගත් කල, පහත දැක්වෙන සම්පූර්ණ පෝස්ටුව අපේක්ෂිත ප්රතිඵලය සාක්ෂාත් කර ගැනීම සඳහා පර්යේෂණ සහ දළ උත්සාහයන් එකතුවකි. මෙය සිදු කිරීම සඳහා, මට විවිධ පැරණි මෙවලම් භාවිතා කිරීමට, කර්නල් මූලාශ්‍ර කියවීමට, මා තවමත් ප්‍රාථමික පාසලේ සිටින දිනවල ලියා ඇති කේත තීව්‍ර ලෙස නිදොස්කරණය කිරීමට සහ මට අවශ්‍ය මෙවලම් සොයා ගැනීමට විශේෂ ද්විමයයක් භාවිතා කර Heroku ගොඩනැගීමට ටින්කර් කිරීමට සිදු විය. . මේ හැම වැඩක්ම මගේ IRC එකේ කොල්ලන්ට මාව මැජික් කියලා කතා කළා. නව කර්නල් සහ OS අනුවාද සමඟ එකම දේ උත්සාහ කිරීමට යමෙකුට විශ්වාසදායක ලියකියවිලි ලෙස මෙම සටහන ක්‍රියා කරයි යැයි මම බලාපොරොත්තු වෙමි.

ගැලපුම්

Linux පරිශීලක මාදිලිය සැකසීම පියවර කිහිපයකින් සිදු කෙරේ:

  • ධාරකය මත යැපීම් ස්ථාපනය කිරීම;
  • ලිනක්ස් කර්නලය බාගත කිරීම;
  • කර්නලය ගොඩනැගීමේ වින්‍යාසය;
  • කර්නල් එකලස් කිරීම;
  • ද්විමය ස්ථාපනය;
  • ආගන්තුක ගොනු පද්ධතිය වින්‍යාස කිරීම;
  • කර්නල් දියත් කිරීමේ පරාමිතීන් තෝරාගැනීම;
  • ආගන්තුක ජාලයක් පිහිටුවීම;
  • ආගන්තුක කර්නලය ආරම්භ කිරීම.

ඔබ එය ඔබම කිරීමට තීරණය කරන්නේ නම්, ඔබ බොහෝ විට Ubuntu හෝ Debian වැනි පද්ධතියක විස්තර කර ඇති සෑම දෙයක්ම කරනු ඇතැයි මම උපකල්පනය කරමි. මම ඉහත සියල්ල මගේ ප්‍රියතම බෙදාහැරීමේදී ක්‍රියාත්මක කිරීමට උත්සාහ කළෙමි - ඇල්පයින්, නමුත් එයින් කිසිවක් සිදු නොවීය, පෙනෙන විදිහට Linux කර්නලයේ පරිශීලක මාදිලියේ ධාවක සඳහා දෘඩ බන්ධන glibc-isms ඇති බැවිනි. මම ගැටලුව අවසානයේ තේරුම් ගත් පසු මෙය උඩුගං බලා වාර්තා කිරීමට අදහස් කරමි.

ධාරකය මත යැපීම් ස්ථාපනය කිරීම

Ubuntu හට ලිනක්ස් කර්නලය තැනීමට අවම වශයෙන් පහත පැකේජ අවශ්‍ය වේ (පිරිසිදු ස්ථාපනයක් උපකල්පනය කරයි):

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

ඔබට ඒවා පහත විධානය සමඟින් ස්ථාපනය කළ හැකිය (root හෝ sudo සමඟ):

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

ලිනක්ස් කර්නල් මෙනු සැකසුම් වැඩසටහන ක්‍රියාත්මක කිරීම සඳහා ස්ථාපනය කිරීම අවශ්‍ය වන බව සලකන්න libncurses-dev. කරුණාකර එය පහත විධානය සමඟ ස්ථාපනය කර ඇති බවට වග බලා ගන්න (root හෝ sudo සමඟ):

apt-get -y install libncurses-dev

කර්නලය බාගත කිරීම

බාගත කළ යුතු ස්ථානය තීරණය කර කර්නලය සාදන්න. මෙම මෙහෙයුම සඳහා, ඔබට දෘඪ තැටියේ 1,3 GB පමණ ඉඩක් වෙන් කිරීමට අවශ්ය වනු ඇත, එබැවින් ඔබ එය ඇති බවට වග බලා ගන්න.

වෙත ගිය පසු kernel.org සහ නවතම ස්ථාවර කර්නලය බාගැනීමට URL එක ලබා ගන්න. ලියන අවස්ථාවේදී මෙය මෙසේය. 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

කර්නල් ගොඩනැගීමේ සැකසුම

කර්නල් ගොඩනැගීමේ පද්ධතිය කට්ටලයකි සාදන ගොනු с බොහෝ ක්‍රියාවලිය ස්වයංක්‍රීය කිරීමට අභිරුචි මෙවලම් සහ ස්ක්‍රිප්ට්. පළමුව, අන්තර් ක්රියාකාරී සැකසුම් වැඩසටහන විවෘත කරන්න:

make ARCH=um menuconfig

එය ඔබ වෙනුවෙන් සංවාද කොටුවක් අර්ධ වශයෙන් ගොඩනඟා පෙන්වනු ඇත. කවදා ද '[Select]', ඔබට Space හෝ Enter යතුරු භාවිතයෙන් වින්‍යාස කිරීමට හැකි වනු ඇත. "ඉහළ" සහ "පහළ" යතුරුපුවරු ඊතල සමඟ සුපුරුදු පරිදි කවුළුව සංචාලනය කරන්න, සහ මූලද්රව්ය තෝරන්න - "වම" හෝ "දකුණ".

View pointer —> යන්නෙන් අදහස් කරන්නේ ඔබ 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]'.

මෙම සටහන කියවීමෙන් පසු ඔබ කර්නල් ගොඩනැගීමේ විකල්ප සමඟ සෙල්ලම් කරන ලෙස මම නිර්දේශ කරමි. මෙම අත්හදා බැලීම් හරහා, පහළ මට්ටමේ කර්නල් යාන්ත්‍ර විද්‍යාවේ ක්‍රියාකාරිත්වය සහ එහි එකලස් කිරීමේදී විවිධ ධජවල බලපෑම පිළිබඳ අවබෝධය සම්බන්ධයෙන් ඔබට බොහෝ දේ ඉගෙන ගත හැකිය.

කර්නලය ගොඩනැගීම

Linux kernel එක කියන්නේ ගොඩක් දේවල් කරන ලොකු program එකක්. පැරණි දෘඪාංගවල එවැනි අවම වින්යාසයකින් වුවද, එය ගොඩනඟා ගැනීමට සෑහෙන කාලයක් ගත විය හැකිය. එබැවින් පහත විධානය සමඟ කර්නලය සාදන්න:

make ARCH=um -j$(nproc)

කුමක් සඳහා ද? මෙම විධානය අපගේ ඉදිකිරීම්කරුට ලබා ගත හැකි සියලුම CPU කෝර් සහ නූල් ගොඩනැගීමේ ක්‍රියාවලියේදී භාවිතා කරන ලෙස කියනු ඇත. කණ්ඩායම $(nproc) Build අවසානයේ විධානයේ ප්‍රතිදානය ආදේශ කරයි 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 සහ in විවෘත කරන්න බාගත කොටස සැබෑ බාගත කිරීමේ සබැඳිය සොයා ගන්න 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

විස්තර කරන ලද ක්රියාවන් කුඩා ගොනු පද්ධති ආකෘතියක් සාදනු ඇත. පද්ධතියේ ස්වභාවය අනුව, Alpine apk කළමනාකරු හරහා පැකේජ ස්ථාපනය කිරීම අතිශයින් දුෂ්කර වනු ඇත. නමුත් මෙම FS සාමාන්ය අදහස ඇගයීමට ප්රමාණවත් වනු ඇත.

අපට මෙවලමක් ද අවශ්ය වේ ටිනි මතක පරිභෝජනය සීමා කිරීමට zombie ක්රියාවලි අපගේ ආගන්තුක කර්නලය.

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.
  • තෝරා hostfs මූල ගොනු පද්ධති ධාවකයක් ලෙස.
  • මූල උපාංගය මත අප විසින් සාදන ලද ආගන්තුක ගොනු පද්ධතිය සවි කරන්න.
  • ඔව්, කියවීමේ-ලිවීමේ මාදිලියේ.
  • RAM ප්‍රමාණය 64 MB පමණක් භාවිතා කරන්න (ඔබ කිරීමට අදහස් කරන දේ අනුව ඔබට ඉතා අඩුවෙන් භාවිතා කළ හැක, නමුත් 64 MB ප්‍රශස්ත ප්‍රමාණය ලෙස පෙනේ).
  • කර්නලය ස්වයංක්රීයව ආරම්භ වේ /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 හෝ control-d ඔබන්න. මෙය කර්නල් භීතියකින් පසුව කවචය විනාශ කරයි:

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

අපට මෙම කර්නල් භීතිකාව ඇති වූයේ Linux කර්නලය ආරම්භක ක්‍රියාවලිය සැමවිටම ක්‍රියාත්මක වන බව සිතන බැවිනි. එය නොමැතිව, පද්ධතිය තවදුරටත් ක්රියා කළ නොහැකි අතර බිඳ වැටේ. නමුත් මෙය පරිශීලක-ප්‍රකාර ක්‍රියාවලියක් බැවින්, ලැබෙන ප්‍රතිදානය තමන් වෙත යවයි SIGABRT, ප්‍රතිදානයක් ඇති කරයි.

ආගන්තුක ජාල සැකසුම

ඒ වගේම මේකෙන් තමයි දේවල් වැරදි වෙන්න පටන් ගන්නේ. පරිශීලක මාදිලියේ ලිනක්ස් හි ජාලකරණය යනු සීමිත "පරිශීලක මාදිලිය" පිළිබඳ සමස්ත සංකල්පය බිඳ වැටීමට පටන් ගන්නා ස්ථානයයි. සියල්ලට පසු, සාමාන්යයෙන් පද්ධති මට්ටමින්, ජාලය සීමා වේ වරප්රසාද ලත් ක්‍රියාත්මක කිරීමේ ක්‍රම අප සැමට තේරුම් ගත හැකි හේතු සඳහා.

සටහන. per .: ඔබට UML හි ජාලයක් සමඟ වැඩ කිරීම සඳහා විවිධ විකල්ප ගැන වැඩිදුර කියවිය හැකිය මෙහි.

Slirp වෙත ගමන

කෙසේ වෙතත්, පැරණි සහ පාහේ සහාය නොදක්වන මෙවලමක් ලෙස හැඳින්වේ Slirp, Linux පරිශීලක මාදිලිය සමඟ ජාලය සමඟ අන්තර් ක්රියා කළ හැකිය. එය පරිශීලක මට්ටමේ 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)

අනේ දෙවියනේ. අපි Slirp හි නිදොස්කරණය ස්ථාපනය කර අපට මෙහි සිදුවන්නේ කුමක්දැයි සොයා ගත හැකිදැයි බලමු:

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 කාල සීමාවන් පරීක්ෂා කිරීමට උත්සාහ කරන විට බවයි. මෙම අවස්ථාවේදී, මට දෝෂහරණය කිරීමේ උත්සාහය අත්හැරීමට සිදු විය. හැබැයි බලමු Slirp build from sorts වැඩද කියලා. මම වෙබ් අඩවියෙන් කෙලින්ම සංරක්ෂිතය නැවත බාගත කළෙමි මූලාශ්‍රය, විධාන රේඛාව හරහා යමක් ඇදගෙන යාම වේදනාවක් වන බැවිනි:

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 ගොඩනඟන පැකේජ. මගේ න්‍යාය වූයේ සමහර 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

පැකේජ නිර්මාපකයා එය ඉවත් කළහොත්, අයි කැඩපතක් හැදුවා.

ජාල සැකසුම

දැන් අපි අපගේ ආගන්තුක කර්නලය මත ජාලය සකසමු. දියත් කිරීමේ විකල්ප යාවත්කාලීන කරන්න:

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 Slirp උමග හරහා සියලුම ගමනාගමනය යැවීමට බල කිරීම සඳහා කර්නල් මාර්ගගත කිරීමේ වගුව සකසයි. DNS විමසුමකින් මෙය පරීක්ෂා කරමු:

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

!

සටහන අනුව.: පෙනෙන විදිහට, මුල් පළ කිරීම රැහැන්ගත ජාල කාඩ්පතක් සහිත ඩෙස්ක්ටොප් එකක ලියා ඇත, හෝ අමතර ධාවක අවශ්‍ය නොවන වෙනත් වින්‍යාසයක්. Intel වෙතින් WiFi 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
/ #

පෙනෙන විදිහට, කර්නලයට ජාල කාඩ්පත් ධාවකය සමඟ සන්නිවේදනය කළ නොහැක. ෆර්ම්වෙයාර් කර්නලයට සම්පාදනය කිරීමට ගත් උත්සාහයක්, අවාසනාවකට මෙන්, තත්වය නිවැරදි කළේ නැත. ප්‍රකාශනය කරන අවස්ථාවේදී, මෙම වින්‍යාසය තුළ විසඳුමක් සොයා ගැනීමට නොහැකි විය. සරල සැකසුම් මත (උදාහරණයක් ලෙස, Virtualbox තුළ), අතුරු මුහුණත නිවැරදිව ඉහල යයි.

පහත shell script එක සමඟින් යළි-යොමුවීම් ස්වයංක්‍රීය කරමු:

#!/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

ජාලය ස්ථාවරයි!

docker ගොනුව

ඔබට මේ සියල්ල පරීක්ෂා කිරීම පහසු කිරීම සඳහා, මම එකතු කර ඇත ඩොකර්ෆයිල්, විස්තර කර ඇති බොහෝ පියවර ස්වයංක්‍රීය කරන අතර ඔබට වැඩ කරන වින්‍යාසයක් ලබා දිය යුතුය. මටත් තියෙනවා පෙර සැකසූ කර්නලය, පෝස්ට් එකේ විස්තර කර ඇති සියල්ල ඇත. නමුත් මෙහිදී මා ගෙනහැර දක්වා ඇත්තේ අවම සැකසුම පමණක් බව වටහා ගැනීම වැදගත්ය.

ආගන්තුක කර්නලයක් ඉහළ නංවන ආකාරය තේරුම් ගැනීමට මෙම සටහන ඔබට උපකාර කර ඇතැයි මම බලාපොරොත්තු වෙමි. එය යම් ආකාරයක යක්ෂයෙකු බවට පත් වූ නමුත්, මෙම ප්‍රකාශනය මෙම පවුලේ මෙහෙයුම් පද්ධතිවල නවීන අනුවාද යටතේ ලිනක්ස් හි පරිශීලක මාදිලිය ගොඩනැගීම, ස්ථාපනය කිරීම සහ වින්‍යාස කිරීම පිළිබඳ පුළුල් මාර්ගෝපදේශයක් ලෙස සංකල්පනය කරන ලදී. මීළඟ පියවරට දැනටමත් ආගන්තුක පද්ධතිය තුළ සේවා සහ අනෙකුත් මෘදුකාංග ස්ථාපනය කිරීම ඇතුළත් විය යුතුය. ඩොකර් බහාලුම් පින්තූර හුදෙක් ප්‍රසිද්ධ තාරබෝල වන බැවින්, ඔබට රූපය හරහා උපුටා ගැනීමට හැකි විය යුතුය docker export, ඉන්පසු ආගන්තුක කර්නලයේ ගොනු පද්ධතියේ මූලයේ එහි ස්ථාපන මාර්ගය තීරණය කරන්න. හොඳයි, එහෙනම් shell script එක execute කරන්න.

Freenode හි #lobsters වෙතින් Rkeene වෙත විශේෂ ස්තුතිය. Slirp දෝශ නිරාකරණය කිරීමට ඔහුගේ උදව් නොමැතිව, මම මෙතරම් දුරක් පැමිණෙන්නේ නැත. ඔහුගේ Slackware පද්ධතිය slirp සමඟ නිවැරදිව ක්‍රියා කරන්නේ කෙසේදැයි මට අදහසක් නැත, නමුත් මගේ Ubuntu සහ Alpine පද්ධති slirp පිළි නොගත් අතර binary Rkeene මට යෝජනා කළේය. ඒත් මට අඩුම තරමේ මොකක් හරි වැඩ කරන එක මට ඇති.

මූලාශ්රය: www.habr.com

අදහස් එක් කරන්න