Guide: How to setup a VPS proxy
This guide will explain how you can use your Virtual Private Server (VPS) as a proxy. We are going to setup Squid (http://www.squid-cache.org/) as a running service on your Linux webserver.
1. Installing Squid
First, we have to install the required packages (press Y to confirm installation):
apt update apt install squid apache2-utils
Immediately after this, run service squid stop
to stop the proxy from running since we need
to do a few security changes first.
You can check your Squid version like so:
squid -v
It should show the version somewhere, like Squid Cache: Version 3.5.12.
2. Configuring Squid
Next, the configuration file for Squid /etc/squid/squid.conf
will have to be updated
to activate some security measures.
The code below makes a backup copy of the configuration file, and strips all comments to make it easier to edit in the next step:
cd /etc/squid mv squid.conf squid.conf.backup grep -o '^[^#]*' squid.conf.backup > squid.conf
You should now have a /etc/squid/squid.conf
file with roughly 20-30 lines of code. Open
this file using
nano /etc/squid/squid.confwhich opens this file in the nano text editor.
Once opened, you have to copy the highlighted text below into your configuration file. This includes:
- Defining which file contains the username+password for accessing your proxy (
/etc/squid/.passwd
). - Change the default proxy port 3128 to another port like
5554
. This step is optional but recommended.
If you are not familiar with the nano text-editor, a simple way to update this file is to manually backspace the lines you don't need, and type over the highlighted lines below. Once done, press CTRL + X, Y and Enter to save and close the file.
Original file
acl SSL_ports port 443 acl Safe_ports port 80 acl Safe_ports port 21 acl Safe_ports port 443 acl Safe_ports port 70 acl Safe_ports port 210 acl Safe_ports port 1025-65535 acl Safe_ports port 280 acl Safe_ports port 488 acl Safe_ports port 591 acl Safe_ports port 777 acl CONNECT method CONNECT http_access deny !Safe_ports http_access deny CONNECT !SSL_ports http_access allow localhost manager http_access deny manager http_access allow localhost http_access deny all http_port 3128 coredump_dir /var/spool/squid refresh_pattern ^ftp: 1440 20% 10080 refresh_pattern ^gopher: 1440 0% 1440 refresh_pattern -i (/cgi-bin/|\?) 0 0% 0 refresh_pattern (Release|Packages(.gz)*)$ 0 20% 2880 refresh_pattern . 0 20% 4320
Updated file
acl SSL_ports port 443
acl Safe_ports port 80
acl Safe_ports port 21
acl Safe_ports port 443
acl Safe_ports port 70
acl Safe_ports port 210
acl Safe_ports port 1025-65535
acl Safe_ports port 280
acl Safe_ports port 488
acl Safe_ports port 591
acl Safe_ports port 777
acl CONNECT method CONNECT
http_access deny !Safe_ports
http_access deny CONNECT !SSL_ports
auth_param basic program /usr/lib/squid/basic_ncsa_auth /etc/squid/.passwd
auth_param basic realm proxy
acl authenticated proxy_auth REQUIRED
http_access allow authenticated
http_port 5554
coredump_dir /var/spool/squid
refresh_pattern ^ftp: 1440 20% 10080
refresh_pattern ^gopher: 1440 0% 1440
refresh_pattern -i (/cgi-bin/|\?) 0 0% 0
refresh_pattern (Release|Packages(.gz)*)$ 0 20% 2880
refresh_pattern . 0 20% 4320
3. Defining a proxy password
Now, we are going to create the .passwd
file in the /etc/squid
directory,
with a username+password of your choosing.
The code below adds a user named autobumper
with the password 1L6BLzFbgcyiL0VDf9O1FdAp
(you are free
to copy this password since it is randomly generated when you refresh this page):
cd /etc/squid htpasswd -vb .passwd autobumper 1L6BLzFbgcyiL0VDf9O1FdAp chown proxy:proxy .passwd chmod 600 .passwd
Once done, you should now have a /etc/squid/.passwd
file assigned to the proxy:proxy
user.
You can check the contents using this command (which should show a hashed version of your password):
cat .passwd
4. Finishing up
Once you have completed all steps above, you are ready to start your squid proxy. Execute the following command:
service squid restart
This may take a minute, but after that your proxy should be up and running.
Depending on your server setup, you might have ufw
active which is a Linux firewall.
In order to access your proxy, you might still need to execute the following command
to open up port 5554
as defined in your configuration file:
ufw allow 5554/tcp
5. Testing and using your proxy on autobumper.io
Now, to use the proxy with autobumper.io, go to your profile here, and fill in the following details:
- Type HTTP
- Host Your VPS IP
- Port 5554 (or whichever port you defined in
squid.conf
) - Username autobumper (or whichever username is shown in
.passwd
) - Password 1L6BLzFbgcyiL0VDf9O1FdAp (or whichever password is hashed in
.passwd
)
Lastly, press the Test Proxy button which should show a success message.
Alternatively, you can test your proxy using cURL like so:
curl https://autobumper.io/ping -x http://autobumper:1L6BLzFbgcyiL0VDf9O1FdAp@111.111.111.111:5554
You can then check the checkbox "Enable this proxy for all threads" to have every autobumper request go through your proxy. Forums will now see all your posts as coming from your VPS IP address instead of the autobumper rotating proxy.