উবুন্টুতে "রেপ্রেপ্রো" সরঞ্জামটি ব্যবহার করে সোর্সফোর্জন.নেটে একটি ".deb প্যাকেজ সংগ্রহস্থল" তৈরি করুন
রেপ্রেপ্রো .deb সহজেই সংগ্রহস্থলগুলি তৈরি এবং পরিচালনা করার জন্য একটি ছোট কমান্ড-লাইন সরঞ্জাম, আজ আমরা দেখাব যে কীভাবে সহজেই ডিপ্রিও ব্যবহার করে ডেবিয়ান প্যাকেজ সংগ্রহস্থল তৈরি করা যায় এবং কীভাবে আরএসএনসি কমান্ড ব্যবহার করে সোর্সফোর্জন.টনে আপলোড করুন।
পদক্ষেপ 1: Reprepro ইনস্টল করুন এবং কী উত্পন্ন করুন
প্রথমে নিম্নলিখিত এপ-গেট কমান্ডটি ব্যবহার করে প্রয়োজনীয় সমস্ত প্যাকেজ ইনস্টল করুন।
$ sudo apt-get install reprepro gnupg
এখন আপনাকে gnupg ব্যবহার করে একটি জিপিজি কী তৈরি করতে হবে, এটি করতে এই আদেশটি প্রয়োগ করুন।
$ gpg --gen-key
এটি আপনাকে কিছু প্রশ্ন জিজ্ঞাসা করবে, কী কী ধরণের চাওয়ার মত, কীটি কতক্ষণ বৈধ হওয়া উচিত, যদি আপনি কী উত্তর দিতে না জানেন তবে ডিফল্ট বিকল্পগুলির জন্য এন্টার ক্লিক করুন (প্রস্তাবিত )।
অবশ্যই, এটি আপনাকে একটি ব্যবহারকারীর নাম এবং একটি পাসওয়ার্ড জিজ্ঞাসা করবে, এগুলি মনে রাখবেন, কারণ আমাদের পরে তাদের প্রয়োজন হবে।
gpg (GnuPG) 1.4.14; Copyright (C) 2013 Free Software Foundation, Inc. This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. Please select what kind of key you want: (1) RSA and RSA (default) (2) DSA and Elgamal (3) DSA (sign only) (4) RSA (sign only) Your selection? RSA keys may be between 1024 and 4096 bits long. What keysize do you want? (2048) Requested keysize is 2048 bits Please specify how long the key should be valid. 0 = key does not expire = key expires in n days w = key expires in n weeks m = key expires in n months y = key expires in n years Key is valid for? (0) Key does not expire at all Is this correct? (y/N) Y You need a user ID to identify your key; the software constructs the user ID from the Real Name, Comment and Email Address in this form: "Heinrich Heine (Der Dichter) <[email >" Real name: ravisaive Email address: [email Comment: tecmint You selected this USER-ID: "Ravi Saive (tecmint) <[email >" Change (N)ame, (C)omment, (E)mail or (O)kay/(Q)uit? O You need a Passphrase to protect your secret key. We need to generate a lot of random bytes. It is a good idea to perform some other action (type on the keyboard, move the mouse, utilize the disks) during the prime generation; this gives the random number generator a better chance to gain enough entropy. +++++ gpg: key 2EB446DD marked as ultimately trusted public and secret key created and signed. gpg: checking the trustdb gpg: 3 marginal(s) needed, 1 complete(s) needed, PGP trust model gpg: depth: 0 valid: 1 signed: 0 trust: 0-, 0q, 0n, 0m, 0f, 1u pub 2048R/2EB446DD 2014-06-24 Key fingerprint = D222 B1C9 342E 5911 02B1 9147 3BD6 7918 2EB4 46DD uid Ravi Saive (tecmint) <[email > sub 2048R/7EF2F750 2014-06-24
এখন আপনার কী উত্পন্ন হবে, যদি তা পরীক্ষা করার জন্য, এই কমান্ডটি মূল সুবিধাগুলি হিসাবে চালান।
$ sudo gpg --list-keys
/home/ravisaive/.gnupg/pubring.gpg ---------------------------------- pub 2048R/2EB446DD 2014-06-24 uid ravisaive (tecmint) <[email > sub 2048R/7EF2F750 2014-06-24
পদক্ষেপ 2: একটি প্যাকেজ সংগ্রহস্থল এবং রফতানি কী তৈরি করুন
সংগ্রহশালা তৈরি করার জন্য আমরা এখনই কাজটি শুরু করব, প্রথমে আপনাকে কয়েকটি ফোল্ডার তৈরি করতে হবে, আমাদের সংগ্রহশালা /var/www/apt ডিরেক্টরিতে থাকবে, সুতরাং আসুন কিছু ফোল্ডার তৈরি করা যাক।
$ sudo su # cd /var/www # mkdir apt # mkdir -p ./apt/incoming # mkdir -p ./apt/conf # mkdir -p ./apt/key
আপনার এখন তৈরি করা কীটি সংগ্রহস্থল ফোল্ডারে রফতানি করতে হবে, রান করুন।
# gpg --armor --export username [email >> /var/www/apt/key/deb.gpg.key
দ্রষ্টব্য: আপনি উপরের পদক্ষেপে প্রবেশ করা ব্যবহারকারীর নাম এবং আপনার ইমেলের সাথে [ইমেল সুরক্ষিত] প্রতিস্থাপন করুন।
আমাদের /var/www/apt/conf এর ভিতরে " বিতরণ " নামে একটি ফাইল তৈরি করতে হবে।
# touch /var/www/apt/conf/distributions
এই নিম্নলিখিত লাইনগুলি বিতরণ ফাইলে যুক্ত করুন এবং ফাইলটি সংরক্ষণ করুন।
Origin: (yourname) Label: (name of repository) Suite: (stable or unstable) Codename: (the codename for the distribution you are using, like trusty) Version: (the version for the distribution you are using, like 14.04) Architectures: (the repository packages architecture, like i386 or amd64) Components: (main restricted universe multiverse) Description: (Some information about the repository) SignWith: yes
এরপরে, আমাদেরকে সংগ্রহস্থল গাছ তৈরি করতে হবে, এটি করতে, সেই আদেশগুলি চালাতে হবে।
# reprepro --ask-passphrase -Vb /var/www/apt export
Created directory "/var/www/apt/db" Exporting Trusty... Created directory "/var/www/apt/dists" Created directory "/var/www/apt/dists/Trusty" Created directory "/var/www/apt/dists/Trusty/universe" Created directory "/var/www/apt/dists/Trusty/universe/binary-i386" FF5097B479C8220C ravisaive (tecmint) <[email > needs a passphrase Please enter passphrase: Successfully created '/var/www/apt/dists/Trusty/Release.gpg.new' FF5097B479C8220C ravisaive (tecmint) <[email > needs a passphrase Please enter passphrase: Successfully created '/var/www/apt/dists/Trusty/InRelease.new'
পদক্ষেপ 3: নতুন তৈরি করা সংগ্রহস্থলে প্যাকেজ যুক্ত করুন
সংগ্রহস্থলে যোগ করার জন্য এখন আপনার .deb প্যাকেজগুলি প্রস্তুত করুন। /var/www/apt ডিরেক্টরিতে যান, প্রতিবার আপনি প্যাকেজ যুক্ত করতে চাইলে আপনাকে এটি করতে হবে।
# cd /var/www/apt # reprepro --ask-passphrase -Vb . includedeb Trusty /home/ravisaive/packages.deb
দ্রষ্টব্য: ডিস্ট্রিবিউশন ফাইলে সংগ্রহস্থলের জন্য আপনার যে কোড কোডটি প্রবেশ করা হয়েছে তার সাথে বিশ্বস্ত প্রতিস্থাপন করুন এবং প্যাকেজটির পাথের সাথে /home/username/package.deb প্রতিস্থাপন করুন পাসফ্রেজ প্রবেশের জন্য জিজ্ঞাসা করা হবে।
/home/ravisaive/packages.deb : component guessed as 'universe' Created directory "./pool" Created directory "./pool/universe" Created directory "./pool/universe/o" Created directory "./pool/universe/o/ojuba-personal-lock" Exporting indices... FF5097B479C8220C ravisaive (tecmint) <[email > needs a passphrase Please enter passphrase: Successfully created './dists/Trusty/Release.gpg.new' FF5097B479C8220C ravisaive (tecmint) <[email > needs a passphrase Please enter passphrase: Successfully created './dists/Trusty/InRelease.new'
আপনার প্যাকেজটি সরানোর জন্য, সংগ্রহস্থলে যুক্ত করা হয়েছে।
# reprepro --ask-passphrase -Vb /var/www/apt remove trusty package.deb
এবং অবশ্যই, আপনাকে আপনার প্যাকেজের নাম এবং সংগ্রহস্থল কোডনাম দিয়ে কমান্ডটি পরিবর্তন করতে হবে।
পদক্ষেপ 4: সোর্সফোর্জন.নেটে সংগ্রহস্থল আপলোড করুন
Sourceforge.net এ সংগ্রহস্থলটি আপলোড করতে আপনার অবশ্যই সেখানে একটি চলমান অ্যাকাউন্ট এবং একটি চলমান প্রকল্পের দরকার আছে, ধরে নেওয়া যাক আপনি http:// উত্সফোরে এই সংগ্রহস্থলটি আপলোড করতে চান .net/প্রজেক্টস/মাইফু/টেস্টিরিপোসিটিরি যেখানে মাইফু আপনার প্রকল্পের নাম (ইউনিক্স নাম, ইউআরএল নয়, শিরোনাম নয়) এবং টেস্টেরপোসিটরি সেই ফোল্ডারে যেখানে আপনি ফাইলগুলি আপলোড করতে চান, আমরা আরএসসিএনসি ব্যবহার করে এটি করব আদেশ
# rsync -avP -e ssh /var/www/apt/ [email :/home/frs/project/myfoo/testrepository/
দ্রষ্টব্য: সোর্সফোর্জন.টেনে আপনার ব্যবহারকারীর নাম এবং মাইফুর সাথে আপনার প্রকল্পের ইউনিক্স-নাম এবং টেস্টেরপোজিটরিটি যে ফোল্ডারে আপনি ফাইলগুলি সংরক্ষণ করতে চান তা প্রতিস্থাপন করুন।
এখন এটি আপনার ইনস্টল করা সিস্টেমে http://sourceforge.net/projects/myfoo/testrepository এ আপলোড করা হয়েছে, প্রথমে আপনাকে সংগ্রহস্থল কীটি আমদানি করতে হবে, এটি < b> /var/www/apt/key/deb.gpg.key , তবে এটি স্থানীয় পথ এবং আপনার সংগ্রহস্থলের ব্যবহারকারীরা তাদের সিস্টেমে এটি যুক্ত করতে সক্ষম হবেন না, তবে আমরা কেন থাকব Sourceforge.net থেকে কীটি আমদানি করা হচ্ছে।
$ sudo su # wget -O - http://sourceforge.net/projects/myfoo/testrepository/apt/key/deb.gpg.key | apt-key add -
আপনি এখন আপনার সিস্টেমে সহজেই সংগ্রহস্থল যুক্ত করতে পারেন /etc/apt/sources.list খুলুন এবং এই লাইনটি যুক্ত করতে পারেন।
deb http://sourceforge.net/projects/myfoo/testrepository/apt/key/deb.gpg.key trusty main
দ্রষ্টব্য: মাইফুকে আপনার প্রকল্প ইউনিক্স-নাম দিয়ে প্রতিস্থাপন করুন, আপনার সংগ্রহস্থল কোডনামের সাথে বিশ্বাসযোগ্য, টেস্টিপোসিটরিটি আপনি যে ফোল্ডারে ফাইলগুলি আপলোড করেছেন তার সাথে এবং ডিস্ট্রিবিউশন ফাইলে আপনি সংস্থাগুলির উপাদান যুক্ত করেছেন main
এরপরে, সংগ্রহস্থলগুলির তালিকা আপডেট করতে নিম্নলিখিতটি চালান।
$ sudo apt-get update
অভিনন্দন! আপনার সংগ্রহস্থল সক্রিয়! আপনি চাইলে এখন তা থেকে সহজেই প্যাকেজ ইনস্টল করতে পারবেন।