-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathstart-firecracker.sh
executable file
·127 lines (106 loc) · 2.99 KB
/
start-firecracker.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
#!/bin/bash -e
SB_ID="${1:-0}" # Default to sb_id=0
RO_DRIVE="$PWD/xenial.rootfs.ext4"
KERNEL="$PWD/vmlinux"
TAP_DEV="fc-${SB_ID}-tap0"
KERNEL_BOOT_ARGS="init=/sbin/boottime_init panic=1 pci=off reboot=k tsc=reliable quiet 8250.nr_uarts=0 ipv6.disable=1"
#KERNEL_BOOT_ARGS="console=ttyS0 reboot=k panic=1 pci=off nomodules ipv6.disable=1"
API_SOCKET="/tmp/firecracker-sb${SB_ID}.sock"
CURL=(curl --silent --show-error --header Content-Type: application/json --unix-socket "${API_SOCKET}" --write-out "HTTP %{http_code}")
curl_put() {
local URL_PATH="$1"
local OUTPUT RC
OUTPUT="$("${CURL[@]}" -X PUT --data @- "http://localhost/${URL_PATH#/}" 2>&1)"
RC="$?"
if [ "$RC" -ne 0 ]; then
echo "Error: curl PUT ${URL_PATH} failed with exit code $RC, output:"
echo "$OUTPUT"
return 1
fi
# Error if output doesn't end with "HTTP 2xx"
if [[ "$OUTPUT" != *HTTP\ 2[0-9][0-9] ]]; then
echo "Error: curl PUT ${URL_PATH} failed with non-2xx HTTP status code, output:"
echo "$OUTPUT"
return 1
fi
}
logfile="$PWD/output/fc-sb${SB_ID}-log"
#metricsfile="$PWD/output/fc-sb${SB_ID}-metrics"
metricsfile="/dev/null"
touch $logfile
# Setup TAP device that uses proxy ARP
MASK_LONG="255.255.255.252"
#MASK_SHORT="/30"
FC_IP="$(printf '169.254.%s.%s' $(((4 * SB_ID + 1) / 256)) $(((4 * SB_ID + 1) % 256)))"
TAP_IP="$(printf '169.254.%s.%s' $(((4 * SB_ID + 2) / 256)) $(((4 * SB_ID + 2) % 256)))"
FC_MAC="$(printf '02:FC:00:00:%02X:%02X' $((SB_ID / 256)) $((SB_ID % 256)))"
#ip link del "$TAP_DEV" 2> /dev/null || true
#ip tuntap add dev "$TAP_DEV" mode tap
#sysctl -w net.ipv4.conf.${TAP_DEV}.proxy_arp=1 > /dev/null
#sysctl -w net.ipv6.conf.${TAP_DEV}.disable_ipv6=1 > /dev/null
#ip addr add "${TAP_IP}${MASK_SHORT}" dev "$TAP_DEV"
#ip link set dev "$TAP_DEV" up
KERNEL_BOOT_ARGS="${KERNEL_BOOT_ARGS} ip=${FC_IP}::${TAP_IP}:${MASK_LONG}::eth0:off"
# Start Firecracker API server
rm -f "$API_SOCKET"
./firecracker --api-sock "$API_SOCKET" --id "${SB_ID}" --boot-timer &>/dev/null &
sleep 0.015s
# Wait for API server to start
while [ ! -e "$API_SOCKET" ]; do
echo "FC $SB_ID still not ready..."
sleep 0.01s
done
curl_put '/logger' <<EOF
{
"level": "Info",
"log_path": "$logfile",
"show_level": false,
"show_log_origin": false
}
EOF
curl_put '/metrics' <<EOF
{
"metrics_path": "$metricsfile"
}
EOF
#curl_put '/machine-config' <<EOF
#{
# "vcpu_count": 1,
# "mem_size_mib": 128
#}
#EOF
curl_put '/boot-source' <<EOF
{
"kernel_image_path": "$KERNEL",
"boot_args": "$KERNEL_BOOT_ARGS"
}
EOF
curl_put '/drives/1' <<EOF
{
"drive_id": "1",
"path_on_host": "$RO_DRIVE",
"is_root_device": true,
"is_read_only": true
}
EOF
#
#curl_put '/drives/2' <<EOF
#{
# "drive_id": "2",
# "path_on_host": "$RW_DRIVE",
# "is_root_device": false,
# "is_read_only": false
#}
#EOF
curl_put '/network-interfaces/1' <<EOF
{
"iface_id": "1",
"guest_mac": "$FC_MAC",
"host_dev_name": "$TAP_DEV"
}
EOF
curl_put '/actions' <<EOF
{
"action_type": "InstanceStart"
}
EOF