make public ip infra
Signed-off-by: GnomeZworc <nicolas.boufidjeline@g3e.fr>
This commit is contained in:
parent
f81a4d959c
commit
a4cd5bce4d
4 changed files with 65 additions and 37 deletions
28
lib/public_ip.sh
Normal file
28
lib/public_ip.sh
Normal file
|
|
@ -0,0 +1,28 @@
|
|||
#!/bin/bash
|
||||
|
||||
function add_public_ip {
|
||||
local vpc_name="${1}"
|
||||
local public_ip="${2}"
|
||||
local private_ip="${3}"
|
||||
local host_ip="${4}"
|
||||
|
||||
ip -n "${vpc_name}" a add "${public_ip}/32" dev br-public
|
||||
ip r add "${public_ip}" dev br-public scope link
|
||||
ip -n "${vpc_name}" r add "${host_ip}" dev br-public scope link
|
||||
ip -n "${vpc_name}" r add default via "${host_ip}"
|
||||
|
||||
ip netns exec "${vpc_name}" iptables -t nat -A PREROUTING -d "${public_ip}/32" -j DNAT --to-destination "${private_ip}"
|
||||
ip netns exec "${vpc_name}" iptables -t nat -A POSTROUTING -s "${private_ip}/32" -o br-public --to-source "${public_ip}" -j SNAT
|
||||
}
|
||||
|
||||
function delete_public_ip {
|
||||
local vpc_name="${1}"
|
||||
local public_ip="${2}"
|
||||
local private_ip="${3}"
|
||||
|
||||
ip -n "${vpc_name}" a del "${public_ip}/32" dev br-public
|
||||
ip r del "${public_ip}" dev br-public
|
||||
|
||||
ip netns exec "${vpc_name}" iptables -t nat -D PREROUTING -d "${public_ip}/32" -j DNAT --to-destination "${private_ip}"
|
||||
ip netns exec "${vpc_name}" iptables -t nat -D POSTROUTING -s "${private_ip}/32" -o br-public --to-source "${public_ip}" -j SNAT
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue