My company has enforced an HTTP proxy requirement on my work computer. That effectively makes the computer unusable for web related work unless I hook it up to the corporate network using a VPN connection. So a local Squid proxy to the rescue!
I create a local domain using the same naming scheme that my work has, create a DNS entry mirroring the proxy host and setup a basic caching Squid proxy.
I choose this setup: https://github.com/sameersbn/docker-squid and forked the repo to my own GitHub account (https://github.com/mry/docker-squid and added my own customizations.
data:image/s3,"s3://crabby-images/ee0b2/ee0b21eab69e91b68cfa3038cb87e8046134e5bf" alt=""
Create the Docker image
docker build -t emryl/squid github.com/mry/docker-squid |
data:image/s3,"s3://crabby-images/e7333/e73339cdc965bf9cc11274594e0b971cbbdfe8b4" alt=""
Login to DockerHub
docker login |
data:image/s3,"s3://crabby-images/1daae/1daae3d11d89e90822e922e3b656aec9d242575d" alt=""
Push image to Docker Hub
docker push |
data:image/s3,"s3://crabby-images/b133a/b133aae168d76d29447d92540d21dc3a49d1f923" alt=""
Running using docker-compose
I set it up to run on my Synology NAS instance. I’ve create the neccessary folder structure according to the volume listing in the docker-compose.yml file.
When first run, it will download the image I uploaded in the previous step. On first run, omit the -d (for daemon) to see the container starts up without issues.
data:image/s3,"s3://crabby-images/65371/653714ca920510dbe6448aa9a8a091486b34eab5" alt=""
data:image/s3,"s3://crabby-images/26b98/26b98feef6959c4519e3c6c21b14fc290a375378" alt=""
Check the mapped folders are used
data:image/s3,"s3://crabby-images/ce886/ce88602b3d618f179a16f239c2adca243f6731c1" alt=""
Check if Squid is reachable
Then configure the HTTP proxy setting in the client for port 8080.
data:image/s3,"s3://crabby-images/80e15/80e152806b01b89d386b26527120a495bf91d7c5" alt=""