mirror of
https://github.com/moparisthebest/arch-ppa
synced 2024-10-31 15:25:02 -04:00
188 lines
4.6 KiB
Groff
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
|