1、init
init函数:进行flannelFlags的初始化,有etcd、iface(网卡)、iface-regex(接口匹配正则)、subnetFile(子网配置)、public-ip(外部访问IP)、subnet-lease-renew-margin(租约)、ip-masq(ip伪装,SNAT)、kube-subnet-mgr(subnet api)、kube-api-url(api server url)、kubeconfig-file(kube配置文件)、healthz(healthz地址访问)、iptables(iptables规则)、net-config-path(网络配置,/etc/kube-flannel/net-conf.json)
2、 main
-
SetFlagsFromEnv解析flannelFlags
-
判断租约是否在有效范围内
-
LookupExtIface查找可用接口
-
使用iface-regex匹配接口是否合法
-
newSubnetManager创建子网,若设置子网管理则返回NewSubnetManager,否则使用默认etcd做子网管理
-
使用Notify注册SIGTERM用来停止服务使用
-
若指定了Healthz,则创建协程执行mustRunHealthz
-
getConfig获取网络配置,会调用GetNetworkConfig
type Config struct { Network ip.IP4Net SubnetMin ip.IP4 SubnetMax ip.IP4 SubnetLen uint BackendType string `json:"-"` Backend json.RawMessage `json:",omitempty"` }
-
NewManager创建后端管理器并通过GetBackend根据配置中指定的类型创建后端
-
RegisterNetwork注册网络,每种后端都有RegisterNetwork,这里根据之前的后端类型执行指定的RegisterNetwork
-
若指定了ipMasq,则SetupAndEnsureIPTables设置MasqRules和iptables foward rules
-
WriteSubnetFile写subnet文件,默认为 /run/flannel/subnet.env
-
启动后端bn.Run(ctx),创建协程调用WatchLeases对子网租约进行一个长期监视,并通过在管道上添加/删除事件,当添加事件就有通过管道触发handleSubnetEvents处理事件,去操作route、arp、fdb