arch-ppa/src/force_bind/force_bind.1

188 lines
4.6 KiB
Groff

.TH FORCE_BIND "1"
.SH NAME
FORCE_BIND
.SH AUTHOR
Catalin(ux) M. BOIE \- catab at embedromix dot ro
.SH DESCRIPTION
Force an application to bind on a specific IP and/or port. Plus forcing setsockopt calls on the socket. Works with both IPv4 and IPv6.
.TP
It is useful if you have a binary application without sources and without the possibility to configure address or port to bind to.
.SH LICENSE
GPLv3
.SH HOW IT WORKS
force_bind is a shared object that is loaded with LD_PRELOAD and hooks 'bind' function. Forcing an IP/port to bind to is done with environments variables.
.SH EXAMPLES
0. Output debug stuff in a log file (for debugging):
.TP
\fB export FORCE_NET_VERBOSE=999
.TP
\fB export FORCE_NET_LOG="xxx.log"
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
1. Force bind to 127.0.0.1, port 33, verbose operations:
.TP
\fB export FORCE_NET_VERBOSE=1
.TP
\fB export FORCE_BIND_ADDRESS_V4=127.0.0.1
.TP
\fB export FORCE_BIND_PORT_V4=33
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
2. Force binding to 127.0.0.2, port unchanged
.TP
\fB export FORCE_BIND_ADDRESS_V4=127.0.0.2
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
3. Force binding to ::1 (IPv6), port unchanged
.TP
\fB export FORCE_BIND_ADDRESS_V6=::1
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
4. Changing TOS on all sockets to 30
.TP
\fB export FORCE_NET_TOS=30
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
5. Force Keep alive to 60 seconds:
.TP
\fB export FORCE_NET_KA=60
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
6. Force MSS to 1400
.TP
\fB export FORCE_NET_MSS=1400
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
7. Force bandwidth to 1000 bytes/s for _all_ connections, cumulated
.TP
\fB export FORCE_NET_BW=1000
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
8. Force bandwidth to 20000 bytes/s per socket
.TP
\fB export FORCE_NET_BW_PER_SOCKET=20000
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
9. Force REUSEADDR
.TP
\fB export FORCE_NET_REUSEADDR=1
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
10. Force NODELAY
.TP
\fB export FORCE_NET_NODELAY=1
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
11. Force client connections (for example 'telnet', 'ssh', 'firefox') to connect from a specified address, not the auto selected one:
.TP
\fB export FORCE_NET_VERBOSE=1
.TP
\fB export FORCE_BIND_ADDRESS_V4=127.0.0.2
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
12. Set a FLOWINFO (flow label + class) for a client connection:
.TP
\fB export FORCE_NET_VERBOSE=1
.TP
\fB export FORCE_NET_FLOWINFO=0x7812345 # class 0x78, label 0x12345
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
13. Force FWMARK on a connection (only root can do it):
.TP
\fB export FORCE_NET_VERBOSE=1
.TP
\fB export FORCE_NET_FWMARK=0x1234
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
14. Force priority (between 0 and 6 for non-root users). You can use 'tc' command from iproute to set-up 'prio' qdisc and to assign prio to queues:
.TP
\fB # 0. setup
.TP
\fB export FORCE_NET_VERBOSE=1
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB # 1. Make sure you have a 'prio' qdisc attached to eth0, for example:
.TP
\fB tc qdisc add ev eth0 root handle 1: prio
.TP
\fB # 2. Assign applications to classed (bands):
.TP
\fB export FORCE_NET_PRIO=6 # interactive, band 0
.TP
\fB your_voip_program_here
.TP
\fB export FORCE_NET_PRIO=0 # best effort, band 1
.TP
\fB your_mail_program_here
.TP
\fB export FORCE_NET_PRIO=2 # bulk, band 2
.TP
\fB your_remote_backup_program_here
.TP
\fB # 3. Run tc statistics so you can see the classification:
.TP
\fB tc -s class show dev eth0
.TP
15. Deny binding to any IPv4 sockets. The bind syscall will return -1 and errno will be set to EACCES.
.TP
\fB export FORCE_NET_VERBOSE=1
.TP
\fB export FORCE_BIND_ADDRESS_V4=deny
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here
.TP
16. Silent fake binding to any IPv6 sockets. The bind will return success, but will never accept any connection.
.TP
\fB export FORCE_NET_VERBOSE=1
.TP
\fB export FORCE_BIND_ADDRESS_V6=fake
.TP
\fB export LD_PRELOAD=${LD_PRELOAD}:/usr/lib/force_bind.so
.TP
\fB your_program_here