Printer Setup: Difference between revisions
|  (mdev hacks) | mNo edit summary | ||
| (22 intermediate revisions by 8 users not shown) | |||
| Line 1: | Line 1: | ||
| [https://en.wikipedia.org/wiki/CUPS CUPS] is a modular printing system for Unix-like computer operating systems. This page explains how to install and configure printers in Alpine Linux.   | |||
| == Installation == | |||
| {{ | Install the basic packages need for configuring printers: {{cmd|# apk add cups cups-filters}} | ||
| If you want to make use of automatic discovery for [https://openprinting.github.io/printers/ printers that support IPP Everywhere™ or AirPrint™] or other printers that support [https://en.wikipedia.org/wiki/Multicast_DNS Multicast DNS], you also need to set up [[MDNS|mDNS with avahi]]. | |||
| To use CUPS to print to PDF, you can use the {{pkg|cups-pdf}} package, which is available in the [[Repositories#Testing|testing]] repository. It can be installed after [[Repositories#Using_testing_repository|configuring the testing repository]] with the below command:{{cmd|# apk add cups-pdf@testing}} | |||
| {{cmd|# apk add  | |||
| == Service configuration == | |||
| To allow a user to configure CUPS, you need to add them to the <code>lpadmin</code> group: {{cmd|adduser $USER lpadmin}} | |||
| To be able to use the CLI commands to configure CUPS, you need to log out and back in again or possibly reboot in order for the new group to take effect. | |||
| Confirm that the CUPS [[OpenRC]] service starts:{{cmd|# rc-service cupsd start}} | |||
| You may also want to configure it to start automatically:{{cmd|# rc-update add cupsd}} | |||
| == Printer configuration ==  | |||
| Go to <code><nowiki>http://localhost:631</nowiki></code> with your web browser, click on the "Administration" tab and use the "Add Printer" or "Find New Printers" button to add a new printer. When asked, you can log in with the user that you previously added to the <code>lpadmin</code> group. Once you have added a printer, you should be able to print. | |||
| To configure ''Hewlett-Packard'' (''HP'') printers ,the {{pkg|hplip}} package is available in the [[Repositories#Testing|testing]] repository. It can be installed after [[Repositories#Using_testing_repository|configuring the testing repository]] with the below command:{{cmd|# apk add hplip}} | |||
| If that doesn't work, you may also need to add HPLIP's dependencies separately. | |||
| There are currently no packages for CUPS DDK, <code>hp-setup</code> or <code>foomatic</code>. | |||
| {{cmd|# apk add ghostscript py3-reportlab libjpeg net-snmp}} | |||
| {{Expand|Modifications/sections required e.g. to address container user-case scenarios, etc.}}   | {{Expand|Modifications/sections required e.g. to address container user-case scenarios, etc.}}   | ||
| == mdev  | == Configure mdev for USB printers == | ||
| By default USB printer with  | By default USB printer with [[mdev]] would have ownership ''root:root'' and permission ''0660''. As ''cupsd'' would try to open a libusb-based printer as ''lp'' user, it won't have permission to use the device in ''/dev/bus/usb''. | ||
| First let's get some info about our USB printer. | First let's get some info about our USB printer. | ||
|   # lsusb | grep Printer |   # lsusb.py -uU | grep Printer | ||
|   3-2               04b8:0007 00 1IF  [USB 2.00,   480 Mbps,   2mA] (EPSON USB2.0 Printer (Hi-speed) 55PKAZZ15776790829) | |||
|  # grep -H "" /sys/bus/usb/devices/usb3/3-2/{id{Vendor,Product},bcdDevice} | |||
|  /sys/bus/usb/devices/usb3/3-2/idVendor:04b8 | |||
|  /sys/bus/usb/devices/usb3/3-2/idProduct:0007 | |||
|  /sys/bus/usb/devices/usb3/3-2/bcdDevice:0100 | |||
| These are important for us to distinguish our printer. | |||
|   # cat >> /etc/mdev.conf <<EOF |   # cat >> /etc/mdev.conf <<EOF | ||
| Line 45: | Line 51: | ||
|   EOF |   EOF | ||
| Unplug USB cable and plug again | Unplug the USB cable and plug it in again. Now the USB printer device at ''/dev/bus/usb/'' will have valid ownership and permissions. | ||
|   # ls -l /dev/bus/usb/002/011 |   # ls -l /dev/bus/usb/002/011 | ||
|   crw-rw---- 1 root lp 189, 138 Apr 14 21:19 /dev/bus/usb/002/011 |   crw-rw---- 1 root lp 189, 138 Apr 14 21:19 /dev/bus/usb/002/011 | ||
| CUPS will be able now to use libusb to discover local USB printer. | CUPS will be able now to use libusb to discover the local USB printer. | ||
| == Managing Printers via KDE Plasma Settings == | |||
| To manage printers from KDE Plasma Settings, it is required to add "root" to SystemGroup in '''''/etc/cups/cups-files.conf'''''. | |||
| e.g.   | |||
| {{Cmd| | |||
| SystemGroup root lpadmin}} | |||
| == Managing Printers via Command Line == | |||
| Credit to ArchWiki's excellent [https://wiki.archlinux.org/index.php/CUPS CUPS] page for guidance with the following basic steps. | |||
| === Locate your printer === | |||
| With your printer connected and powered on, determine the ''URI'' for your printer.  Depending on whether the connection is via '''usb''' or '''parallel''' ports, the URI will carry a <code>usb://</code> or <code>parallel:/</code> prefix. | With your printer connected and powered on, determine the ''URI'' for your printer.  Depending on whether the connection is via '''usb''' or '''parallel''' ports, the URI will carry a <code>usb://</code> or <code>parallel:/</code> prefix. | ||
| Line 92: | Line 88: | ||
| In the example above, the URI is <code>usb://HP/LaserJet%202200</code> | In the example above, the URI is <code>usb://HP/LaserJet%202200</code> | ||
| === Find a .ppd or .ppd.gz ''driver'' === | |||
| If your printer supports ''IPP Everywhere'' --most recent models do-- see the ''driverless'' command in ''cups-filters'': | If your printer supports ''IPP Everywhere'' -- most recent models do -- see the ''driverless'' command in ''cups-filters'': | ||
|   $ driverless ipp_uri > printer.ppd |   $ driverless ipp_uri > printer.ppd | ||
| or just pass ''-m everywhere'' to ''lpadmin''. | or just pass ''-m everywhere'' to ''lpadmin''. | ||
| Otherwise, you could list all the drivers available by running <code>lpinfo -m</code> and then searching through the results to find a .ppd or .ppd.gz specific to your printer.  A quick solution is to use the <code>--make-and-model</code> flag and  | Otherwise, you could list all the drivers available by running <code>lpinfo -m</code> and then searching through the results to find a .ppd or .ppd.gz specific to your printer.  A quick solution is to use the <code>--make-and-model</code> flag and <code>grep</code> to filter the results by plugging in your printer's make, model and series in this fashion: | ||
|   $ lpinfo --make-and-model "''make_and_model_names''" -m | grep -i ''printer_series'' |   $ lpinfo --make-and-model "''make_and_model_names''" -m | grep -i ''printer_series'' | ||
| Line 112: | Line 108: | ||
|   $ lpinfo --make-and-model "HP LaserJet" -m | grep -i 2200 |   $ lpinfo --make-and-model "HP LaserJet" -m | grep -i 2200 | ||
| From the results, you might select the following .ppd ''driver'': | |||
|   drv:///hp/hpcups.drv/hp-laserjet_2200_series.ppd |   drv:///hp/hpcups.drv/hp-laserjet_2200_series.ppd | ||
| If required,  | If required, additional drivers can be obtained by installing {{Pkg|gutenprint}}, and running the <code>lpinfo</code> search again.  These may not specify <code>.ppd</code> names. | ||
| {{Cmd|# apk add gutenprint gutenprint-doc}} | |||
| === Configure a queue === | |||
| Create a queue using a ''queue_name'' of your choice.  Your selected printer's name is an obvious choice, but do not  | Create a queue using a ''queue_name'' of your choice.  Your selected printer's name is an obvious choice, but do not use spaces.<BR> | ||
| You will also need to be root or use <code>sudo</code>, and you will also need to plug in the ''URI'' and the .ppd ''driver'': | |||
|   # lpadmin -p ''queue_name'' -E -v "''uri''" -m ''driver'' |   # lpadmin -p ''queue_name'' -E -v "''uri''" -m ''driver'' | ||
| Line 149: | Line 147: | ||
| == See also == | == See also == | ||
| * [[MDNS|Use mDNS to discover printers]] | |||
| * [https://www.cups.org/documentation.html CUPS documentation] | * [https://www.cups.org/documentation.html CUPS documentation] | ||
| [[Category:Printers]] | [[Category:Printers]] | ||
Latest revision as of 20:34, 23 October 2025
CUPS is a modular printing system for Unix-like computer operating systems. This page explains how to install and configure printers in Alpine Linux.
Installation
Install the basic packages need for configuring printers:
# apk add cups cups-filters
If you want to make use of automatic discovery for printers that support IPP Everywhere™ or AirPrint™ or other printers that support Multicast DNS, you also need to set up mDNS with avahi.
To use CUPS to print to PDF, you can use the cups-pdf package, which is available in the testing repository. It can be installed after configuring the testing repository with the below command:
# apk add cups-pdf@testing
Service configuration
To allow a user to configure CUPS, you need to add them to the lpadmin group: 
adduser $USER lpadmin
To be able to use the CLI commands to configure CUPS, you need to log out and back in again or possibly reboot in order for the new group to take effect.
Confirm that the CUPS OpenRC service starts:
# rc-service cupsd start
You may also want to configure it to start automatically:
# rc-update add cupsd
Printer configuration
Go to http://localhost:631 with your web browser, click on the "Administration" tab and use the "Add Printer" or "Find New Printers" button to add a new printer. When asked, you can log in with the user that you previously added to the lpadmin group. Once you have added a printer, you should be able to print.
To configure Hewlett-Packard (HP) printers ,the hplip package is available in the testing repository. It can be installed after configuring the testing repository with the below command:
# apk add hplip
If that doesn't work, you may also need to add HPLIP's dependencies separately.
There are currently no packages for CUPS DDK, hp-setup or foomatic.
# apk add ghostscript py3-reportlab libjpeg net-snmp
|  Modifications/sections required e.g. to address container user-case scenarios, etc. | 
Configure mdev for USB printers
By default USB printer with mdev would have ownership root:root and permission 0660. As cupsd would try to open a libusb-based printer as lp user, it won't have permission to use the device in /dev/bus/usb.
First let's get some info about our USB printer.
# lsusb.py -uU | grep Printer 3-2 04b8:0007 00 1IF [USB 2.00, 480 Mbps, 2mA] (EPSON USB2.0 Printer (Hi-speed) 55PKAZZ15776790829)
# grep -H "" /sys/bus/usb/devices/usb3/3-2/{id{Vendor,Product},bcdDevice}
/sys/bus/usb/devices/usb3/3-2/idVendor:04b8
/sys/bus/usb/devices/usb3/3-2/idProduct:0007
/sys/bus/usb/devices/usb3/3-2/bcdDevice:0100
These are important for us to distinguish our printer.
# cat >> /etc/mdev.conf <<EOF SUBSYSTEM=usb;PRODUCT=4b8/7/100;.* root:lp 660 */lib/mdev/usbdev EOF
Unplug the USB cable and plug it in again. Now the USB printer device at /dev/bus/usb/ will have valid ownership and permissions.
# ls -l /dev/bus/usb/002/011 crw-rw---- 1 root lp 189, 138 Apr 14 21:19 /dev/bus/usb/002/011
CUPS will be able now to use libusb to discover the local USB printer.
Managing Printers via KDE Plasma Settings
To manage printers from KDE Plasma Settings, it is required to add "root" to SystemGroup in /etc/cups/cups-files.conf.
e.g.
SystemGroup root lpadmin
Managing Printers via Command Line
Credit to ArchWiki's excellent CUPS page for guidance with the following basic steps.
Locate your printer
With your printer connected and powered on, determine the URI for your printer.  Depending on whether the connection is via usb or parallel ports, the URI will carry a usb:// or parallel:/ prefix.
$ lpinfo -v # network lpd network socket network beh file cups-brf:/ direct usb://HP/LaserJet%202200 network ipp network ipps network https network http direct hp
In the example above, the URI is usb://HP/LaserJet%202200
Find a .ppd or .ppd.gz driver
If your printer supports IPP Everywhere -- most recent models do -- see the driverless command in cups-filters:
$ driverless ipp_uri > printer.ppd
or just pass -m everywhere to lpadmin.
Otherwise, you could list all the drivers available by running lpinfo -m and then searching through the results to find a .ppd or .ppd.gz specific to your printer.  A quick solution is to use the --make-and-model flag and grep to filter the results by plugging in your printer's make, model and series in this fashion:
$ lpinfo --make-and-model "make_and_model_names" -m | grep -i printer_series
- Search for the term HP to find instances of Hewlett-Packard.
- You do not need to state the printer_seriesin whole if at all e.g. 2200 may be preferable to searching for 2200M, etc.
For example, type:
$ lpinfo --make-and-model "HP LaserJet" -m | grep -i 2200
From the results, you might select the following .ppd driver:
drv:///hp/hpcups.drv/hp-laserjet_2200_series.ppd
If required, additional drivers can be obtained by installing gutenprint, and running the lpinfo search again.  These may not specify .ppd names.
# apk add gutenprint gutenprint-doc
Configure a queue
Create a queue using a queue_name of your choice.  Your selected printer's name is an obvious choice, but do not use spaces.
You will also need to be root or use sudo, and you will also need to plug in the URI and the .ppd driver:
# lpadmin -p queue_name -E -v "uri" -m driver
With this example, you could set as follows, but there are other solutions.
# lpadmin -p HP_LaserJet_2200 -E -v "usb://HP/LaserJet%202200" -m drv:///hp/hpcups.drv/hp-laserjet_2200-pcl3.ppd
This printer queue could be set as default:
# lpoptions -d HP_LaserJet_2200
Printer settings can typically be set in your GUI application's Print menu or by examining the CUPS lpoptions page. If you have a single queue, the setting options available (such as page type, duplex, etc.) for your queue can simply be listed by using the -l flag. Asterisks(*) indicate current settings:
# lpoptions -l PageSize/Media Size: Card3x5 Hagaki Photo4x6 A6 Photo5x7 Card5x8 Oufuku A5 B5 JB5 Executive 16k Letter *A4 ExecutiveJIS FLSA Legal EnvA2 EnvC6 EnvChou4 EnvMonarch EnvDL Env10 EnvChou3 EnvC5 EnvB5 Custom.WIDTHxHEIGHT Duplex/Double-Sided Printing: DuplexNoTumble DuplexTumble *None InputSlot/Media Source: *Auto PhotoTray Upper Lower Envelope LargeCapacity Manual MPTray ColorModel/Output Mode: *Gray MediaType/Media Type: *Plain OutputMode/Print Quality: *Normal Draft Best OptionDuplex/Duplexer Installed: *False True
If there is only one queue, options can be set by simply using -o flags for each setting:
# lpoptions -o PageSize=Legal -o Duplex=DuplexNoTumble