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.