Backport da unstable in testing: differenze tra le versioni

Da Guide@Debianizzati.Org.
Vai alla navigazione Vai alla ricerca
mNessun oggetto della modifica
m (corretti pacchetti necessari, rimossa categoria "Aggiornamento" e correzioni minori)
 
(22 versioni intermedie di 7 utenti non mostrate)
Riga 1: Riga 1:
{{debianized}}
{{Versioni compatibili|ONLY|Testing_2016}}
== Introduzione ==
A causa delle numerose migrazioni gli utenti di [[testing]] possono trovarsi davanti a qualche problema relativo alla mancanza di pacchetti nel [[repository]] ufficiale Debian.


==Introduzione==
Ciò è dovuto alla politica di gestione di testing, la quale richiede che un [[pacchetto]] debba avere le seguenti caratteristiche, prima di entrare in testing:
Spesso, per vari motivi, � necessario installare Java su una macchina Debian...
* sia stato in [[unstable]] per almeno 10 giorni (nel caso di priorità bassa (''low''));
Sicuramente tutti gli utenti avranno notato che non c'�, nel repository ufficiale, un pacchetto contenente j2se o j2dk ufficiali della SUN.
* non abbia Bug gravi;
Sono, invece, presenti i compilatori alternativi, come gcj, kaffe, kjc, javacc....
* le dipendenze richieste siano completamente soddisfatte in testing.
Per�, se volessimo avere il compilatore e/o l'interprete 'originale' della SUN? come possiamo fare?


Il primo modo che salta agli occhi � di installarlo in /opt e poi sistemare il $PATH...ma la soluzione, giustamente, non piace a tutti, in quanto 'sporca' il sistema e, cosa che crea parecchi problemi, genera dei problemi con le dipendenze dei pacchetti, visto che molti dei pacchetti che richiedono java per funzionare non lo trovano installato.
In questo caso è possibile adattare i pacchetti di Sid per l'uso su [[testing]] (o anche su [[stable]] talvolta) eseguendo la procedura di '''[[backport]]''' illustrata in questa guida, anche se non sempre può essere applicata a causa di dipendenze non risolte: o perché non presenti in testing (in questo caso è necessario partire dal backporting delle librerie mancanti) o perché le versioni dei pacchetti in testing non sono abbastanza aggiornate per concludere con successo la compilazione (evento molto raro).


In questo HowTo vedremo come pacchettizzare Java, usando direttamente il binario di installazione disponibile sul sito della Sun!
Questa guida  è utilizzabile prevalentemente per il backport da ''unstable'' a ''testing'', mentre potrebbe dare problemi per il backport da ''testing'' a ''stable''.


==Cosa ci occorre==
== Preparazione ==
Provvediamo a scaricare i pacchetti java-package e fakeroot.
Per eseguire le operazioni illustrare in questa pagina sono necessari i seguenti pacchetti, normalmente utilizzati per lo sviluppo e l'installazione dei [[pacchetto|pacchetti Debian]]:
* build-essential
* dpkg-dev
* fakeroot
* gdebi-core
 
Per installarli, con [[privilegi di amministrazione]], è sufficiente il comando:
<pre>
<pre>
# apt-get install java-package fakeroot
# apt-get install build-essential dpkg-dev fakeroot gdebi-core
</pre>
</pre>


E poi scarichiamo il jdk o jre dal sito ufficiale Sun:<br(>
== Scaricare i sorgenti ==
1.5: http://java.sun.com/j2se/1.5.0/download.jsp<br/>
=== Con APT ===
1.4: http://java.sun.com/j2se/1.4.2/download.html
Se i [[repository]] dei sorgenti sono abilitati (ossia se sono presenti e non commentate nel proprio <code>/etc/apt/sources.list</code> la riga iniziante con '''<code>deb-src</code>''' relativa a Debian [[Sid]]), è sufficiente utilizzare [[APT]].


Una volta terminato il download, saremo pronti per proseguire.
==== Aggiungere i repository sorgenti di Sid ====
Se si sono già abilitati i repository sorgenti di Debian [[Sid]] si può saltare questa sezione e passare alla [[#Scaricare il pacchetto sorgente|successiva]]. In caso contrario, se non fossero abilitati, basterebbe eseguire con [[privilegi di amministrazione]]:
<pre>
# apt edit-sources
</pre>
per aggiungere ai repository correnti quello con i sorgenti di Sid con il proprio editor preferito, scrivendo la seguente riga (in questo esempio con [[mirror]] italiano, ma è possibile usarne uno qualsiasi; e con solo la sezione [[main]]):
<pre>
deb-src http://ftp.it.debian.org/debian sid main
</pre>
(scegliendo l'editor [[nano]], premere <code>Ctrl-o</code> per salvare e <code>Ctrl-x</code> per uscire)


==Creazione del Pacchetto==
Infine va aggiornata la lista dei pacchetti:
 
Bene, siamo pronti a creare il pacchetto!!!
Posizioniamoci nella directory dove sono stati scaricati i binari di java e, da utente normale, diamo il seguente comando:
<pre>
<pre>
$ fakeroot make-jpkg jdk-1_5_0_01-linux-i586.bin
# apt update
</pre>
</pre>
(o il nome del pacchetto scaricato...in questo caso ho pacchettizzato il jdk 1.5.0)
al comando '''make-jpkg''' possibile passare i seguenti parametri:<br/>
; --full-name <name> : Nome del Maintainer<br/>
; --email <email> : Email del Maintainer<br/>
; --changes : Indica che il processo deve creare un file .changes<br/>
; --help : Visualizza un piccolo help contenente i comandi qui illustrati<br/>
; --version : Stampa a video la versione


Una volta terminato il processo di generazione del pacchetto, provvediamo a fare quanto segue:
Se si utilizzano soltanto i repository dei sorgenti, non sarà nemmeno necessario configurare il [[pinning]]. In caso contrario, se si sono aggiunti i repository di Sid, è '''necessario''' impostare almeno una ''default release'' (per maggiori informazioni si rimanda a [[Repository_%26_pinning#Testing_con_unstable_ed_experimental | questa sezione della guida sul pinning]]).
 
==== Scaricare il pacchetto sorgente ====
Per scaricare il sorgente di un pacchetto (per esempio ''nomepacchetto'') basta:
<pre>
<pre>
$ su
$ apt-get source nomepacchetto
# dpkg -i sun-j2sdk1.5_1.5.0+update01_i386.deb
</pre>
</pre>


Ovviamente sostituendo 'sun-j2sdk1.5_1.5.0+update01_i386.deb' con il nome del pacchetto appena creato!
Saranno scaricati gli archivi con i sorgenti originali (<code>''.orig.tar.gz''</code>) e le patch (<code>''.patch.gz''</code>), che saranno estratti in una directory con lo stesso nome, e un file contenente la descrizione  del pacchetto (<code>''.dsc''</code>).
Se ci sono problemi, relativamente ad una dipendenza con un nome simile a 'sun-j2sdk1.5debian', � possibile sistemare tutto con il comando
 
=== Manualmente ===
Se non si sono abilitati i sorgenti dei repository di [[Sid]], è possibile anche scaricarli manualmente, senza avvalersi di [[APT]]. Innanzitutto è necessario conoscere lo stato di un pacchetto (per l'esattezza di un pacchetto di sorgenti) tramite il sito della [http://qa.debian.org Quality Assurance]; si procede nel seguente modo:
* ottenere il pacchetto sorgente da cui viene creato il pacchetto binario in questione, eseguendo: <pre>$ apt-cache show nomepacchetto | grep Source</pre>
* recarsi su [https://tracker.debian.org Debian Package Tracker] ed inserire il nome del pacchetto sorgente;
* leggere lo stato del pacchetto.
 
{{Box|Nota:|è possibile automatizzare la procedura inserendo, nella pagina [https://tracker.debian.org https://tracker.debian.org], il nome del pacchetto binario: il sistema mostrerà il nome del pacchetto di sorgenti relativo ed in 10 secondi reindirizzerà alla pagina relativa al suo stato.}}
 
Alla pagina relativa allo stato del pacchetto è possibile scaricare i sorgenti necessari per questo backport (nel riquadro '''Source files'''). I file sono, per l'esattezza, 3:
* l'archivio contenente i sorgenti originali, <code>'''.orig.tar.gz'''</code>;
* l'archivio contenente le patch per creare il pacchetto, <code>'''.patch.gz'''</code>;
* il file contenente la descrizione del pacchetto, <code>'''.dsc'''</code> .
 
Una volta scaricati in una unica directory è necessario estrarli:
<pre>
<pre>
# apt-get install sun-j2sdk1.5debian
$ dpkg-source -x nomepacchetto.....dsc
</pre>
</pre>


Ora non ci resta che sistemare una ultima cosa: '''alternatives'''
== Installare le dipendenze per la compilazione ==
(se precedentemente era stato installato un pacchetto non ufficiale di java)
Prima di procedere alla compilazione bisogna installare i pacchetti <code>-dev</code> necessari per la compilazione.
Date il comando
Anche in questo caso, come sempre del resto, il sistema di gestione dei pacchetti Debian ci viene in aiuto: con [[privilegi di amministrazione]] basta infatti un semplice:
<pre>
<pre>
# update-alternatives --config java
# apt-get build-dep nomepacchetto
</pre>
</pre>
(uguale procedimento anche per javac, javadoc ed eventualmente altri eseguibili java)
per installare le dipendenze necessarie alla compilazione.
e selezionate 'quale java' utilizzare!


==Conclusioni==
{{Box|Nota:|il comando potrebbe non risolvere tutte le dipendenze (nel peggiore dei casi potrebbe non trovare informazioni riguardo a queste). In questo caso, quindi, bisognerà installarle a mano. Le dipendenze mancanti verranno mostrate nell'output di <code>dpkg-buildpackage</code> e dovranno essere installate come viene installato normalmente un pacchetto. Non sarà possibile continuare nel processo di compilazione se non si soddisfano tutte le dipendenze di compilazione.}}


Con questi pochi e semplici passaggi, abbiamo installato java senza sporcare il sistema, e risolvendo il problema delle dipendenze!
== Creare i pacchetti deb ==
Una volta installate le dipendenze si può procedere con la compilazione e la creazione dei pacchetti deb:
* bisogna entrare nella directory dei sorgenti creata durante l'estrazione dei sorgenti;
* per far partire la compilazione si può usare il seguente comando:<pre>$ fakeroot dpkg-buildpackage</pre>


Buon Java a tutti!!!
== Installare i pacchetti ==
Se tutto procede senza problemi verranno creati, nella directory precedente, i pacchetti binari frutto della compilazione. Per installarli sarebbe sufficiente utilizzare [[dpkg]], ma è consigliabile utilizzare [[gdebi]], in modo da risolvere prima in automatico le dipendenze dei pacchetti tramite APT, ed essere informati di possibili conflitti prima di alterare il sistema. Con [[privilegi di amministrazione]] basta:
<pre>
# gdebi nomepacchetto.....deb
</pre>


== Riferimenti ==
* [https://www.debian.org/doc/manuals/debian-reference/ch02.it.html#_porting_a_package_to_the_stable_system Debian Reference - port di un pacchetto]
* [http://qa.debian.org Debian Quality Assurance]
* [https://tracker.debian.org Debian Package Tracker]


---- [[User:MaXeR|MaXeR]]
{{Autori
|Autore = [[Utente:MaXeR|MaXeR]]
|Estesa_da =
|Verificata_da =
: [[Utente:HAL 9000|HAL 9000]] 10:43, 23 apr 2016 (CEST)
|Numero_revisori = 1
}}


[[Categoria:Creare e modificare pacchetti]]
[[Categoria:Apt]]
[[Categoria:Apt]]
[[Categoria:Apt-Dev]]

Versione attuale delle 08:43, 23 apr 2016

Debian-swirl.png Versioni Compatibili

soltanto:
Debian testing (anno: 2016)

Introduzione

A causa delle numerose migrazioni gli utenti di testing possono trovarsi davanti a qualche problema relativo alla mancanza di pacchetti nel repository ufficiale Debian.

Ciò è dovuto alla politica di gestione di testing, la quale richiede che un pacchetto debba avere le seguenti caratteristiche, prima di entrare in testing:

  • sia stato in unstable per almeno 10 giorni (nel caso di priorità bassa (low));
  • non abbia Bug gravi;
  • le dipendenze richieste siano completamente soddisfatte in testing.

In questo caso è possibile adattare i pacchetti di Sid per l'uso su testing (o anche su stable talvolta) eseguendo la procedura di backport illustrata in questa guida, anche se non sempre può essere applicata a causa di dipendenze non risolte: o perché non presenti in testing (in questo caso è necessario partire dal backporting delle librerie mancanti) o perché le versioni dei pacchetti in testing non sono abbastanza aggiornate per concludere con successo la compilazione (evento molto raro).

Questa guida è utilizzabile prevalentemente per il backport da unstable a testing, mentre potrebbe dare problemi per il backport da testing a stable.

Preparazione

Per eseguire le operazioni illustrare in questa pagina sono necessari i seguenti pacchetti, normalmente utilizzati per lo sviluppo e l'installazione dei pacchetti Debian:

  • build-essential
  • dpkg-dev
  • fakeroot
  • gdebi-core

Per installarli, con privilegi di amministrazione, è sufficiente il comando:

# apt-get install build-essential dpkg-dev fakeroot gdebi-core

Scaricare i sorgenti

Con APT

Se i repository dei sorgenti sono abilitati (ossia se sono presenti e non commentate nel proprio /etc/apt/sources.list la riga iniziante con deb-src relativa a Debian Sid), è sufficiente utilizzare APT.

Aggiungere i repository sorgenti di Sid

Se si sono già abilitati i repository sorgenti di Debian Sid si può saltare questa sezione e passare alla successiva. In caso contrario, se non fossero abilitati, basterebbe eseguire con privilegi di amministrazione:

# apt edit-sources

per aggiungere ai repository correnti quello con i sorgenti di Sid con il proprio editor preferito, scrivendo la seguente riga (in questo esempio con mirror italiano, ma è possibile usarne uno qualsiasi; e con solo la sezione main):

deb-src http://ftp.it.debian.org/debian sid main

(scegliendo l'editor nano, premere Ctrl-o per salvare e Ctrl-x per uscire)

Infine va aggiornata la lista dei pacchetti:

# apt update

Se si utilizzano soltanto i repository dei sorgenti, non sarà nemmeno necessario configurare il pinning. In caso contrario, se si sono aggiunti i repository di Sid, è necessario impostare almeno una default release (per maggiori informazioni si rimanda a questa sezione della guida sul pinning).

Scaricare il pacchetto sorgente

Per scaricare il sorgente di un pacchetto (per esempio nomepacchetto) basta:

$ apt-get source nomepacchetto

Saranno scaricati gli archivi con i sorgenti originali (.orig.tar.gz) e le patch (.patch.gz), che saranno estratti in una directory con lo stesso nome, e un file contenente la descrizione del pacchetto (.dsc).

Manualmente

Se non si sono abilitati i sorgenti dei repository di Sid, è possibile anche scaricarli manualmente, senza avvalersi di APT. Innanzitutto è necessario conoscere lo stato di un pacchetto (per l'esattezza di un pacchetto di sorgenti) tramite il sito della Quality Assurance; si procede nel seguente modo:

  • ottenere il pacchetto sorgente da cui viene creato il pacchetto binario in questione, eseguendo:
    $ apt-cache show nomepacchetto | grep Source
  • recarsi su Debian Package Tracker ed inserire il nome del pacchetto sorgente;
  • leggere lo stato del pacchetto.
Info.png Nota:
è possibile automatizzare la procedura inserendo, nella pagina https://tracker.debian.org, il nome del pacchetto binario: il sistema mostrerà il nome del pacchetto di sorgenti relativo ed in 10 secondi reindirizzerà alla pagina relativa al suo stato.


Alla pagina relativa allo stato del pacchetto è possibile scaricare i sorgenti necessari per questo backport (nel riquadro Source files). I file sono, per l'esattezza, 3:

  • l'archivio contenente i sorgenti originali, .orig.tar.gz;
  • l'archivio contenente le patch per creare il pacchetto, .patch.gz;
  • il file contenente la descrizione del pacchetto, .dsc .

Una volta scaricati in una unica directory è necessario estrarli:

$ dpkg-source -x nomepacchetto.....dsc

Installare le dipendenze per la compilazione

Prima di procedere alla compilazione bisogna installare i pacchetti -dev necessari per la compilazione. Anche in questo caso, come sempre del resto, il sistema di gestione dei pacchetti Debian ci viene in aiuto: con privilegi di amministrazione basta infatti un semplice:

# apt-get build-dep nomepacchetto

per installare le dipendenze necessarie alla compilazione.

Info.png Nota:
il comando potrebbe non risolvere tutte le dipendenze (nel peggiore dei casi potrebbe non trovare informazioni riguardo a queste). In questo caso, quindi, bisognerà installarle a mano. Le dipendenze mancanti verranno mostrate nell'output di dpkg-buildpackage e dovranno essere installate come viene installato normalmente un pacchetto. Non sarà possibile continuare nel processo di compilazione se non si soddisfano tutte le dipendenze di compilazione.


Creare i pacchetti deb

Una volta installate le dipendenze si può procedere con la compilazione e la creazione dei pacchetti deb:

  • bisogna entrare nella directory dei sorgenti creata durante l'estrazione dei sorgenti;
  • per far partire la compilazione si può usare il seguente comando:
    $ fakeroot dpkg-buildpackage

Installare i pacchetti

Se tutto procede senza problemi verranno creati, nella directory precedente, i pacchetti binari frutto della compilazione. Per installarli sarebbe sufficiente utilizzare dpkg, ma è consigliabile utilizzare gdebi, in modo da risolvere prima in automatico le dipendenze dei pacchetti tramite APT, ed essere informati di possibili conflitti prima di alterare il sistema. Con privilegi di amministrazione basta:

# gdebi nomepacchetto.....deb

Riferimenti




Guida scritta da: MaXeR Swirl-auth40.png Debianized 40%
Estesa da:
Verificata da:
HAL 9000 10:43, 23 apr 2016 (CEST)

Verificare ed estendere la guida | Cos'è una guida Debianized