Vietnē Sourceforge.net izveidojiet ".deb pakešu krātuvi", izmantojot Ubuntu rīku "Reprepro"
Reprepro ir mazs komandrindas rīks, lai viegli izveidotu un pārvaldītu .deb krātuves. Šodien mēs parādīsim, kā viegli izveidot Debian pakotņu krātuves, izmantojot reprepro un kā augšupielādējiet to vietnē Sourceforge.net, izmantojot komandu rsync .
1. darbība: instalējiet Reprepro un Generate Key
Vispirms instalējiet visas nepieciešamās paketes, izmantojot šādu komandu apt-get.
$ sudo apt-get install reprepro gnupg
Tagad jums jāģenerē gpg atslēga, izmantojot gnupg , lai to izdarītu, izmantojiet šo komandu.
$ gpg --gen-key
Tas jums uzdos dažus jautājumus, piemēram, kāda veida atslēgu vēlaties, cik ilgi atslēgai jābūt derīgai, ja nezināt, ko atbildēt, noklusējuma opcijām noklikšķiniet uz Enter (ieteicams ).
Protams, tas jums prasīs lietotājvārdu un paroli, paturiet to prātā, jo mums tie būs vajadzīgi vēlāk.
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
Tagad jūsu atslēga tiks ģenerēta, lai pārbaudītu, vai tā, palaidiet šo komandu kā root tiesības.
$ 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. darbība: izveidojiet pakotņu krātuvi un eksportēšanas atslēgu
Tagad mēs sāksim darbu, lai izveidotu repozitoriju. Vispirms jums ir jāizveido dažas mapes, mūsu repozitorijs atradīsies direktorijā /var/www/apt , tāpēc izveidosim dažas mapes.
$ sudo su # cd /var/www # mkdir apt # mkdir -p ./apt/incoming # mkdir -p ./apt/conf # mkdir -p ./apt/key
Tagad jums ir jāeksportē izveidotā atslēga uz krātuves mapi, palaidiet.
# gpg --armor --export username [email >> /var/www/apt/key/deb.gpg.key
Piezīme. Nomainiet lietotājvārdu ar lietotājvārdu, kuru ievadījāt iepriekšējā darbībā, un [e-pasts aizsargāts] ar savu e-pastu.
Mums jāizveido fails ar nosaukumu “ sadalījumi ”, kas atrodas /var/www/apt/conf iekšpusē.
# touch /var/www/apt/conf/distributions
Pievienojiet šīs nākamās rindas izplatīšanas failam un saglabājiet failu.
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
Tālāk mums būs jāizveido krātuves koks, lai to izdarītu, palaidiet šīs komandas.
# 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. darbība: pievienojiet paketes jaunizveidotajam krātuvei
Tagad sagatavojiet savas .deb paketes, kas jāpievieno repozitorijam. Atveriet direktoriju /var/www/apt , jums tas jādara katru reizi, kad vēlaties pievienot paketes.
# cd /var/www/apt # reprepro --ask-passphrase -Vb . includedeb Trusty /home/ravisaive/packages.deb
Piezīme. Aizstājiet uzticams ar koda nosaukumu, kuru ievadījāt krātuvei izplatīšanas failā, un aizstājiet /home/username/package.deb ar ceļu uz pakotni, jūs tiek prasīta paroles ievadīšana.
/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'
Jūsu pakotne tiek pievienota repozitorijam, lai to noņemtu.
# reprepro --ask-passphrase -Vb /var/www/apt remove trusty package.deb
Un, protams, jums ir jāmaina komanda ar pakotnes nosaukumu un krātuves koda nosaukumu.
4. darbība: augšupielādējiet krātuvi vietnē Sourceforge.net
Lai augšupielādētu krātuvi vietnē Sourceforge.net , jums, protams, ir jābūt darbojošam kontam un darbojošam projektam, pieņemsim, ka vēlaties augšupielādēt repozitoriju vietnē http:// sourceforge .net/projects/myfoo/testrepository kur myfoo ir jūsu projekta nosaukums (UNIX nosaukums, nevis URL, nevis nosaukums), un testrepository ir mape, kurā vēlaties augšupielādēt failus, mēs to izdarīsim, izmantojot rsync komandu.
# rsync -avP -e ssh /var/www/apt/ [email :/home/frs/project/myfoo/testrepository/
Piezīme: Nomainiet lietotājvārdu ar savu lietotājvārdu vietnēs sourceforge.net un myfoo ar projekta UNIX nosaukumu un testrepozitoriju ar mapi, kurā vēlaties saglabāt failus.
Tagad jūsu krātuve ir augšupielādēta vietnē http://sourceforge.net/projects/myfoo/testrepository , lai pievienotu to instalētajai sistēmai, vispirms jāimportē krātuves atslēga, tā būs < b> /var/www/apt/key/deb.gpg.key , bet tas ir lokāls ceļš, un jūsu krātuves lietotāji nevarēs to pievienot savām sistēmām, tāpēc mēs importējot atslēgu no sourceforge.net.
$ sudo su # wget -O - http://sourceforge.net/projects/myfoo/testrepository/apt/key/deb.gpg.key | apt-key add -
Tagad jūs varat viegli pievienot krātuvi savai sistēmai, atvērt /etc/apt/sources.list un pievienot šo rindu.
deb http://sourceforge.net/projects/myfoo/testrepository/apt/key/deb.gpg.key trusty main
Piezīme. Nomainiet myfoo ar sava projekta UNIX nosaukumu, uzticieties savam repozitorija koda nosaukumam, testrepozitorijs ar mapi, kurā augšupielādējāt failus, un galvenais ar krātuves komponentiem, kurus pievienojāt izplatīšanas failam.
Pēc tam palaidiet šo, lai atjauninātu krātuvju sarakstu.
$ sudo apt-get update
Apsveicam! Jūsu krātuve ir aktīva! Tagad, ja vēlaties, no tā varat viegli instalēt paketes.