Skip to content

Commit

Permalink
feat(riklet): allow microVM to access network
Browse files Browse the repository at this point in the history
Signed-off-by: AlexandreBrg <[email protected]>
  • Loading branch information
alexandrebrg committed May 12, 2023
1 parent f44d3b8 commit 42a3754
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 9 deletions.
8 changes: 5 additions & 3 deletions riklet/src/runtime/function_runtime.rs
Original file line number Diff line number Diff line change
Expand Up @@ -240,11 +240,13 @@ impl RuntimeManager for FunctionRuntimeManager {
serde_json::from_str(workload.definition.as_str())
.map_err(RuntimeError::ParsingError)?;

let fn_config = FnConfiguration::load().map_err(|e| RuntimeError::Error(e.to_string()))?;

Ok(Box::new(FunctionRuntime {
function_config: FnConfiguration::load()
.map_err(|e| RuntimeError::Error(e.to_string()))?,
function_config: fn_config.clone(),
file_path: self.create_fs(&workload_definition)?,
network: FunctionRuntimeNetwork::new(&workload).map_err(RuntimeError::NetworkError)?,
network: FunctionRuntimeNetwork::new(&workload, fn_config.iface)
.map_err(RuntimeError::NetworkError)?,
machine: None,
id: workload.instance_id,
}))
Expand Down
31 changes: 25 additions & 6 deletions riklet/src/runtime/network/function_network.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ use std::net::Ipv4Addr;
use tracing::{debug, error};

use crate::constants::DEFAULT_FIRECRACKER_NETWORK_MASK;
use crate::iptables::Chain;
use crate::net_utils::{self, get_iptables_riklet_chain};
use crate::{
iptables::{rule::Rule, Iptables, MutateIptables, Table},
Expand All @@ -28,6 +29,10 @@ pub struct FunctionRuntimeNetwork {
/// A unique name for the tap interface
pub tap: Option<String>,
pub iptables: Iptables,

/// Name of the interface that is detected to be the one giving externel
/// access to the network
gateway_iface: String,
}

impl FunctionRuntimeNetwork {
Expand All @@ -40,7 +45,7 @@ impl FunctionRuntimeNetwork {
/// The IPv4 range given to the machine will be taken from the global
/// [IP_ALLOCATOR] which is a singleton that keeps track of the available
/// IPv4 networks
pub fn new(workload: &InstanceScheduling) -> Result<Self> {
pub fn new(workload: &InstanceScheduling, gateway_iface: String) -> Result<Self> {
let mask_long: &str = "255.255.255.252";

let workload_definition: WorkloadDefinition =
Expand All @@ -64,6 +69,7 @@ impl FunctionRuntimeNetwork {

Ok(FunctionRuntimeNetwork {
mask_long: mask_long.to_string(),
gateway_iface,
host_ip,
guest_ip,
identifier: workload.instance_id.clone(),
Expand All @@ -80,8 +86,20 @@ impl FunctionRuntimeNetwork {
.ok_or_else(|| NetworkError::Error("Tap interface name not found".to_string()))
}

fn generate_iptables_rules(&self) -> Vec<Rule> {
fn generate_iptables_rules(&self) -> Result<Vec<Rule>> {
let mut rules = Vec::new();
// nat network
let rule = Rule {
rule: format!(
"-i {} -o {} -j ACCEPT",
self.tap_name()?,
self.gateway_iface,
),
table: Table::Filter,
chain: Chain::Forward,
};
rules.push(rule);
// port mapping
for (exposed_port, internal_port) in self.port_mapping.iter() {
let rule = Rule {
rule: format!(
Expand All @@ -93,14 +111,14 @@ impl FunctionRuntimeNetwork {
};
rules.push(rule);
}
rules
Ok(rules)
}

/// Insert new iptables rules to forward traffic from host to guest
#[tracing::instrument(skip(self), fields(instance_id = %self.identifier))]
fn up_routing(&mut self) -> Result<()> {
debug!("Create iptables rules");
let rules = self.generate_iptables_rules();
let rules = self.generate_iptables_rules()?;
for rule in rules {
self.iptables
.create(&rule)
Expand All @@ -113,7 +131,7 @@ impl FunctionRuntimeNetwork {
#[tracing::instrument(skip(self), fields(instance_id = %self.identifier))]
fn down_routing(&mut self) -> Result<()> {
debug!("Delete iptables rules");
let rules = self.generate_iptables_rules();
let rules = self.generate_iptables_rules()?;
for rule in rules {
self.iptables
.delete(&rule)
Expand Down Expand Up @@ -190,7 +208,7 @@ mod tests {

use crate::{
iptables::{rule::Rule, Iptables, MutateIptables, Table},
net_utils::get_iptables_riklet_chain,
net_utils::{get_default_iface, get_iptables_riklet_chain},
runtime::network::{GlobalRuntimeNetwork, RuntimeNetwork},
};

Expand Down Expand Up @@ -240,6 +258,7 @@ mod tests {
) -> FunctionRuntimeNetwork {
FunctionRuntimeNetwork {
identifier: "test".to_string(),
gateway_iface: get_default_iface().unwrap(),
mask_long: "255.255.255.200".to_string(),
host_ip: Ipv4Addr::new(10, 0, 0, 2),
guest_ip: Ipv4Addr::new(10, 0, 0, 1),
Expand Down

0 comments on commit 42a3754

Please sign in to comment.