Failed: bson encoding error: BSON element key cannot contain null bytes
mongo, mongodb, bson, null, key
2024-08-24
Nem bízol a kollégáidban? Akkor valamit rosszul csinálsz!
bizalom vezetokent
2023-05-03
Dolgok, amikről a programozók azt hiszik, hogy tudják, de tévednek
programozoi-tevhitek-falsehoods
2023-04-08
A programozóktól meg kell szabadulni
chatgpt no-code low-code
2023-01-22
Miért fontosak a személyes adatok egyáltalán?
privacyaware, privacy
2023-01-07
Egy tanmese a szerény, de tehetséges informatikusról, akit én csak Gézának hívok
privacyaware, privacy
2023-01-02
Beskatulyáznád magad egy termékkel? Gondold át még egyszer!
learning, vendorlockin, risky
2022-12-11
Rekrúterekről és állásajánlatokról
bérsáv, recruiter, relevancia
2022-10-30
"A hídon akkor kell átmenni, amikor odaérünk."​ - YAGNI
yagni, pagni
2022-10-17
"A lényeg, hogy a munka készen legyen!"
agile, estimation, becsles, scrum, home office
2022-08-20
Munka vs. hivatás, a klasszikus dilemma
hr, hobbi, munka, egyensuly, hivatas
2022-07-18
Miért nem fogok nálatok technikai interjún részt venni?
technikai interju, hr, recruit, leet code, coding challenge, take home challenge
2022-07-04
"Hogyan építsek kapcsolati tőkét, ha karriert szeretnék váltani?"
linkedin, tippek, trukkok
2022-06-10
Junior/Medior/Senior, hogyan mérjük?
junior, medior, senior, hr, grade, level, experience
2022-05-09
11 tipp frontendeseknek, hogyan tegyék hatékonyabbá a munkájukat
frondend, vscode, angular
2021-10-31
Motion zoom - mozgás alapú képrekonstrukció
#52het
2021-06-01
Gesture Launcher
#52het
2021-05-31
CellEvent, első Android alkalmazásom
#52het
2021-05-19
Notebookcheck, azaz hogyan válasszuk ki a legjobb ár-érték arányú eszközt
#52het
2021-05-18
Torrent multiplexer
#52het
2021-05-17
Process watcher, logger
#52het
2021-05-05
Lazy loading material dialog content
lazy loading, angular, material, dialog
2020-12-28
Runtime configuration loading in Angular
angular, runtime, configuration, settings, environment, production
2020-03-29
How to start an Angular project?
angular
2020-03-11
Az 52 hét projekt
#52het
2020-01-01
Akkutöltöttség-jelző
#52het
2020-01-01
NetClub - Kollégiumi internetszolgáltató
#52het
2019-12-31
DeeJayy - Lost Terminal
#52het
2019-12-31
Counter Strike monitor
#52het
2019-12-31
Kollégiumi CS bajnokság 2005
#52het
2019-12-31
Mozgásérzékelős képrögzítő, Camera Capture
#52het
2019-12-30
Többszörös host pingelő
#52het
2019-12-30
Sávszélesség mérő, tesztelő
#52het
2019-12-30
Generáljunk hamis adatokat
#52het
2019-12-30
SQL lekérdezések parancssorból, odbc-vel
#52het
2019-12-30
Nonogram generátor (aka. "Fesse feketére")
#52het
2019-12-30
Egyedi chat alkalmazás, kliens és szerver
#52het
2019-12-29
FontSelector - betűtípusválasztó / font preview
#52het
2019-12-28
Saját hálózati kommunikációs segédszoftver - sox
#52het
2019-12-28
Csoportos e-mail küldő szoftver Delphiben
#52het
2019-12-28
Universal Api caller module for Angular 7-9 With NGRX state management
Ngrx, API, Effects, HttpClient
2019-07-02
A leghosszabb projekt
#52het
2019-04-19
Legelső kioszk projektem: Stari Sör Jukebox
#52het
2019-02-28
BPM számláló
#52het
2018-11-01
Assembly féléves beadandók
#52het
2018-11-01
Chatbot before it was cool
#52het
2018-10-30
StartX - Cseréljük ki a windows tálcáját és a Start menüt
#52het
2018-10-28
What? - fájltípus azonosító
#52het
2018-10-27
Transport Tycoon DirectX
#52het
2018-10-26
Diff - fájlösszehasonlító
#52het
2018-10-26
De Facto - Szoftverfelügyelet
#52het
2018-10-25
CD és DVD katalogizáló
#52het
2018-09-24
MP3 segédeszközök
#52het
2018-09-24
Keylogger - azaz billentyűleütés-figyelő és naplózó alkalmazás
#52het
2018-08-29
Az örök projekt: személyes weboldal és blog
#52het
2018-08-14
Szógyakorló nyelvtanuláshoz
#52het
2018-08-13
Warzone 2100 mentett játék szerkesztő
#52het
2018-08-13
Rejtett Windows-beállításokat konfiguráló program: TweakMaster
#52het
2018-08-13
A DrótPostaGalamb levelezőprogram adatfájljainak dekódolása
#52het
2018-08-13
Privacy jegyzet
2018-07-30
Egy éve ilyenkor
2018-07-25
The Matrix - konzol szimuláció
#52het
2018-07-13
Kakaóreceptkönyv
kakaó
2018-06-29
Crackelés!
#52het
2018-06-22
A K.I.T.T. challenge
#52het
2018-06-18
Doom 2 botokkal
#52het
2018-06-16
Römi játék Delphiben
#52het
2018-06-09
MeetsCow & DeeJayy - Intro
#52het
2018-06-09
Direct viewer - bitmap megjelenítő
#52het
2018-06-09
bazMAG
#52het
2018-06-09
Console Vision - Konzolos ablakkezelő Delphiben
#52het
2018-05-01
Quake 2 egy floppyn
#52het
2018-04-20
Játék-kitömörítők
#52het
2018-04-12
Tetszőleges program elrejtése Windows tálcáról
#52het
2018-04-05
Személyre szabás
#52het
2018-03-28
A year with Angular 5, 6 - Angular 2018
#angular5 #angular #resources #articles
2018-03-16
Az ikon evolúciója
#52het
2018-03-14
Betűtípusok
#52het
2018-03-04
Billentyűzet-gyakorló
#52het
2018-02-28
Zenél is a DeeJayy?
#52het
2018-02-22
Térképrajzoló az Ascii 3D labirintushoz
#52het
2018-02-19
Ascii 3D labyrinth
#52het
2018-02-14
52 hét - 52 projekt, avagy #eletem
#52het
2018-02-14
Dockerezzünk virtualizált környezetben!
docker, xen, ubuntu
2017-11-12
A cloud-initramfs-copymods hatásai paravirtualizált környezetben
ubuntu, xen, copymods, docker, docker-ce, docker.io
2017-11-11
Virtualizáljunk Xen 4.6-tal Ubuntu 16-on (Xenial)
ubuntu, xen, virtualizálás, hypervisor, debootstrap
2017-11-04
Álláskeresésem története
álláskeresés, it, fejvadászok, linkedin, job
2017-10-24
FAR Manager competitors
far manager, file managers
2010-01-01
Blog
blog
2001-01-02

Mi az a copymods?

A copymods lényege röviden annyi, hogy az initrd-ből egy tmpfs-re kimásolja a benne található kernelmodulokat, majd felmountolja a /lib/modules könyvtárba, ha az létezik. Az, hogy a copymods aktív-e, a következő paranccsal lehet ellenőrizni:

mount | egrep copymods

Ha a parancsnak nincs kimenete, akkor a copymods nem aktív, tehát a rendszer a /lib/modules/<kernelverzió> könyvtár alatti modulokat tölti be. A továbbiakban viszont azt tárgyalom, hogy, ha mégis aktív, akkor hogyan tudjuk kikapcsolni vagy úgy beállítani, hogy ne okozzon gondot.

Az initramfs-ben mi található?

lsinitramfs /boot/initrd.img-`uname -r`

Benne van-e a copymods script?

lsinitramfs /boot/initrd.img-`uname -r` | egrep copymods

Ez azért okozhat problémát, mert amikor létrehozunk egy paravirtualizált (Xen) guest-et, akkor meg kell adni, hogy milyen kernellel és initrd-vel induljon el:

kernel      = '/boot/vmlinuz-4.4.0-87-generic'
ramdisk     = '/boot/initrd.img-4.4.0-87-generic'

Abban az esetben, ha az initrd-ben van copymods script, akkor teljesen mindegy, hogy a guest fájlrendszerébe felmásoltuk-e korábban a /lib/modules tartalmát a host oprendszerből, vagy sem, ezért nagyon sok modul hiányozhat pl. egy docker használata esetén.

Megoldási módok

1. copymods script törlése/átírása

Nem túl szép megoldás, inkább tüneti kezelésnek mondanám, rövidtávú, instabil hack.

Az initrd-be kerülő copymods script a /usr/share/initramfs-tools/scripts/init-bottom könyvtárban található. Törüljük vagy kommentezzük ki a problémás részeket belőle, utána update-eljük az initramfs-t.

update-initramfs -u -k all

Ezután (ha töröltük és nem módosítottuk), már nem kellene találatot kihoznia a következő sornak:

lsinitramfs /boot/initrd.img-`uname -r` | egrep copymods

2. copymods csomag eltávolítása

Eltávolíthatjuk az oprendszergen található copymods csomagot:

apt purge cloud-initramfs-copymods

Ez a parancs automatikusan update-eli az aktuális kernel initrd fájlját is, tehát nem kell kézzel futtatni.

Ezután sem kellene találatot kihoznia a következő sornak:

lsinitramfs /boot/initrd.img-`uname -r` | egrep copymods

Nem biztos, hogy ez a legstabilabb megoldás, hiszen bármilyen más csomagnak lehet függősége és később felkerülhet.

3. szükséges modulok hozzáadása

Amikor dockert akartam futtatni virtualizált környezetben, belefutottam abba a problémába, hogy nem indul el a szerviz, mert modulok hiányoztak neki:

dockerd: level=warning msg="Running modprobe bridge br_netfilter failed with message: modprobe: WARNING: Module bridge not found in directory /lib/modules/4.4.0-87-gen
dockerd: modprobe: WARNING: Module br_netfilter not found in directory /lib/modules/4.4.0-87-generic
dockerd: error: exit status 1"
dockerd: level=warning msg="Running modprobe nf_nat failed with message: `modprobe: WARNING: Module nf_nat not found in directory /lib/modules/4.4.0-87-generic`, error
dockerd: level=warning msg="Running modprobe xt_conntrack failed with message: `modprobe: WARNING: Module xt_conntrack not found in directory /lib/modules/4.4.0-87-gen

Ez azért van, mert az initramfs-ből felül lett írva a /lib/modules könyvtár, tehát hiába másoltam oda minden modult, amit itt a docker hiányol.

A megoldás itt az, hogy az initrd-hez hozzáadjuk a szükséges modulokat a hoszt oprendszeren:

vi /etc/initramfs-tools/modules

...

br_netfilter
bridge
ip_tables
ipt_MASQUERADE
iptable_filter
iptable_nat
llc
nf_conntrack
nf_conntrack_ipv4
nf_conntrack_netlink
nf_nat
nf_nat_ipv4
nf_nat_masquerade_ipv4
stp
x_tables
xt_addrtype
xt_conntrack
veth

Majd update-initramfs:

update-initramfs -u -k all

Ezek után ellenőrizzük, hogy az az initramfs, ami be van állítva a Xen guest-nek (ramdisk paraméter), tartalmazza-e a modulokat, amiket hozzáadtunk:

lsinitramfs /boot/initrd.img-4.4.0-87-generic | egrep "br_netfilter|bridge|ip_tables|ipt_MASQUERADE|iptable_filter|iptable_nat|llc|nf_conntrack|nf_conntrack_ipv4|nf_conntrack_netlink|nf_nat|nf_nat_ipv4|nf_nat_masquerade_ipv4|stp|x_tables|xt_addrtype|xt_conntrack"

Rebootolni sem kell, az ezután induló xen guestek már ezt az initrd-t fogják használni.