Slow HP Printer: A fix for HP Wireless Printers

Slow HP Printer? You’re not alone!

Recently I had a couple of computer repair customers who had HP OfficeJet Pro 8600 series printers. One was an OfficeJet Pro 8600 and the other the OfficeJet Pro 8620. They were both experiencing similar issues. Both complained about a slow HP printer, and both were using Wireless networking to print, and experienced rather severe problems aside from slowness. One would simply refuse to print until either the computer or the printer were restarted. The other would print fine for a few pages and then stop for sometimes several minutes before it started back up. This made printing long documents very difficult for the customer.

I tried various fixes including using older PCL-only drivers, and OfficeJet 8600 drivers on the 8620. The problems persisted. Finally, I gave up and called HP. Slow HP Printers, specially wireless, are apparently a real problem, since they were able to identify the issue immediately and fixed it in just a few minutes.

Since I could find no documentation on the web regarding this easy fix for a slow HP printer, I thought I would write it up for you here. This fix should also work on other models that are similarly configured, such as the newer OfficeJet Pro 8720.

The Fix

The general idea is that we’re going to configure both the printer and the computer to use Port 9100 printing instead of the default configuration. Once configured, the slow HP printer should be a fast HP printer.

Step 1: Find the Printer’s IP Address

Use the control panel on the printer itself.

  • Touch  Settings > Wireless > Display Network Configuration > Display Network Summary (or similar).
  • It should display at least 4 lines: Hostname, IP Address, MAC and SSID. If it shows none of those things, then it isn’t connected to a network, and this isn’t the guide you’re looking for.
  • Write down the IP Address It’ll look like “” or “” or something similar.

Step 2: Log In to Printers Web Interface

Now, open up a web browser, and enter the IP address of the printer in the Address bar, and press Enter. You’ll be presented with the HP Embedded Web Server. That’s great! We’re getting there.



Step 3: Set a Static IP Address

Normally your router will assign your printer an IP address every time it reconnects. We’re going to bypass that. Click the “Network” tab, and then select “IPv4 Configuration” on the left column. Change the setting under “IP Address Configuration” on the right side so that “Manual IP” is selected instead of “Automatic IP”. Don’t change any of the IP information. Your router is smart enough not to assign that IP to another computer, so we’re not going to worry about changing the IP. We’re just ensuring it doesn’t change. DNS Address Configuration should be changed to “Manual DNS Server”. Click Apply.

Step 4: Change Bonjour Priority

Click the Advanced Settings option on the left column. Several options will show themselves. Select “Bonjour”. Bonjour should already be enabled. Open the “Bonjour Highest Priority Service” drop down, and select “9100 Printing”, then click Apply.

Step 5: Enable TCP Port 9100 Printing

Still under Advanced Settings in the left column, click “Port 9100 Printing”. Enable it on the right side, and click Apply.

Step 6: Configure the PC for Port 9100 Printing

While I am presenting these steps as done in Windows 10, they are almost identical between Windows XP, 7, 8, and 10.

  • Open the Control Panel, and go to Printers (or View devices and Printers).Slow HP Printer: Configure TCP/IP Port
  • Right Click on the slow HP printer and select “Printer properties”.
  • Select the “Ports” tab, and then “Add Port…”.
  • Select “Standard TCP/IP Port”, and then click “New Port…” and click Next.
  • Type in your printer’s IP Address, and let Windows select the Port Name. Click Next.
  • Close the “New Port” box.
  • Click on the new port, which says “Standard TCP/IP Port” and click “Configure Port…”
  • Click the check box labeled “SNMP Status Enabled” and then click OK.

Now, try printing a document. You may need to cancel any documents you’d tried to print previously, but even those will likely start printing.

This should fix your problem with a slow HP printer. It changes the networking of the printer to use a more tried and true TCP/IP connection on port 9100, which is how network printers have been printing since, well, forever.

Did this work for you? Please let us know in the comments. We’d love to hear your experiences with this fix for your slow HP printer!

What if it doesn’t work?

Unfortunately this is a very complicated problem and this fix doesn’t always work because the problem may lay elsewhere. If you’re using WiFi then make sure the printer is reasonably close to your WiFi router, as is the computer you are printing from. Also, do a basic virus scan on your computer and make sure there aren’t other problems. If your computer is slow in general, then that could be the source of your slow HP printer too.

Today’s printers rely very much on the computer to do all the computing. Slow computer = Slow printer. If you’re not sure, just try printing from a different computer and see if the problem persists. If the printer is quite old, then it simply may be time for a new one. Amazon has great deals on HP printers (click the picture to the left for some ideas), and the latest models are quite nice.


Virtualmin Configuration: Adding Image Magick to PHP 5.6.5

Tonight I needed to do some work on my Other Blog and noticed that I was unable to edit images directly in WordPress. Yep, I hadn’t installed Image Magick yet and so those functions were not available. If you followed the installation/configuration instructions at my Previous Post, then the following likely applies to you. And it might apply to you anyway. I knew it was just a PECL install away, but I forgot to install Imagick first, and so I got the error “checking Testing /usr/local/bin/MagickWand-config… Doesn’t exist”. If you follow the steps below, it’ll fix it right up.

I’ve distilled it into a few simple steps:

1: Install Image Magick and needed libraries:

yum install ImageMagick-Devel ImageMagick

Now you’re ready to install the PHP PECL library.

2: Install imagick via PECL:

/opt/rh/rh-php56/root/bin/pecl install imagick

3: Enable it in your php.ini

echo "" >> /home/username/etc/php5.6/php.ini

4: Restart Apache

systemctl restart httpd

That should do it! Use a phpinfo() to check to make sure the module is there, and you’re good to go!

Setting up Virtualmin on CentOS 7 with Spam Filtering and a Firewall

Setup a Virtualmin Server on CentOS 7

Well hello there! In this tutorial, we’re going to take a bare CentOS 7 server and install Virtualmin. Along the way we’ll get it ready for some basic spam filtering with postfix and make it ready for general use. This build was originally deployed on a VPS over at They have great deals on cheap servers, and I’ve been impressed with the speed. For $3.49/mo you get an OpenStack KVM server with 1 core, 2GB memory and 10GB of SSD disk. More info is here:

And in case you’re wondering: No, I don’t get anything from OVH for talking about it. It’s just a good deal, and it works.

When you order, you’ll want to select CentOS 7 as your OS. In a little bit, you’ll get an email that contains all the information you need to log in to your server.

Step 1: Install some preliminary packages

Before we get too far, we’ll need some basic Linux tools that a base install of CentOS 7 does not have. Run the following command:

yum -y install perl lsof sysstat lsof traceroute whois wget ftp nano

Step 2: install your SSH key

I strongly recommend securing ssh and only using key based authentication. I already have a Linux server at home that I use as a media server and a “jump box” of sorts, and it has my ssh private and public keys already set up. For me, the first step was logging in with SSH as “root” and installing my public SSH key. I copied my key to the server and set permissions on the authorized_keys file. If the /root/.ssh directory does not yet exist, then create it and chmod it to 600.

mkdir /root/.ssh
nano /root/.ssh/authorized_keys
chmod 600 /root/.ssh/authorized_keys /root/.ssh

From here you can disable ssh password authentication for the root user, but I’m not going to discuss that here.

Step 3: Set your hostname

OVH, and many other providers, will give you a default hostname. There’s nothing wrong with that, but for a web hosting server, you want to use a hostname that matches your branding or at least your domain name. Normally you need to reboot after doing this, but we’ll be rebooting after some other steps, so we’ll hold off rebooting just yet. For now just use the following command to set a hostname.

A word about hostnames: “” is not a valid hostname. You need to use something like “” or “”. If you use “www” then it’ll interfere with the Apache virtualhosts later on, and you don’t want that. Also don’t use “new-server” or some other “new” designation. Eventually this is going to be your old server, so make it something timeless and easy to type. Many folks use characters from their favorite show or some other theme.
echo "" > /etc/hostname

Step 4: Turn off SELinux

This interferes with a lot of things and isn’t generally used on a web server, so lets turn it off with the following command.

sed -i 's/SELINUX=enabled/SELINUX=disabled/' /etc/selinux/config

Step 5: Change the command prompt to have the full working directory.

I like to have the full working directory in the command prompt for clarity.

nano /root/.bash_profile

add the following line:

export PS1="[\u@\h \w]# "

Step 6: Reboot

Now it’s time to enact the changes in hostname and the disabling of SELinux. Just type the word “reboot” and wait about a minute to log back in.


Step 7: Install Virtualmin

Now we get to install Virtualmin. From their website “Virtualmin is a powerful and flexible web hosting control panel for Linux and BSD systems.” The nice thing is that it’s fairly lightweight, is free, and is open source. There are other options, but this is the one I chose based on my needs which admittedly were very specific. It’s a good control panel though and I’ve come to like it quite a bit. One of the beautiful things is that it installs a complete LAMP stack for you- did you notice that we’ve not installed Apache, MySQL, Postfix, PHP, or really any other services? The Virtualmin installer does this for you.

If you are starting this tutorial on a box already configured with sites- stop. This tutorial isn’t for you. Virtualmin needs a clean installation to start with. You’ll need a new server and then can migrate your sites to it.

Paste the following commands:


This is what you’ll see:

Press “y” and then press Enter, and wait 10-15 minutes. Got get some coffee or stretch your legs. I prefer pretty much anything with caffeine. Put on some tunes, and lets get configuring!

[For the tutorial, we’re going to pretend that the IP for this server is Replace with your actual IP from here on out.]

First, log in to your new Virtualmin control panel at


Step 8: Disable Mailman

Unless you want to have Mailman based mailing lists, you need to disable that feature in Virtualmin before we go much farther. Go to System Settings -> Features and Plugins, and in there you can disable the Mailman feature and Save.

Congrats! You have a functioning Virtualmin server. It’s not quite ready to rumble though. There are some tweaks that need to be made. DNS doesn’t work out of the box, and there’s no spam filtering. We’ll fix those things and more. Here is what you should see:

A brand new Virtualmin install


Step 9: Configure DNS so that it answers queries for your zones

For this we’re going to replaced the named.conf configuration file. It’s easy to do. Copy the config file from below, then make a backup copy of the config, and paste the new configuration into a fresh file. Here are the steps:

[root@server ~]# cd /etc/
[root@server /etc]# cp named.conf named.conf.bak
[root@server /etc]# > named.conf
[root@server /etc]# nano named.conf

Now paste in the following:

 // named.conf
 // Provided by Red Hat bind package to configure the ISC BIND named(8) DNS
 // server as a caching only nameserver (as a localhost DNS resolver only).
 // See /usr/share/doc/bind*/sample/ for example named configuration files.

options {
 directory "/var/named";
 dump-file "/var/named/data/cache_dump.db";
 statistics-file "/var/named/data/named_stats.txt";
 memstatistics-file "/var/named/data/named_mem_stats.txt";

 - If you are building an AUTHORITATIVE DNS server, do NOT enable recursion.
 - If you are building a RECURSIVE (caching) DNS server, you need to enable
 - If your recursive DNS server has a public IP address, you MUST enable access
 control to limit queries to your legitimate users. Failing to do so will
 cause your server to become part of large scale DNS amplification
 attacks. Implementing BCP38 within your network would greatly
 reduce such attack surface
 recursion no;

dnssec-enable yes;
 dnssec-validation yes;

/* Path to ISC DLV key */
 bindkeys-file "/etc/named.iscdlv.key";

managed-keys-directory "/var/named/dynamic";

pid-file "/run/named/";
 session-keyfile "/run/named/session.key";
 allow-recursion {
 allow-query { any; };

logging {
 channel default_debug {
 file "data/";
 severity dynamic;

zone "." IN {
 type hint;
 file "";

include "/etc/named.rfc1912.zones";
 include "/etc/named.root.key";

Save the file and exit, then restart BIND with the following command:

systemctl restart named

Now your server will serve zone files correctly when you start installing accounts.


10: Add PHP 5.6 with OPcache

This step is optional. Virtualmin comes with PHP 5.4.16 out of the box, but I wanted something more modern than that, and faster. PHP 5.6 with OPcache fits the bill and is pretty easy to install. We’ll need to follow a few steps to get it installed. You can paste these in, but I recommend doing it one-by-one.

yum -y install scl-utils
yum install centos-release-scl-rh
yum -y install rh-php56 rh-php56-php-mysqlnd rh-php56-php-opcache
systemctl restart httpd

This will install php 5.6 in /opt/rh/rh-php56/root/bin/php, and all its tools are there. If you need to install a pear module for php 5.6, you’d use /opt/rh/rh-php56/root/bin/pear rather than /usr/bin/pear which is configured for php 5.4. Virtualmin will automatically assign the newest PHP version available, but it is fairly simple to assign PHP 5.4 to a directory or an entire account, for compatibility reasons.

11: Add RBL’s and whitelisting to Postfix

Every so often you might get someone who is unable to contact an address on your server because their ISP or host is on a Realtime Block List. So, you can configure Postfix to whitelist just that users email address, or even the entire domain. For that we need to create the files that contain the domain names or email addresses, and use Postmap to put them into a hash format that Postfix understands. Paste in the following lines:

touch /etc/postfix/rbl_override /etc/postfix/sender_access
postmap /etc/postfix/rbl_override
postmap /etc/postfix/sender_access

If you want to exclude an IP from being checked by the Realtime Block List checks, then simply add the following line to /etc/postfix/rbl_override (use the actual IP, not this example!): OK

then run

postmap /etc/postfix/rbl_override; postfix reload

to enact the changes. The same format goes for sender_access. Run postmap on it and then do a postfix reload. The format for sender_access is: OK REJECT

Did I mention you can block specific addresses this way too? You can block specific addresses this way too 😉

Now we need to edit Postfix’s main configuration file: Let’s make a backup first, just in case:

cp /etc/postfix/ /etc/postfix/

Now edit the file:

nano /etc/postfix/

If you’re using nano, just press ctrl+k to remove the line, and then paste in its replacement.

Replace the following line:

smtpd_recipient_restrictions = permit_mynetworks permit_sasl_authenticated reject_unauth_destination

With the following:

smtpd_recipient_restrictions = 
 check_client_access hash:/etc/postfix/rbl_override,
 check_sender_access hash:/etc/postfix/sender_access,

Now we need to tell Postfix to refresh its configuration:

postfix reload

12: Fix Poodle

Apache comes setup to allow vulnerable versions of the SSL protocol to be used, which can allow a data breach. So lets plug the hole. Edit the Apache configuration file:

nano /etc/httpd/conf/httpd.conf

Find the “SSLProtocol” line and add “-SSLv3” to it so that it looks like this:

SSLProtocol ALL -SSLv2 -SSLv3

Now restart Apache to load the new configuration.

systemctl restart httpd


13: Tweak MySQL

Now lets fix up MySQL to be just a bit more thrifty with memory usage. Use nano (or your favorite editor) to open /etc/my.cnf and locate the following lines:

 innodb_file_per_table = 1

After those lines, paste in the following:

 innodb_buffer_pool_size = 64M
 myisam_sort_buffer_size = 8M
 read_rnd_buffer_size = 512K
 net_buffer_length = 8K
 read_buffer_size = 256K
 sort_buffer_size = 512K
 table_open_cache = 64
 max_allowed_packet = 1M
 key_buffer_size = 16M

Save the file, and then restart MySQL (MariaDB)

systemctl restart mariadb

14: Tweak OPcache

We don’t want OPCache to use more memory that it needs. It’s best to start small and go bigger if needed. Lets go into the php 5.6 configuration directory:

cd /etc/opt/rh/rh-php56/php.d

Now we’ll back up our configuration just in case:

cp 10-opcache.ini 10-opcache.ini.orig

Now clear then edit the opcached config file:

> 10-opcache.ini
 nano 10-opcache.ini

Paste in the following:

Now restart Apache:

systemctl restart httpd

Now you can use OPcache for your sites. Here’s a good script for monitoring it from a web page:


15: Install Advanced Policy Firewall/Brute Force Detector

APF is the Advanced Policy Firewall, BFD is Brute Force Detector. BFD works with APF to ban IP’s that are trying to brute force their way into accounts, which negates the need for fail2ban. They are generally good, and are open source. You can read about APF and BFD here:

First we need to install them:

 tar -zxf bfd-current.tar.gz
 tar -zxf apf-current.tar.gz
 cd apf-9.7-2

Now we need to configure it to allow ports for our server, including Virtualmin.

nano /etc/apf/conf.apf

Look for the following lines (search for the value before the = sign) and remove them, and replace them with the lines below:


Now you’ll need to restart APF:

apf -r

Make sure you can still log in remotely from another ssh session, and also make sure that virtualmin is still answering on port :10000 by going to your Virtualmin control panel. If all is well, then edit /etc/apf/conf.apf again, and change




Now restart apf again with apf -r.

apf -r

Now we must configure BFD, and this part is very easy.

cd /root/bfd-1.5-2/


Finishing up:

Service/Server SSL

The next steps for setting up your server are fairly basic, so I won’t explain how to do this step-by-step. You’ll want to install a Virtualmin account for the servers hostname, such as “”, and make sure that SSL is enabled for it when creating it. Then create an SSL certificate for it with the LetsEncrypt module. Make sure to create the SSL certificate so it matches your full hostname and domain name such as “”, and copy that SSL certificate to Webmin and Usermin and the other services. That’ll encrypt your control panel so you don’t have SSL errors.

Post-Installation Wizard

Run the Virtualmin post-installation wizard. If you have a small VPS, select the low-memory options. Leave the mysql password blank, and don’t edit the configuration since we already did that.

Setting up DNS for Web Hosting

You’ll also need to create A records in the zone file for for ns1 and, and point them at your servers IP address. Then go to your registrar for your domain name, and register those name servers. Then you can point your domain to ns1 and, and it’ll work when you create a hosting account for it.


There’s certainly a lot more that can be done with the server configuration. I prefer to have watchdog scripts to make sure I’m alerted if the mail queue gets too big (an indicator of a compromised account) and get weekly reports on the effectiveness of my spam blocking.

More Information

For more information about the exact use of Virtualmin, I recommend checking out the second half of the following tutorial for some nice screen shots and explanations of features: