Difference between revisions of "Pacman Overview"
Views
Actions
Namespaces
Variants
Tools
(Prepared the page for translation) |
(extended warning) |
||
(16 intermediate revisions by 8 users not shown) | |||
Line 1: | Line 1: | ||
<languages/> | <languages/> | ||
__TOC__ | __TOC__ | ||
<translate> | |||
=Overview= <!--T:1--> | |||
<!--T:2--> | |||
Manjaro's package manager, [[Special:MyLanguage/Pamac|Pamac]] ships with most Manjaro editions. All Manjaro editions include [https://www.archlinux.org/pacman/ pacman], the package manager from upstream Arch Linux. Pacman includes some advanced features not found in Pamac. | Manjaro's package manager, [[Special:MyLanguage/Pamac|Pamac]] ships with most Manjaro editions. All Manjaro editions include [https://www.archlinux.org/pacman/ pacman], the package manager from upstream Arch Linux. Pacman includes some advanced features not found in Pamac. | ||
<!--T:3--> | |||
Key points to know: | Key points to know: | ||
<!--T:4--> | |||
* Pacman is already installed in Manjaro Linux by default | * Pacman is already installed in Manjaro Linux by default | ||
* Pacman is mainly developed/maintained by Arch Linux developers | * Pacman is mainly developed/maintained by Arch Linux developers | ||
* Pacman can only be used from the command line, if you would prefer a graphical package manager please see [[Special:MyLanguage/Pamac|Pamac]] or [[Special:MyLanguage/Octopi|Octopi]] | * Pacman can only be used from the command line, if you would prefer a graphical package manager please see [[Special:MyLanguage/Pamac|Pamac]] or [[Special:MyLanguage/Octopi|Octopi]] | ||
* Pacman can only use the official Manjaro [[Special:MyLanguage/Repositories_and_Servers|repository]]. There are | * Pacman can only use the official Manjaro [[Special:MyLanguage/Repositories_and_Servers|repository]]. There are separate articles available for accessing the [[Special:MyLanguage/Arch_User_Repository|Arch User Repository(AUR)]], using [[Special:MyLanguage/Flatpak|flatpaks]] and using [[Special:MyLanguage/Snaps|snaps]] | ||
=Installing Updates= | =Installing Updates= <!--T:5--> | ||
<!--T:6--> | |||
Update the package database and update all packages on the system | |||
{{UserCmd|command=sudo pacman -Syu}} | |||
<!--T:8--> | |||
Update all packages on the system and allow packages to be downgraded. Downgrading should be only be needed when switching to an older branch. For example, switching from Testing to Stable.</translate> | |||
{{UserCmd|command=sudo pacman -Syuu}} | |||
<translate> | |||
=Searching for Packages= <!--T:9--> | |||
To | <!--T:10--> | ||
To search the Manjaro repositories for available packages you can use the command {{ic|pacman -Ss keyword}}. It will search both the package name and the description for the keyword. For example, to search for packages containing the keyword smplayer you could use:</translate> | |||
{{UserCmd|command=pacman -Ss smplayer}} | |||
<translate><!--T:11--> You can search your installed packages in the same manner using {{ic|-Qs}} instead of {{ic|-Ss}}. To search your installed packages for smplayer:</translate> | |||
{{UserCmd|command=pacman -Qs smplayer}} | |||
<translate><!--T:12--> Once you have found a package you can use {{ic|pacman -Qi}} to get more information about an installed packages or {{ic|pacman -Si}} for packages in the repos. Following the example above you could use</translate> | |||
{{UserCmd|command=pacman -Si smplayer}} | |||
<translate><!--T:13--> Finally, for a list of all installed packages on your system, enter the following command:</translate> | |||
{{UserCmd|command=pacman -Ql}} | |||
<translate> | |||
=Installing Packages= <!--T:14--> | |||
<!--T:15--> | |||
{{BoxWarning|Never install a package without updating the system first| On a rolling release this can lead to an unbootable system}} | |||
<!--T:16--> | |||
To install a software package, the basic syntax is {{ic|pacman -S packagename}}. However, installing a package without updating the system will lead to a partial upgrade situation so all the examples here will use {{ic|pacman -Syu packagename}} which will install the package and ensure the system is up to date. For example, to install smplayer the command is:</translate> | |||
{{UserCmd|command=sudo pacman -Syu smplayer}} | |||
<translate> | <translate> | ||
<!--T:17--> | |||
You will then be presented a list of software to install. You may notice this list has more packages than you requested. This is because many packages also have dependencies which are packages that must be installed in order for the software you selected to function properly. | You will then be presented a list of software to install. You may notice this list has more packages than you requested. This is because many packages also have dependencies which are packages that must be installed in order for the software you selected to function properly. | ||
<!--T:18--> | |||
Pacman can also directly install packages from the local system or a location on the internet. The format of that command is {{ic|pacman -U packagelocation}}. For example, to install a copy of your package cache you could do something like:</translate> | |||
{{UserCmd|command=sudo pacman -U /var/cache/pacman/pkg/smplayer-19.5.0-1-x86_64.pkg.tar.xz}} | |||
<translate><!--T:19--> Alternatively, you could get it directly from one of Manjaro's mirrors:</translate> | |||
{{UserCmd|command=sudo pacman -U <nowiki>https://mirror.alpix.eu/manjaro/stable/community/x86_64/smplayer-19.5.0-1-x86_64.pkg.tar.xz</nowiki>}} | |||
<translate> | <translate> | ||
<!--T:20--> | |||
{{BoxWarning|Warning|When using pacman -U it is up to you to ensure that the package you are installing is fully compatible with your system.}} | |||
=Removing Packages= | =Removing Packages= <!--T:21--> | ||
< | <!--T:22--> | ||
{{ | {{BoxWarning|Always review the package list before confirming when removing packages|If you are not careful you can easily remove your entire desktop due to dependencies.}} | ||
To remove a software package, the basic syntax is {{ic|sudo pacman -R packagename}}. We could remove the smplayer package we installed above with: | <!--T:23--> | ||
To remove a software package, the basic syntax is {{ic|sudo pacman -R packagename}}. We could remove the smplayer package we installed above with:</translate> | |||
{{UserCmd|command=sudo pacman -R smplayer}} | |||
This will remove the package, but will leave all the dependencies behind. If you also want to remove the unneeded dependencies you could use {{ic|pacman -Rsu packagename}} as seen in this example: | <translate><!--T:24--> This will remove the package, but will leave all the dependencies behind. If you also want to remove the unneeded dependencies you could use {{ic|pacman -Rsu packagename}} as seen in this example:</translate> | ||
{{UserCmd|command=sudo pacman -Rsu smplayer}} | |||
Sometimes when you try to remove a package you will not be able to because there are other packages which depend on it. You can use {{ic|pacman -Rc packagename}} to remove a package and everything that depends on it. Be careful to heed the above warning when using this option. | <translate><!--T:25--> Sometimes when you try to remove a package you will not be able to because there are other packages which depend on it. You can use {{ic|pacman -Rc packagename}} to remove a package and everything that depends on it. Be careful to heed the above warning when using this option.</translate> | ||
{{UserCmd|command=sudo pacman -Rc smplayer}} | |||
The most nuclear option is {{ic|pacman -Rcs packagename}}. | <translate><!--T:26--> | ||
The most nuclear option is {{ic|pacman -Rcs packagename}}. | |||
{{BoxDanger|Use this with extreme caution, or don’t use it at all| | |||
-Rcs will remove every package that depends on packagename regardless of whether a package is needed for something else. This could render Manjaro unusable. }} | |||
<!--T:27--> | |||
Pacman usually also creates backup configuration files when deleting packages. To remove those, you can add {{ic|n}} to any of the examples above. For example:</translate> | |||
{{UserCmd|command=sudo pacman -Rn smplayer}} | |||
{{UserCmd|command=sudo pacman -Rsun smplayer}} | |||
{{UserCmd|command=sudo pacman -Rcn smplayer}} | |||
<translate> | |||
=Viewing and Removing Orphans= | =Viewing and Removing Orphans= <!--T:28--> | ||
<!--T:29--> | |||
To list all ''orphans'', installed packages that are not used by anything else and should no longer be needed: | To list all ''orphans'', installed packages that are not used by anything else and should no longer be needed: | ||
{{UserCmd|command=pacman -Qdt}} | |||
To remove all the orphans: | <!--T:30--> | ||
To remove all the orphans:</translate> | |||
{{UserCmd|command=sudo pacman -Rs $(pacman -Qdtq)}} | |||
=Downloading Packages without Installing= | <translate> | ||
=Downloading Packages without Installing= <!--T:31--> | |||
In some cases it may be useful to download a package without installing. For example, to install on a different system that is not connected to the internet. This can be done with {{ic|pacman -Sw packagename}}. For example: | <!--T:32--> | ||
In some cases it may be useful to download a package without installing. For example, to install on a different system that is not connected to the internet. This can be done with {{ic|pacman -Sw packagename}}. For example:</translate> | |||
{{UserCmd|command=sudo pacman -Sw smplayer}} | |||
<translate> | |||
<!--T:33--> | |||
The package and any rerquired dependencies will be downloaded to your pacman cache at {{ic|/var/cache/pacman/pkg}} | The package and any rerquired dependencies will be downloaded to your pacman cache at {{ic|/var/cache/pacman/pkg}} | ||
=Determining which Package Owns a File= | =Determining which Package Owns a File= <!--T:34--> | ||
It is often useful to understand which package installed a file on your system. This is easy to do with pacman using {{ic|pacman -Qo /path/to/filename}}. For example: | <!--T:35--> | ||
It is often useful to understand which package installed a file on your system. This is easy to do with pacman using {{ic|pacman -Qo /path/to/filename}}. For example:</translate> | |||
{{UserCmd|command=pacman -Qo /usr/bin/smplayer}} | |||
=Cleaning the Cache= | <translate> | ||
=Cleaning the Cache= <!--T:36--> | |||
<!--T:37--> | |||
When pacman installs packages, it keeps a copy of all the old packages you have downloaded. This cache can be very useful if you have to install older packages in an emergency. However, left unchecked, this cache will grow very large over time. Systems running [[Special:MyLanguage/Pamac|Pamac]] will already have access to its automated pacman cache cleaning functions. It is also possible to clean them manually using pacman. | When pacman installs packages, it keeps a copy of all the old packages you have downloaded. This cache can be very useful if you have to install older packages in an emergency. However, left unchecked, this cache will grow very large over time. Systems running [[Special:MyLanguage/Pamac|Pamac]] will already have access to its automated pacman cache cleaning functions. It is also possible to clean them manually using pacman. | ||
To clear the cache of packages that are no longer installed, enter the following command: | <!--T:38--> | ||
To clear the cache of packages that are no longer installed, enter the following command:</translate> | |||
{{UserCmd|command=sudo pacman -Sc}} | |||
Otherwise, to clear the cache completely, enter the following command (and use with care): | <translate><!--T:39--> Otherwise, to clear the cache completely, enter the following command (and use with care):</translate> | ||
{{UserCmd|command=sudo pacman -Scc}} | |||
A safer way to remove old package cache files is to remove all packages except for the latest three package versions using {{ic|paccache}}: | <translate><!--T:40--> A safer way to remove old package cache files is to remove all packages except for the latest three package versions using {{ic|paccache}}:</translate> | ||
{{UserCmd|command=paccache -rvk3}} | |||
<translate> | <translate> | ||
=The Configuration File, pacman.conf= <!--T:41--> | |||
<!--T:42--> | |||
Pacman's settings are located in {{ic|/etc/pacman.conf}}. This file is owned by root, please see [[Special:MyLanguage/Viewing_and_editing_configuration_files|this guide]] if you need more information on how to edit this file. A full reference to these options can be found in the Arch Wiki linked below. This sections features some settings that may be of particular interest to Manjaro users. | |||
<!--T:43--> | |||
{{BoxSuccess|Note|pacman.conf settings are case sensitive}} | |||
==Enabling Color Output== | ==Enabling Color Output== <!--T:44--> | ||
By default, pacman's output is monochrome but enabling colored output can make the output easier to read if your terminal supports colors. This can be enabled by uncommenting or adding the following line to the file | <!--T:45--> | ||
By default, pacman's output is monochrome but enabling colored output can make the output easier to read if your terminal supports colors. This can be enabled by uncommenting or adding the following line to the file</translate> | |||
Color | Color | ||
<translate> | |||
==Showing PacMan Eating Power Pills== <!--T:46--> | |||
<!--T:47--> | |||
If you are bored of simply watching lines of hashes while downloading software packages in the terminal, why not change the progress bar to Pacman eating power pills instead? To enable this, simply add the line:</translate> | |||
If you are bored of simply watching lines of hashes while downloading software packages in the terminal, why not change the progress bar to Pacman eating power pills instead? To enable this, simply add the line: | |||
ILoveCandy | ILoveCandy | ||
<translate> | |||
=Troubleshooting= | =Troubleshooting= <!--T:48--> | ||
A separate page for pacman troubleshooting is available '''[[Special:MyLanguage/pacman troubleshooting|here]]'''. | A separate page for pacman troubleshooting is available '''[[Special:MyLanguage/pacman troubleshooting|here]]'''. | ||
=See Also= | =See Also= <!--T:49--> | ||
* [[Special:MyLanguage/System Maintenance|System Maintenance]] | * [[Special:MyLanguage/System Maintenance|System Maintenance]] | ||
* [[Special:MyLanguage/Pacman-mirrors|Pacman-mirrors]] | * [[Special:MyLanguage/Pacman-mirrors|Pacman-mirrors]] | ||
Line 179: | Line 191: | ||
* [https://wiki.archlinux.org/index.php/Pacman_tips ArchWiki: pacman tips] | * [https://wiki.archlinux.org/index.php/Pacman_tips ArchWiki: pacman tips] | ||
* [https://wiki.archlinux.org/index.php/Improve_pacman_performance ArchWiki: pacman performance] | * [https://wiki.archlinux.org/index.php/Improve_pacman_performance ArchWiki: pacman performance] | ||
</translate> | |||
[[Category:Contents Page]] | [[Category:Contents Page{{#translation:}}]] | ||
Latest revision as of 09:23, 28 December 2023
Overview
Manjaro's package manager, Pamac ships with most Manjaro editions. All Manjaro editions include pacman, the package manager from upstream Arch Linux. Pacman includes some advanced features not found in Pamac.
Key points to know:
- Pacman is already installed in Manjaro Linux by default
- Pacman is mainly developed/maintained by Arch Linux developers
- Pacman can only be used from the command line, if you would prefer a graphical package manager please see Pamac or Octopi
- Pacman can only use the official Manjaro repository. There are separate articles available for accessing the Arch User Repository(AUR), using flatpaks and using snaps
Installing Updates
Update the package database and update all packages on the system
Update all packages on the system and allow packages to be downgraded. Downgrading should be only be needed when switching to an older branch. For example, switching from Testing to Stable.
Searching for Packages
To search the Manjaro repositories for available packages you can use the command pacman -Ss keyword
. It will search both the package name and the description for the keyword. For example, to search for packages containing the keyword smplayer you could use:
You can search your installed packages in the same manner using -Qs
instead of -Ss
. To search your installed packages for smplayer:
Once you have found a package you can use pacman -Qi
to get more information about an installed packages or pacman -Si
for packages in the repos. Following the example above you could use
Finally, for a list of all installed packages on your system, enter the following command:
Installing Packages
To install a software package, the basic syntax is pacman -S packagename
. However, installing a package without updating the system will lead to a partial upgrade situation so all the examples here will use pacman -Syu packagename
which will install the package and ensure the system is up to date. For example, to install smplayer the command is:
You will then be presented a list of software to install. You may notice this list has more packages than you requested. This is because many packages also have dependencies which are packages that must be installed in order for the software you selected to function properly.
Pacman can also directly install packages from the local system or a location on the internet. The format of that command is pacman -U packagelocation
. For example, to install a copy of your package cache you could do something like:
Alternatively, you could get it directly from one of Manjaro's mirrors:
Removing Packages
To remove a software package, the basic syntax is sudo pacman -R packagename
. We could remove the smplayer package we installed above with:
This will remove the package, but will leave all the dependencies behind. If you also want to remove the unneeded dependencies you could use pacman -Rsu packagename
as seen in this example:
Sometimes when you try to remove a package you will not be able to because there are other packages which depend on it. You can use pacman -Rc packagename
to remove a package and everything that depends on it. Be careful to heed the above warning when using this option.
The most nuclear option is pacman -Rcs packagename
.
Pacman usually also creates backup configuration files when deleting packages. To remove those, you can add n
to any of the examples above. For example:
Viewing and Removing Orphans
To list all orphans, installed packages that are not used by anything else and should no longer be needed:
To remove all the orphans:
Downloading Packages without Installing
In some cases it may be useful to download a package without installing. For example, to install on a different system that is not connected to the internet. This can be done with pacman -Sw packagename
. For example:
The package and any rerquired dependencies will be downloaded to your pacman cache at /var/cache/pacman/pkg
Determining which Package Owns a File
It is often useful to understand which package installed a file on your system. This is easy to do with pacman using pacman -Qo /path/to/filename
. For example:
Cleaning the Cache
When pacman installs packages, it keeps a copy of all the old packages you have downloaded. This cache can be very useful if you have to install older packages in an emergency. However, left unchecked, this cache will grow very large over time. Systems running Pamac will already have access to its automated pacman cache cleaning functions. It is also possible to clean them manually using pacman.
To clear the cache of packages that are no longer installed, enter the following command:
Otherwise, to clear the cache completely, enter the following command (and use with care):
A safer way to remove old package cache files is to remove all packages except for the latest three package versions using paccache
:
The Configuration File, pacman.conf
Pacman's settings are located in /etc/pacman.conf
. This file is owned by root, please see this guide if you need more information on how to edit this file. A full reference to these options can be found in the Arch Wiki linked below. This sections features some settings that may be of particular interest to Manjaro users.
Enabling Color Output
By default, pacman's output is monochrome but enabling colored output can make the output easier to read if your terminal supports colors. This can be enabled by uncommenting or adding the following line to the file
Color
Showing PacMan Eating Power Pills
If you are bored of simply watching lines of hashes while downloading software packages in the terminal, why not change the progress bar to Pacman eating power pills instead? To enable this, simply add the line:
ILoveCandy
Troubleshooting
A separate page for pacman troubleshooting is available here.