ماجرا از جایی شروع شد که به امین، یه #رزبریپای دادم که شروع کنه برنامهنویسی یاد بگیره اما تصمیم گرفت که کارهای گرافیکی کنه. براش #اینکاسکیپ نصب کردم و یه قدری هم بهش آموزش دادم اما بهش گفتم فیلمهای شروع سریع کار با اینکاسکیپ و باز طراحی پوستر لاگ ایلام در نرمافزار اینکاسکیپ رو که در ایلاملاگ ارائه داده بودم و روی پیرتیوب منتشر کرده بودم ببینه. اون هم شروع کرد به دیدن و خوب هم پیشرفت کرد.
این وسط دو مشکل داشتیم: اول اینکه انگلیسی امین خوب نیست و مجبوره محیط رو فارسی کنه و دوم اینکه نسخه اینکاسکیپ روی مخازن، ۰٫۹۲ خیلی قدیمی بود که متن راست به چپ را پشتیبانی نمیکرد. در مورد مشکل اول، سالها پیش بخشهایی از اینکاسکیپ به فارسی ترجمه شده. اما خیلی ناقصه. لازم بود که روی ترجمهاش کار کنم. اما منطقی نبود که روی ترجمه نسخه قدیمی وقت گذاشت. در مورد مشکل دوم هم فعلا مشکلش رو با ساخت قالب پیشفرضی که به صورت دستی، جهت متن کل سند، راست به چپ تنظیم شده حل کردم. اما راهحل، این نیست. هم به این خاطر و هم به خاطر ویژگیهای جدید نسخه ۱، بهتر بود که یه جوری به نسخه ۱ ارتقا بدیم. اینطوری، هر دو مشکل رفع میشدند.
قدری بررسی کردم و در فضای گفتگویی که کاربران اینکاسکیپ دارند، موضوع رو مطرح کردم. کسی پیام داد که در مخازن backports دبیان نسخه ۱ اینکاسکیپ وجود داره. قدری چرخ زدم و متوجه شدم آن مخزن، برای نسخه دبیان buster هست ولی نسخه رزبین روی رزبریپای، بر اساس دبیان stretch بود. کار سخت شد. من هم دیگه ایران نبودم که بتونم مستقیم برای امین یه رزبین جدید نصب کنم. تنها کاری که میشد کرد، ارتقای مستقیم از stretch به buster بود. شانسی که آوردیم این بود که خودم هم رزبریپای داشتم. بنابراین تصمیم گرفتم یک بار این ارتقا را روی دستگاه خودم انجام دهم و بعد در صورت موفقیت، این کار را از راه دور برای امین انجام دهم.
شروع به روزرسانی
کار را بر اساس آموزشی در همین رابطه آغاز کردم. شروع کار (طبیعتا) با این دستورات بود:
sudo apt update
sudo apt dist-upgrade -y
اما همین اول به مشکل برخوردم:
➜ ~ sudo apt dist-upgrade -y
Reading package lists... Done
Building dependency tree
Reading state information... Done
Calculating upgrade... Done
The following package was automatically installed and is no longer required:
libmicrodns0
Use 'sudo apt autoremove' to remove it.
0 upgraded, 0 newly installed, 0 to remove and 0 not upgraded.
1 not fully installed or removed.
After this operation, 0 B of additional disk space will be used.
Setting up wolfram-engine (12.0.1+2019062401) ...
ln: failed to create symbolic link '/usr/share/icons/nuoveXT2/64x64/mimetypes/application-mathematica.png': File exists
dpkg: error processing package wolfram-engine (--configure):
subprocess installed post-installation script returned error exit status 1
Errors were encountered while processing:
wolfram-engine
E: Sub-process /usr/bin/dpkg returned an error code (1)
برنامه wolfram-engine نیاز داشت یه سری پرونده ایجاد کنه که از قبل وجود داشتند. خطایی که میده، خطای مسخرهای است. منطقا یا باید در صورت وجود، بی خیال بشه، یا باید جایگزین کنه و یا میتونه سوال کنه. اما ترجیح میده با چنین خطایی، بهروزرسانی کل دستگاه رو با اختلال مواجه کنه. سوال را روی raspberrypi.stackexchange.com پرسیدم اما به جز نهی کردن از بهروزرسانی مستقیم، جوابی نگرفتم. رفتم بررسی کردم ببینم این برنامه چیه که دیدم لازمش ندارم. حذفش کردم و حل شد.
دستورها را دوباره اجرا کردم. اما این بار طبق همان آموزشی که بالاتر اشاره کردم، مخازن را از stretch به buster تغییر دادم. برای این کار، محتوای پروندههای زیر را (با دسترسی root) ویرایش و buster را جایگزین stretch کردم:
/etc/apt/sources.list
/etc/apt/sources.list.d/raspi.list
مجددا دستورات زیر را اجرا کردم:
sudo apt update
sudo apt dist-upgrade -y
این بار، پس از دریافت بیش از ۲ گیگابایت بستههای جدید، در آخر کار به خطای زیر خوردم:
Err:1 http://archive.raspberrypi.org/debian buster/main armhf raspberrypi-kernel armhf 1.20210108-1
Hash Sum mismatch
Hashes of expected file:
- SHA256:9ecb41e8129827e18f1addee8105491f0227f320f3fccfadaa2507e57229f8b9
- SHA1:49434d37d9a840805b38e893660f178e6efcd1bc [weak]
- MD5Sum:514c436e37abab16414852e6f0b1eadd [weak]
- Filesize:76426824 [weak]
Hashes of received file:
- SHA256:ab4000628b59585d0c260db1b09b3bdd2c527eb030ae5d5fb3dc65b26484ffca
- SHA1:edf95406a68889f193aa87e95745597d0c3e05f0 [weak]
- MD5Sum:14ed22b18b1477a27c96dd631b05a450 [weak]
- Filesize:34230959 [weak]
Last modification reported: Fri, 08 Jan 2021 15:50:34 +0000
Fetched 34.2 MB in 5min 57s (95.7 kB/s)
E: Failed to fetch http://archive.raspberrypi.org/debian/pool/main/r/raspberrypi-firmware/raspberrypi-kernel_1.20210108-1_armhf.deb Hash Sum mismatch
Hashes of expected file:
- SHA256:9ecb41e8129827e18f1addee8105491f0227f320f3fccfadaa2507e57229f8b9
- SHA1:49434d37d9a840805b38e893660f178e6efcd1bc [weak]
- MD5Sum:514c436e37abab16414852e6f0b1eadd [weak]
- Filesize:76426824 [weak]
Hashes of received file:
- SHA256:ab4000628b59585d0c260db1b09b3bdd2c527eb030ae5d5fb3dc65b26484ffca
- SHA1:edf95406a68889f193aa87e95745597d0c3e05f0 [weak]
- MD5Sum:14ed22b18b1477a27c96dd631b05a450 [weak]
- Filesize:34230959 [weak]
Last modification reported: Fri, 08 Jan 2021 15:50:34 +0000
E: Unable to fetch some archives, maybe run apt-get update or try with --fix-missing?
مطابق پیشنهاد خط پایانی، دستورات sudo apt update
و sudo apt install --fix-missing
را اجرا کردم اما مشکل رفع نشد. موضوع را روی raspberrypi.stackexchange.com مطرح کردم اما باز هم پاسخ گرفتم که ارتقای مستقیم از stretch به buster پیشنهاد نمیشه. به گروه رزبریپای روی ماتریکس پیام دادم و دوستان هم کمک کردند اما باز هم مشکل حل نشد.
در این فاصله، یک بخش دیگر از دستوراتی که در آموزش دیده بودم را به کار بستم؛ دستوری که سفتافزار (firmware) را بهروز میکرد. هم خود دستور و هم بسیاری جاها روی اینترنت تاکید داشتند که هرگز این کار را نکنید. اما دل را به دریا زدم و دستور زیر را اجرا کردم:
sudo rpi-update
خدا را شکل بدون مشکل نصب شد و دستگاه هم به درستی بالا آمد. اما مشکل قبلی هنوز پابرجا بود.
شروع کردم به بررسی خط به خط خطایی که نمایش داده میشد. متوجه شدم که به جای دریافت پروندهای با اندازه 76426824، پروندهای با اندازه 34230959 بایت دریافت میشود و طبیعی است که hash sum این دو پرونده با هم تطابق نداشته باشه. (hash sum، روشی برای بررسی تطابق عین به عین دو پرونده است) تلاش کردم مستقیم دریافتش کنم که چند بار سر ۴۹ درصد، بارگیری به شکست میخورد. نهایتا (همراه با چند بالا و پایین نه چندان مهم) این پرونده را کامل بارگیری کرده و آن را در جایی که بستههای بهروزرسانی دیگر قرار داشتند کپی کردم؛ در این نشانی:
/var/cache/apt/archive/
پس از این مرحله، مجددا دستور sudo apt dist-upgrade -y
را اجرا کردم و نصب بستهها آغاز شد. بعد از چند ساعت و پاسخ به پرسشهایی در ارتباط با جایگزین پرونده تنظیمات چند برنامه با نسخه جدید (که برخی را بررسی کرده و متناسب با تغییرات، اجازه جایگزینی را دادم) بهروزرسانی کامل شد.
تا اینجا، رزبری از سیستمعامل مبتنی بر دبیان stretch به سیستمعامل مبتنی بر دبنیان buster ارتقا پیدا کرده بود و همه چیز هم به خوبی کار میکرد. حالا نوبت به اینکاسکیپ رسیده بود. برای این کار لازم بود مخزن backports دبیان را به فهرست مخازن اضافه کنم. برای این کار، خط زیر را به /etc/apt/sources.list
اضافه کردم:
deb http://deb.debian.org/debian buster-backports main contrib non-free
سپس، نیز به بهروزرسانی مخازن بود و…. خطای جدید:
➜ ~ sudo apt update
Hit:1 http://raspbian.raspberrypi.org/raspbian buster InRelease
Get:2 http://deb.debian.org/debian buster-backports InRelease [46.7 kB]
Hit:3 http://archive.raspberrypi.org/debian buster InRelease
Hit:4 http://packages.microsoft.com/repos/code stable InRelease
Err:2 http://deb.debian.org/debian buster-backports InRelease
The following signatures couldn't be verified because the public key is not available: NO_PUBKEY 04EE7237B7D453EC NO_PUBKEY 648ACFD622F3D138
Reading package lists... Done
W: GPG error: http://deb.debian.org/debian buster-backports InRelease: The following signatures couldn't be verified because the public key is not available: NO_PUBKEY 04EE7237B7D453EC NO_PUBKEY 648ACFD622F3D138
E: The repository 'http://deb.debian.org/debian buster-backports InRelease' is not signed.
N: Updating from such a repository can't be done securely, and is therefore disabled by default.
N: See apt-secure(8) manpage for repository creation and user configuration details.
دلیل بروز این خطا این است که کلید رمزنگاری مخزن، روی دستگاه من نیست و لذا (اگر درست بگویم) اعتبارسنجی تطابق پروندههای آن مخزن برای من میسر نخواهد بود. با جستجویی ساده در اینترنت، شیوه دریافت کلیدهای مربوط به رمزنگاری این مخازن را یافتم. با دو دستور زیر، اطلاعات لازم برای کلیدهای خواسته شده را دریافت کردم:
➜ ~ sudo apt-key adv --keyserver hkp://pool.sks-keyservers.net:80 --recv-keys 04EE7237B7D453EC
Executing: /tmp/apt-key-gpghome.lIZGQoIfwR/gpg.1.sh --keyserver hkp://pool.sks-keyservers.net:80 --recv-keys 04EE7237B7D453EC
gpg: key E0B11894F66AEC98: public key "Debian Archive Automatic Signing Key (9/stretch) <ftpmaster@debian.org>" imported
gpg: Total number processed: 1
gpg: imported: 1
➜ ~ sudo apt-key adv --keyserver hkp://pool.sks-keyservers.net:80 --recv-keys 648ACFD622F3D138
Executing: /tmp/apt-key-gpghome.N6TmoFgj5O/gpg.1.sh --keyserver hkp://pool.sks-keyservers.net:80 --recv-keys 648ACFD622F3D138
gpg: keyserver receive failed: No data
هرچند دستور دوم با خطا مواجه شد اما ظاهرا تاثیری در ادامه کار نداشت. گام بعدی، نصب اینکاسکیپ از بود. انتظار داشتم با دستور معمول sudo apt install inkscape
کار نصل انجام شود اما چنین نشد. نسخه روی مخازن هنوز قدیمی بود. با یک بررسی مختصر متوجه شدم که به طور پیشفرض، apt از مخازن backports برای نصب استفاده نمیکند و اگر کسی بخواهد چنین کند، باید به طور دقیق چنین خواستهای را مطرح کند. این کار هم با افزون گزینه مربوط به این کار قابل انجام بود؛ به این شکل:
➜ ~ sudo apt -t buster-backports install inkscape
و نصب انجام شد!
تمام :)
جمعبندی
قشنگی دنیای #گنولینوکس و #نرمافزار_آزاد همین است که میشود ریز اتفاقات را دید و دنبال کرد و حتی دستکاریشان کرد. البته من کار خاصی نکردم اما همین مقدار هم کم نیست. و نکته دیگر اینکه از خطاها نباید ترسید. گاهی با خواندن خطاها، میتوان درد را فهمید. هیچ کس به من نگفت (یکی گفت اما دیر گفت) که چرا فلان پرونده، ناقص بارگیری میشود. خودم فهمیدم و برایش چارهای اندیشیدم.
خلاصه اینکه تمرین ارتقا از stretch به buster روی رزبری خودم، با موفقیت انجام شد. حال، باید این کار را روی دستگاه امین و از راه دور انجام دهم.
Comments
February 3, 2021 18:23
@ahangarha
اگه من تو موقعیت مشابهی گیر میوفتادم احتمالا بسته .deb اش رو از https://packages.debian.org/buster-backports/amd64/inkscape/download
دانلود میکردم و بعد با dpkg -i نصبش میکردم.
February 3, 2021 18:27
@ahangarha
البته اینجا اشتباهی لینک بسته amd64 رو فرستادم ( طبق عادت D: )
من تو موقعیت مشابه طبیعتا بسته arm رو دانلود میکردم.
February 3, 2021 18:52
@amirzlf @ahangarha
وابستگیهاش چی؟
February 3, 2021 19:14
@ahangarha @ahangarha
الان این صفحه
https://wiki.inkscape.org/wiki/index.php/Tracking_Dependencies
رو چک کردم بین اون دو نسخه فقط نسخه تعداد کمی از وابستگی ها متفاوته که میشه نسخه جدید اونا رو هم به همین شکل نصب کرد.
( بعدش هم اگه برنامه دیگه ای تو سیستم باشه که به نسخه قبلی اون وابستگی نیاز داشته باشه در اکثر مواقع با چند تا soft link از لایبرری های جدید به قدیم مشکل حل میشه)
کار دیگه ای هم که ممکن بود انجام بدم نصب از appimage یا flatpak عه که توش مشکل وابستگی خود به خود حل شده است.
February 4, 2021 03:47
@amirzlf @ahangarha
ممنون
البته درباره اپایمیج و فلتپک و اسنپ، ترجیحم همیشه اینه که از اینها استفاده نکنم. باز اپایمیج یه کاربردهایی برام داره اما از اون دو تا سعی میکنم پرهیز کنم.
بقیهاش رو هم تجربهای نداشتهام در این سطح. اگر خودت رزبریپای داری، با این روشی که گفتی نصب کن و تجربهات رو به اشتراک بگذار. دیدن روشهای مختلف انجام کار، همیشه جالبه.