26 lines
1.3 KiB
Markdown
26 lines
1.3 KiB
Markdown
---
|
|
layout: post
|
|
title: Anonymizing IPs Using HAProxy
|
|
description: "Description of how to easily anonymize IPs using HAProxy."
|
|
date: 2016-01-31 17:46:00 CET
|
|
category: posts
|
|
tags: [haproxy, ops, english]
|
|
comments: true
|
|
---
|
|
|
|
At work, I had to come up with an easy way to anonymize the last octet of a logged IP address in order to comply with German data protection laws. If you're using [HAProxy](http://www.haproxy.org) (1.5+), you can do this in one line.
|
|
|
|
If you want to forward the source IP address to a backend server, you would usually use `option forwardfor`. Sadly you can't set or change the forwarded IP using that option, so instead you have to set the `X-Forwarded-For` header manually.
|
|
|
|
{% highlight text %}
|
|
http-request set-header X-Forwarded-For %[src,ipmask(24)]
|
|
{% endhighlight %}
|
|
|
|
This will set the last octet of the source IP address to zero.
|
|
|
|
The HAProxy documentation has more information on the various things I used in this post:
|
|
|
|
* [option forwardfor](https://cbonte.github.io/haproxy-dconv/configuration-1.5.html#4-option%20forwardfor)
|
|
* [http-request](https://cbonte.github.io/haproxy-dconv/configuration-1.5.html#4-http-request)
|
|
* [src sample](https://cbonte.github.io/haproxy-dconv/configuration-1.5.html#7.3.3-src)
|
|
* [ipmask converter](https://cbonte.github.io/haproxy-dconv/configuration-1.5.html#7.3.1-ipmask)
|