Difference between revisions of "Pacman/Tips and tricks (Español)"

From ArchWiki
Jump to: navigation, search
(Coloreando la salida de pacman)
m (use translateme instead)
 
(17 intermediate revisions by 5 users not shown)
Line 1: Line 1:
 +
{{Lowercase title}}
 
[[Category:Package management (Español)]]
 
[[Category:Package management (Español)]]
[[en:Pacman Tips]]
+
[[en:Pacman/Tips and tricks]]
[[it:Pacman Tips]]
+
[[fa:Pacman tips]]
[[ru:Pacman Tips]]
+
[[fr:Astuces Pacman]]
[[tr:Pacman_ipuçları]]
+
[[it:Pacman/Tips and tricks]]
[[zh-CN:Pacman Tips]]
+
[[ja:Pacman ヒント]]
{{Bad translation|Outdated and does not follow style guidelines, contrast [[Pacman_Tips#Restore_pacman.27s_local_database]]}}
+
[[ru:Pacman/Tips and tricks]]
==Cómo restaurar la base de datos local de Pacman==
+
[[tr:Pacman ipuçları]]
 +
[[zh-hans:Pacman/Tips and tricks]]
 +
{{Related articles start}}
 +
{{Related|pacman}}
 +
{{Related|Improve pacman performance}}
 +
{{Related|Mirrors}}
 +
{{Related|Creating packages}}
 +
{{Related articles end}}
 +
{{Translateme (Español)|Outdated and does not follow style guidelines, contrast [[Pacman tips#Restore pacman's local database]] }}
 +
Para métodos generales para mejorar la flexibilidad de las sugerencias proporcionadas o del propio pacman, consulte [[Core utilities]] y [[Bash]].
  
===Introducción===
+
== Mantenimiento ==
  
Algo ha ido mal con pacman. 'Pacman -Q' no da resultados en absoluto, y 'pacman -Syu' le dice que sus sistema está actualizado, pero usted sabe que no es así. Cuando intenta instalar un paquete usando 'pacman -S package', se le presenta una lista de dependencias, aunque usted sepa positivamente que ya están todas ellas instaladas.
+
=== Listando paquetes ===
  
Su problema es que la base de datos de software instalado de pacman, '/var/lib/pacman/local' se ha corrompido o borrado. Este es un problema serio, pero afortunadamente puede restaurar '/var/lib/pacman/local' siguiendo las instrucciones que se indican a continuación.
+
Es posible que desee obtener la lista de paquetes instalados con su versión, lo cual es útil cuando se reportan errores o se discuten los paquetes instalados.
 +
* Enumere todos los paquetes explícitamente instalados: pacman -Qe .
 +
*todos los paquetes nativos instalados explícitamente (es decir, presentes en la base de datos de sincronización) que no sean dependencias directas o opcionales: pacman -Qent .
 +
* Lista de todos los paquetes extranjeros (normalmente descargados e instalados manualmente): pacman -Qm .
 +
* Haga una lista de todos los paquetes nativos (instalados desde la (s) base de datos de sincronización): pacman -Qn .  
 +
* Listar paquetes por regex: pacman -Qs regex .
 +
* Lista de paquetes por regex con formato de salida personalizado: expac -s "%-30n %v" regex (necesita expac ).
  
====Ausencia de responsabilidad====
+
==== Con el tamaño ====
 +
Para obtener una lista de paquetes instalados ordenados por tamaño, lo que puede ser útil al liberar espacio en el disco duro:
 +
* Instalar expac y ejecutar expac -HM '%m\t%n' | sort -h expac -HM '%m\t%n' | sort -h .
 +
* Ejecute pacgraph con la opción -c .
 +
Para enumerar el tamaño de descarga de varios paquetes (deje packages en blanco para listar todos los paquetes):
 +
  $ Expac -S -HM '% k \ t% n' paquetes
 +
Para listar los paquetes explícitamente instalados que no están en base ni en base-devel con tamaño y descripción:
 +
  $ Expac -HM "% 011m \ t% -20n \ t% 10d" $ (comm -23 <(pacman -Qqen | sort) <(pacman -Qqg base-devel | sort)) |  Ordenar -n
  
Antes de comenzar, quiero recalcar que aunque estas instrucciones me funcionaron a mí, puede que no funcionen para usted. De hecho, sus sistema podría no volver a ser el mismo nunca más.
+
==== Por fecha ====
 +
Para enumerar los 20 últimos paquetes instalados con expac , ejecute:
 +
  $ Expac --timefmt = '% Y-% m-% d% T' '% l \ t% n' |  Ordenar |  Cola-n 20
 +
O, con segundos desde la época (1970-01-01 UTC):
 +
  $ Expac --timefmt =% s '% l \ t% n' |  Sort -n |  Cola-n 20
  
PROCEDA ASUMIENDO EL RIESGO!
+
Lista los paquetes explícitamente instalados que no están en los grupos de base o base-devel :
 +
  $ Comm -23 <(pacman -Qeq | sort) <(pacman -Qgq base base-devel | sort)
 +
Enumere todos los paquetes instalados no requeridos por otros paquetes y que no estén en los grupos de base o de base :
 +
  $ Comm -23 <(pacman -Qqt | sort) <(pacman -Sqg base base-devel | sort)
 +
Como arriba, pero con descripciones:
 +
  $ Expac -HM '% -20n \ t% 10d' $ (comm -23 <(pacman -Qqt | sort) <(pacman -Qqg base -devel | sort)
 +
Lista todos los paquetes instalados que no están en el repositorio especificado repo_name
 +
  $ Comm -23 <(pacman -Qtq | sort) <(pacman -Slq repo_name | sort)
 +
Liste todos los paquetes instalados que están en el repositorio repo_name :
 +
  $ Comm -12 <(pacman -Qtq | sort) <(pacman -Slq repo_name | sort)
  
====Línea de órdenes====
+
== Optimización ==
  
La línea a continuación indica una orden tecleada por el usuario 'me' en un terminal, esto es, cualquier usuario excepto root.
+
=== Velocidades de acceso a la base de datos ===
 
 
[me@linuxbox]$ ls
 
 
 
La línea a continuación indica una orden tecleada en un terminal por el usuario 'root', esto es, el usuario con todos los derechos en su sistema.
 
 
 
[root@linuxbox]# ls
 
 
 
La mayoría de las instrucciones descritas a continuación suponen que tiene usted acceso como root a su sistema.
 
 
 
===Instrucciones===
 
 
 
*En primer lugar, tiene que asegurarse de que tiene el archivo de anotaciones de pacman.
 
 
 
[me@linuxbox]$ ls /var/log/pacman.log
 
/var/log/pacman.log
 
 
 
Si no existe su archivo de anotaciones de pacman, NO debe continuar. La única opción que tiene es reinstalar su sistema desde cero.
 
 
 
De acuerdo, su archivo '/var/log/pacman.log' existe. ¿Va a continuar?
 
 
 
*cree el archivo 'pkglist.sh'.
 
 
 
[root@linuxbox]# touch pkglist.sh
 
 
*Copie y pegue las líneas siguientes en su archivo 'pkglist.sh'.
 
 
 
#!/bin/bash
 
#
 
SEDEXP='s/^\[[^ ]* *[0-9][0-9]:[0-9][0-9]\] \([^ ]*\) *\([^ ]*\) .*/\1 \2/'
 
GRPEXP='(upgraded)|(installed)'
 
AWKEXP='{print $2}'
 
#
 
sed -e "$SEDEXP" /var/log/pacman.log | grep -E "$GRPEXP" | awk "$AWKEXP" | sort -u
 
# End
 
 
 
Gracias a 'rdt' https://bbs.archlinux.org/viewtopic.php?id=38531
 
 
 
grabe y salga.
 
 
 
*Haga al archivo 'pkglist.sh' ejecutable.
 
 
 
[root@linuxbox]# chmod 744 pkglist.sh
 
 
*Ahora ejecute 'pklglist.sh' y redireccione la salida a 'pkglist'.
 
 
 
[root@linuxbox]# ./pkglist.sh > pkglist
 
 
*'pkglist' conendrá ahora una lista de todo el software que instaló o actualizó. Edite 'pkglist' y elimine todo lo que no quiera reinstalar. Usted podría querer hacer esto si por ejemplo constryó un paquete personalizado y lo instaló con 'abs'.
 
 
 
[root@linuxbox]# vi pkglist
 
 
*Una vez esté satisfecho con el contenido de 'pkglist', puede utilizarlo para reinstalar su software, y restaurar '/var/lib/pacman/local'.
 
 
 
No hay ninguna necesidad de comprobar las dependencias, y tiene que 'forzar' la instalación dado que los programas ya existen.
 
 
 
[root@linuxbox]# pacman -Sdf `cat pkglist`
 
 
Pacman le presentará ahora una larga lista de software que va a ser instalado. Diga 'yes' y espere a que termine pacman.
 
 
 
* Finalmente, necesitará descubrir todos los archivos de configuración que han cambiado. Puede hacer esto actualizando primero la base de datos 'locate'.
 
 
 
[root@linuxbox]# updatedb
 
 
 
* Ahora puede buscar todos los archivos de configuración que hayan cambiado.
 
 
 
[root@linuxbox]# locate pacorig
 
 
 
Esto le dará una lista de todos los archivos de configuración que han sido reemplazados. Su archivo original tendrá la extensión '.pacorig'. Borre los nuevos archivos, y renombre los archivos '.pacorig' para restaurar su configuración inicial para cada paquete de software que pueda estar afectado. Pueden haber cambido también algunos permisos de directorio. Compruebe esto si algo se niega a arrancar.
 
 
 
Felicidades, acaba de restaurar con éxito su base de datos local de pacman.
 
 
 
{{Merge|Pacman Tips (Español)}}
 
== Coloreando la salida de pacman ==
 
Ahora que makepkg tiene una salida colorizada, ¿por qué no pacman también? El administrador de paquetes en [http://www.gentoo.org/ Gentoo] llamado 'portage' usa colores ampliamente, y como pueden ver en esta [http://gentoo-portage.com/up_img/1026.png screenshot], se mejora enormemente la legibilidad.
 
 
 
==== Scripts ====
 
El usuario citral usa el siguiente script en su .bashrc:
 
 
 
alias pacs="pacsearch"
 
pacsearch () {
 
        echo -e "$(pacman -Ss $@ | sed \
 
        -e 's#core/.*#\\033[1;31m&\\033[0;37m#g' \
 
        -e 's#extra/.*#\\033[0;32m&\\033[0;37m#g' \
 
        -e 's#community/.*#\\033[1;35m&\\033[0;37m#g' \
 
        -e 's#^.*/.* [0-9].*#\\033[0;36m&\\033[0;37m#g' )"
 
}
 
 
 
Que es la solución más limpia. Sin embargo, si deseas un script para todo el sistema, ejecuta '''como root''':
 
  touch /usr/bin/pacs && chmod 755 /usr/bin/pacs
 
 
 
y copia esto dentro de /usr/bin/pacs también como root:
 
  #!/bin/bash
 
  echo -e "$(pacman -Ss $@ | sed \
 
  -e 's#core/.*#\\033[1;31m&\\033[0;37m#g' \
 
  -e 's#extra/.*#\\033[0;32m&\\033[0;37m#g' \
 
  -e 's#community/.*#\\033[1;35m&\\033[0;37m#g' \
 
  -e 's#^.*/.* [0-9].*#\\033[0;36m&\\033[0;37m#g' )"
 
 
 
Puedes sustituir "pacs" en esas lineas por lo que quieras. Puedes crear tambien un alias de "pacs" por otra cosa en tu .bashrc, como se hizo antes..
 
 
 
El uso de estos comandos es muy sencillo; solo usa tu nuevo comando en vez de 'pacman', el resto sigue siendo lo mismo!
 
 
 
==== Alternativas ====
 
 
 
Una alternativa es usar este script en python, que emula la salida de pacman -Ss (¡con colores!) pero obtiene la lista de paquetes eso si desde el sitio web. Busca los repositorios oficiales y AUR (las dos community y unsupported).
 
 
 
#!/usr/bin/python
 
 
import os
 
import re
 
import sys
 
import urllib2
 
 
OFFICIAL_QUERY = "https://archlinux.org/packages/search/\?q="
 
AUR_QUERY = "https://aur.archlinux.org/packages.php?K="
 
 
# Repos and colors
 
repos = {"Core":'32',"Extra":'36',"Testing":'31',"community":'33',"unsupported":'35'}
 
 
def strip_html(buffer):
 
    <nowiki>buffer = re.sub('<[^>]*>','',buffer)</nowiki>
 
    <nowiki>buffer = re.sub('(?m)^[ \t]*','',buffer)</nowiki>
 
    return buffer
 
 
def cut_html(beg,end,buffer):
 
    <nowiki>buffer = re.sub('(?s).*' + beg,'',buffer)</nowiki>
 
    <nowiki>buffer = re.sub('(?s)' + end + '.*','',buffer)</nowiki>
 
    return buffer
 
 
class RepoSearch:
 
    def __init__(self,keyword):
 
        self.keyword = keyword
 
        <nowiki>self.results = ''</nowiki>
 
        for name in ['official','aur']:
 
            self.get_search_results(name)
 
            self.parse_results(name)
 
        self.colorize()
 
 
    def get_search_results(self,name):
 
        if name == "official":
 
            query = OFFICIAL_QUERY
 
        elif name == "aur":
 
            query = AUR_QUERY
 
 
        f = urllib2.urlopen( query + self.keyword )
 
        self.search_results = f.read()
 
        f.close()
 
 
    def preformat(self,header,a,b):
 
        <nowiki>self.buffer = cut_html('<table class=\"' + header + '\"[^>]*>','</table',self.search_results)</nowiki>
 
        self.buffer = strip_html(self.buffer)
 
        self.buffer = self.buffer.split('\n')
 
        self.buffer = [line for line in self.buffer if line]
 
        del self.buffer[a:b]
 
 
    def parse_results(self,name):
 
        <nowiki>self.buffer = ''</nowiki>
 
        if name == 'official':
 
            <nowiki>if re.search('<table class=\"results\"',self.search_results):</nowiki>
 
                self.preformat('results',0,6)
 
            <nowiki>elif re.search('<div class=\"box\">',self.search_results):</nowiki>
 
                <nowiki>temp = re.search('<h2 class=\"title\">([^<]*)</h2>',self.search_results)</nowiki>
 
                temp = temp.group(1)
 
                temp = temp.split()
 
                self.preformat('listing',7,-1)
 
                for i in range(0,3): del self.buffer[i]
 
                for i in temp: self.buffer.insert(temp.index(i) + 2,i)
 
 
        elif name == 'aur':
 
            <nowiki>p = re.compile('<td class=.data[^>]*>')</nowiki>
 
            self.buffer = self.search_results.split('\n')
 
            self.buffer = [strip_html(line) for line in self.buffer if p.search(line)]
 
 
        l = len(self.buffer)/6
 
        <nowiki>parsed_buf = ''</nowiki>
 
 
        for i in range(l):
 
            parsed_buf += self.buffer[i*6] + '/'
 
            parsed_buf += self.buffer[i*6+1] + ' '*(24-len(self.buffer[i*6] + self.buffer[i*6+1]))
 
            parsed_buf += self.buffer[i*6+2]
 
            if name == "official":
 
                parsed_buf += ' ' + self.buffer[i*6+3]
 
            parsed_buf += '\n' + self.buffer[i*6+4] + '\n'
 
 
        self.results += parsed_buf
 
 
    def colorize(self):
 
        for repo,repo_color in repos.iteritems():
 
            <nowiki>self.results = re.sub(repo + '/.*','\\033[1;' + repo_color + 'm' + '\g<0>' + '\\033[0;0m',self.results)</nowiki>
 
 
   
 
   
if __name__ == "__main__":
+
Pacman almacena toda la información del paquete en una colección de archivos pequeños, uno para cada paquete. La mejora de las velocidades de acceso a la base de datos reduce el tiempo empleado en las tareas relacionadas con la base de datos, por ejemplo, buscar paquetes y resolver las dependencias del paquete. El método más seguro y fácil es ejecutarlo como root:  
    if len(sys.argv) < 2:
+
  # Pacman-optimize
        print "Usage: " + sys.argv[0] + " <keyword>"
+
Esto intentará poner todos los archivos pequeños juntos en una ubicación (física) en el disco duro para que la cabeza del disco duro no tenga que moverse tanto al acceder a todos los datos. Este método es seguro, pero no es infalible: depende del sistema de archivos, el uso del disco y la fragmentación del espacio vacío. Otra opción más agresiva sería eliminar primero los paquetes desinstalados del caché y eliminar los repositorios no utilizados antes de la optimización de la base de datos:
        sys.exit(2)
+
  # Pacman -Sc && pacman-optimize
    reposearch = RepoSearch(sys.argv[1])
+
=== Velocidades de descarga ===
    sys.stdout.write(reposearch.results)
+
Nota: Si las velocidades de descarga se han reducido a un rastreo, asegúrese de que está utilizando uno de los muchos espejos y no ftp.archlinux.org, que se estrangula desde marzo de 2007 .  
 
+
Al descargar paquetes pacman usa los espejos en el orden en que están en /etc/pacman.d/mirrorlist . El espejo que está en la parte superior de la lista por defecto, sin embargo, puede no ser el más rápido para usted. Para seleccionar un espejo más rápido, consulte Espejos .  
==== Usando 'acoc' ====
+
La velocidad de Pacman en la descarga de paquetes también puede ser mejorada mediante el uso de una aplicación diferente para descargar paquetes, en lugar del descargador de archivos integrado de Pacman.  
Hay otra, una posibilidad más general de colorear arbitrariamente la salida de los comandos.
+
En todos los casos, asegúrese de tener la última Pacman antes de hacer cualquier modificación.  
Puedes descargar la pequeña herramienta en [http://www.ruby-lang.org/en/ Ruby], llamada [http://raa.ruby-lang.org/project/acoc/ acoc] (y sus dependencias, [http://raa.ruby-lang.org/project/ansicolor/ term-ansicolor] y [http://raa.ruby-lang.org/cache/ruby-tpty/ tpty]. ).
+
  # Pacman -Syu
tpty no es realmente requerida, pero algunas aplicaciones como "ls" no funcionan con acoc (necesitan ser iniciadas en la terminal (o pseudo terminal, en este caso), o bien se comportarán diferente).
+
=== Powerpill ===
 
+
Powerpill es un envoltorio de Pacman que utiliza la descarga paralela y segmentada para tratar de acelerar las descargas de Pacman.  
La instalación es relativamente fácil, aquí hay un paseo rápido:
+
=== Wget ===
 
+
Esto también es muy útil si necesita configuraciones proxy más potentes que las capacidades incorporadas de pacman.
$ tar xvzf tpty-0.0.1.tar.gz
 
$ cd tpty-0.0.1
 
$ ruby extconf.rb
 
$ make
 
$ ruby ./test.rb
 
# make install
 
 
 
$ tar xvzf term-ansicolor-1.0.1.tar.gz
 
$ cd term-ansicolor-1.0.1
 
# ruby install.rb
 
 
 
Y ahora acoc en si:
 
  
$ tar xvzf acoc-0.7.1.tar.gz
+
Para usar wget , primero instale el paquete wget y luego modifique /etc/pacman.conf descomentando la siguiente línea en la sección [options] :
$ cd acoc-0.7.1
+
  XferCommand = / usr / bin / wget -c -q --show-progress --passive-ftp -O% o% u
# make install
+
En lugar de descomentar los parámetros de wget en /etc/pacman.conf , también puede modificar el archivo de configuración de wget directamente (el archivo de todo el sistema es /etc/wgetrc , por usuario los archivos son $HOME/.wgetrc .
  
Ahora, solo lee la sección "Advanced Installation" en el archivo INSTALL de acoc, y configura acoc como se te plazca.
+
=== Aria2  ===
Crea un enlace para 'pacman' también, ya que es principalmente para eso que lo estamos haciendo.
+
Aria2 es una utilidad de descarga de peso ligero con soporte para HTTP / HTTPS y transferencias directas continuas y segmentadas. Aria2 permite múltiples y simultáneas conexiones HTTP / HTTPS y FTP a un espejo de Arch, lo que debería resultar en un aumento en las velocidades de descarga para la recuperación de archivos y paquetes.  
Una vez ejecutes acoc, puedes añadir estas lineas a tu acoc.conf:
 
  
[pacman -Si]
+
Nota: El uso de aria2c en XferCommand de Pacman no dará lugar a descargas paralelas de varios paquetes. Pacman invoca el XferCommand con un solo paquete a la vez y espera a que se complete antes de invocar el siguiente. Para descargar varios paquetes en paralelo, consulte Powerpill.  
/^Name\s+:\s([\w.-]+)/                              bold
 
[pacman -Qi]
 
/^Name\s+:\s([\w.-]+)/                              bold
 
[pacman -Qi$]
 
/^([\w.-]+)\s([\w.-]+)/                bold,clear
 
[pacman -Ss]
 
/^([\w.-]+)\/([\w.-]+)\s+([\w.-]+)/    clear,bold,clear
 
[pacman -Qs]
 
/^([\w.-]+)\/([\w.-]+)\s+([\w.-]+)/    clear,bold,clear
 
[pacman -Sl]
 
/^([\w.-]+)\s([\w.-]+)\s([\w.-]+)/              clear,bold,clear
 
[pacman -Qo]
 
/^([\w.-\/]+)\sis\sowned\sby\s([\w.-]+)\s([\w.-]+)/    clear,bold,clear
 
[pacman -Qe$]
 
/^([\w.-]+)\s([\w.-]+)/                bold,clear
 
[pacman -Qg$]
 
/^([\w.-]+)\s([\w.-]+)/                clear,bold
 
  
Puede no ser perfecto, o particulármente bonito, pero por lo menos funciona bien para mí.
+
Instale aria2 y luego edite /etc/pacman.conf agregando la siguiente línea a la sección [options] :
Las lineas de arriba solo hacen que pacman imprima todos los nombres de los paquetes en negrita, que es particularmente útil en p.ej. "pacman -Ss xfce". Si lo que quieres son más colores, puedes modificar las lineas a tu gusto.
+
  XferCommand = / usr / bin / aria2c --allow-overwrite = true --continue = true --file-allocation = ninguno --log-level = error --max-tries = 2 --max-connection-per-server = 2 --max-file-not-found = 5 --min-split-size = 5M --no-conf --remote-time = true --summary-interval = 60 --timeout = 5 --dir = / --out% o% u
Lee la documentación de acoc contenida en la paquete con las fuentes del programa para más información.
 
  
==== Links ====
+
Sugerencia: Esta configuración alternativa para usar pacman con aria2 intenta simplificar la configuración y añade más opciones de configuración.  
[https://bbs.archlinux.org/viewtopic.php?t=12430&postdays=0&postorder=asc&start=15 Forum thread]
 
  
==== Alternativa ====
+
Vea OPCIONES en man aria2c para las opciones de aria2c usadas.
En AUR está disponible un [https://aur.archlinux.org/packages.php?do_Details=1&ID=11827 PKGBUILD] con el parche para los colores para pacman de Vogo.
+
* -d, --dir : El directorio para almacenar los archivos descargados según lo especificado por pacman .  
 +
* -o, --out : El nombre de archivo de salida del archivo (s) descargado (s).  
 +
* %o : Variable que representa el nombre de archivo local especificado por pacman.
 +
* %u : Variable que representa la URL de descarga especificada por pacman.

Latest revision as of 23:01, 26 November 2017

Tango-preferences-desktop-locale.pngEste artículo o sección necesita ser traducido.Tango-preferences-desktop-locale.png

Notas: Outdated and does not follow style guidelines, contrast Pacman tips#Restore pacman's local database ‎ (Discusión)

Para métodos generales para mejorar la flexibilidad de las sugerencias proporcionadas o del propio pacman, consulte Core utilities y Bash.

Mantenimiento

Listando paquetes

Es posible que desee obtener la lista de paquetes instalados con su versión, lo cual es útil cuando se reportan errores o se discuten los paquetes instalados.

  • Enumere todos los paquetes explícitamente instalados: pacman -Qe .
  • todos los paquetes nativos instalados explícitamente (es decir, presentes en la base de datos de sincronización) que no sean dependencias directas o opcionales: pacman -Qent .
  • Lista de todos los paquetes extranjeros (normalmente descargados e instalados manualmente): pacman -Qm .
  • Haga una lista de todos los paquetes nativos (instalados desde la (s) base de datos de sincronización): pacman -Qn .
  • Listar paquetes por regex: pacman -Qs regex .
  • Lista de paquetes por regex con formato de salida personalizado: expac -s "%-30n %v" regex (necesita expac ).

Con el tamaño

Para obtener una lista de paquetes instalados ordenados por tamaño, lo que puede ser útil al liberar espacio en el disco duro:

  • Instalar expac y ejecutar expac -HM '%m\t%n' | sort -h expac -HM '%m\t%n' | sort -h .
  • Ejecute pacgraph con la opción -c .

Para enumerar el tamaño de descarga de varios paquetes (deje packages en blanco para listar todos los paquetes):

 $ Expac -S -HM '% k \ t% n' paquetes

Para listar los paquetes explícitamente instalados que no están en base ni en base-devel con tamaño y descripción:

 $ Expac -HM "% 011m \ t% -20n \ t% 10d" $ (comm -23 <(pacman -Qqen | sort) <(pacman -Qqg base-devel | sort)) |  Ordenar -n

Por fecha

Para enumerar los 20 últimos paquetes instalados con expac , ejecute:

 $ Expac --timefmt = '% Y-% m-% d% T' '% l \ t% n' |  Ordenar |  Cola-n 20

O, con segundos desde la época (1970-01-01 UTC):

 $ Expac --timefmt =% s '% l \ t% n' |  Sort -n |  Cola-n 20

Lista los paquetes explícitamente instalados que no están en los grupos de base o base-devel :

 $ Comm -23 <(pacman -Qeq | sort) <(pacman -Qgq base base-devel | sort)

Enumere todos los paquetes instalados no requeridos por otros paquetes y que no estén en los grupos de base o de base :

 $ Comm -23 <(pacman -Qqt | sort) <(pacman -Sqg base base-devel | sort)

Como arriba, pero con descripciones:

 $ Expac -HM '% -20n \ t% 10d' $ (comm -23 <(pacman -Qqt | sort) <(pacman -Qqg base -devel | sort)

Lista todos los paquetes instalados que no están en el repositorio especificado repo_name

 $ Comm -23 <(pacman -Qtq | sort) <(pacman -Slq repo_name | sort)

Liste todos los paquetes instalados que están en el repositorio repo_name :

 $ Comm -12 <(pacman -Qtq | sort) <(pacman -Slq repo_name | sort)

Optimización

Velocidades de acceso a la base de datos

Pacman almacena toda la información del paquete en una colección de archivos pequeños, uno para cada paquete. La mejora de las velocidades de acceso a la base de datos reduce el tiempo empleado en las tareas relacionadas con la base de datos, por ejemplo, buscar paquetes y resolver las dependencias del paquete. El método más seguro y fácil es ejecutarlo como root:

 # Pacman-optimize

Esto intentará poner todos los archivos pequeños juntos en una ubicación (física) en el disco duro para que la cabeza del disco duro no tenga que moverse tanto al acceder a todos los datos. Este método es seguro, pero no es infalible: depende del sistema de archivos, el uso del disco y la fragmentación del espacio vacío. Otra opción más agresiva sería eliminar primero los paquetes desinstalados del caché y eliminar los repositorios no utilizados antes de la optimización de la base de datos:

 # Pacman -Sc && pacman-optimize

Velocidades de descarga

Nota: Si las velocidades de descarga se han reducido a un rastreo, asegúrese de que está utilizando uno de los muchos espejos y no ftp.archlinux.org, que se estrangula desde marzo de 2007 . Al descargar paquetes pacman usa los espejos en el orden en que están en /etc/pacman.d/mirrorlist . El espejo que está en la parte superior de la lista por defecto, sin embargo, puede no ser el más rápido para usted. Para seleccionar un espejo más rápido, consulte Espejos . La velocidad de Pacman en la descarga de paquetes también puede ser mejorada mediante el uso de una aplicación diferente para descargar paquetes, en lugar del descargador de archivos integrado de Pacman. En todos los casos, asegúrese de tener la última Pacman antes de hacer cualquier modificación.

 # Pacman -Syu

Powerpill

Powerpill es un envoltorio de Pacman que utiliza la descarga paralela y segmentada para tratar de acelerar las descargas de Pacman.

Wget

Esto también es muy útil si necesita configuraciones proxy más potentes que las capacidades incorporadas de pacman.

Para usar wget , primero instale el paquete wget y luego modifique /etc/pacman.conf descomentando la siguiente línea en la sección [options] :

 XferCommand = / usr / bin / wget -c -q --show-progress --passive-ftp -O% o% u

En lugar de descomentar los parámetros de wget en /etc/pacman.conf , también puede modificar el archivo de configuración de wget directamente (el archivo de todo el sistema es /etc/wgetrc , por usuario los archivos son $HOME/.wgetrc .

Aria2

Aria2 es una utilidad de descarga de peso ligero con soporte para HTTP / HTTPS y transferencias directas continuas y segmentadas. Aria2 permite múltiples y simultáneas conexiones HTTP / HTTPS y FTP a un espejo de Arch, lo que debería resultar en un aumento en las velocidades de descarga para la recuperación de archivos y paquetes.

Nota: El uso de aria2c en XferCommand de Pacman no dará lugar a descargas paralelas de varios paquetes. Pacman invoca el XferCommand con un solo paquete a la vez y espera a que se complete antes de invocar el siguiente. Para descargar varios paquetes en paralelo, consulte Powerpill.

Instale aria2 y luego edite /etc/pacman.conf agregando la siguiente línea a la sección [options] :

 XferCommand = / usr / bin / aria2c --allow-overwrite = true --continue = true --file-allocation = ninguno --log-level = error --max-tries = 2 --max-connection-per-server = 2 --max-file-not-found = 5 --min-split-size = 5M --no-conf --remote-time = true --summary-interval = 60 --timeout = 5 --dir = / --out% o% u

Sugerencia: Esta configuración alternativa para usar pacman con aria2 intenta simplificar la configuración y añade más opciones de configuración.

Vea OPCIONES en man aria2c para las opciones de aria2c usadas.

  • -d, --dir : El directorio para almacenar los archivos descargados según lo especificado por pacman .
  • -o, --out : El nombre de archivo de salida del archivo (s) descargado (s).
  •  %o : Variable que representa el nombre de archivo local especificado por pacman.
  •  %u : Variable que representa la URL de descarga especificada por pacman.