本文整理匯總了Golang中github.com/shaleman/libOpenflow/openflow13.NewActionOutput函數的典型用法代碼示例。如果您正苦於以下問題:Golang NewActionOutput函數的具體用法?Golang NewActionOutput怎麽用?Golang NewActionOutput使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了NewActionOutput函數的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: sendGARP
// sendGARP sends GARP for the specified IP, MAC
func (self *Vxlan) sendGARP(ip net.IP, mac net.HardwareAddr, vni uint64) error {
// NOTE: Enable this when EVPN support is added.
if !VXLAN_GARP_SUPPORTED {
return nil
}
pktOut := BuildGarpPkt(ip, mac, 0)
tunnelIdField := openflow13.NewTunnelIdField(vni)
setTunnelAction := openflow13.NewActionSetField(*tunnelIdField)
// Add set tunnel action to the instruction
pktOut.AddAction(setTunnelAction)
self.agent.vtepTableMutex.RLock()
for _, vtepPort := range self.agent.vtepTable {
log.Debugf("Sending to Vtep port: %+v", *vtepPort)
pktOut.AddAction(openflow13.NewActionOutput(*vtepPort))
}
self.agent.vtepTableMutex.RUnlock()
// Send it out
self.ofSwitch.Send(pktOut)
self.agent.incrStats("GarpPktSent")
return nil
}
示例2: GetOutAction
// Return an output action (Used by group mods)
func (self *Output) GetOutAction() openflow13.Action {
switch self.outputType {
case "drop":
return nil
case "toController":
outputAct := openflow13.NewActionOutput(openflow13.P_CONTROLLER)
// Dont buffer the packets being sent to controller
outputAct.MaxLen = openflow13.OFPCML_NO_BUFFER
return outputAct
case "port":
return openflow13.NewActionOutput(self.portNo)
}
return nil
}
示例3: GetFlowInstr
// instruction set for output element
func (self *Output) GetFlowInstr() openflow13.Instruction {
outputInstr := openflow13.NewInstrApplyActions()
switch self.outputType {
case "drop":
return nil
case "toController":
outputAct := openflow13.NewActionOutput(openflow13.P_CONTROLLER)
// Dont buffer the packets being sent to controller
outputAct.MaxLen = openflow13.OFPCML_NO_BUFFER
outputInstr.AddAction(outputAct, false)
case "port":
outputAct := openflow13.NewActionOutput(self.portNo)
outputInstr.AddAction(outputAct, false)
}
return outputInstr
}
示例4: processArp
// Process incoming ARP packets
func (self *Vrouter) processArp(pkt protocol.Ethernet, inPort uint32) {
log.Debugf("processing ARP packet on port %d", inPort)
switch t := pkt.Data.(type) {
case *protocol.ARP:
log.Debugf("ARP packet: %+v", *t)
var arpHdr protocol.ARP = *t
switch arpHdr.Operation {
case protocol.Type_Request:
// Lookup the Dest IP in the endpoint table
vlan := self.agent.portVlanMap[inPort]
if vlan == nil {
return
}
endpointId := self.agent.getEndpointIdByIpVlan(arpHdr.IPDst, *vlan)
endpoint := self.agent.endpointDb[endpointId]
if endpoint == nil {
// If we dont know the IP address, dont send an ARP response
log.Infof("Received ARP request for unknown IP: %v", arpHdr.IPDst)
return
}
// Form an ARP response
arpResp, _ := protocol.NewARP(protocol.Type_Reply)
arpResp.HWSrc = self.myRouterMac
arpResp.IPSrc = arpHdr.IPDst
arpResp.HWDst = arpHdr.HWSrc
arpResp.IPDst = arpHdr.IPSrc
log.Infof("Sending ARP response: %+v", arpResp)
// build the ethernet packet
ethPkt := protocol.NewEthernet()
ethPkt.HWDst = arpResp.HWDst
ethPkt.HWSrc = arpResp.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = arpResp
log.Infof("Sending ARP response Ethernet: %+v", ethPkt)
// Packet out
pktOut := openflow13.NewPacketOut()
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(inPort))
log.Infof("Sending ARP response packet: %+v", pktOut)
// Send it out
self.ofSwitch.Send(pktOut)
default:
log.Infof("Dropping ARP response packet from port %d", inPort)
}
}
}
示例5: sendGARP
// sendGARP sends GARP for the specified IP, MAC
func (vl *VlanBridge) sendGARP(ip net.IP, mac net.HardwareAddr, vlanID uint16) error {
pktOut := BuildGarpPkt(ip, mac, vlanID)
for _, portNo := range vl.uplinkDb {
log.Debugf("Sending to uplink: %+v", portNo)
pktOut.AddAction(openflow13.NewActionOutput(portNo))
// NOTE: Sending it on only one uplink to avoid loops
// Once MAC pinning mode is supported, this logic has to change
break
}
// Send it out
vl.ofSwitch.Send(pktOut)
return nil
}
示例6: sendArp
func (self *OfnetBgp) sendArp() {
//Get the Mac of the vlan intf
//Get the portno of the uplink
//Build an arp packet and send on portno of uplink
time.Sleep(5 * time.Second)
for {
if self.myBgpPeer == "" {
return
}
intf, _ := net.InterfaceByName(self.vlanIntf)
ofPortno, _ := self.agent.ovsDriver.GetOfpPortNo(self.vlanIntf)
bMac, _ := net.ParseMAC("FF:FF:FF:FF:FF:FF")
zeroMac, _ := net.ParseMAC("00:00:00:00:00:00")
srcIP := net.ParseIP(self.routerIP)
dstIP := net.ParseIP(self.myBgpPeer)
arpReq, _ := protocol.NewARP(protocol.Type_Request)
arpReq.HWSrc = intf.HardwareAddr
arpReq.IPSrc = srcIP
arpReq.HWDst = zeroMac
arpReq.IPDst = dstIP
log.Infof("Sending ARP Request: %+v", arpReq)
// build the ethernet packet
ethPkt := protocol.NewEthernet()
ethPkt.HWDst = bMac
ethPkt.HWSrc = arpReq.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = arpReq
log.Infof("Sending ARP Request Ethernet: %+v", ethPkt)
// Packet out
pktOut := openflow13.NewPacketOut()
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(ofPortno))
log.Infof("Sending ARP Request packet: %+v", pktOut)
// Send it out
self.agent.ofSwitch.Send(pktOut)
time.Sleep(1800 * time.Second)
}
}
示例7: getProxyARPResp
func getProxyARPResp(arpIn *protocol.ARP, tgtMac string, vid uint16, inPort uint32) *openflow13.PacketOut {
arpPkt, _ := protocol.NewARP(protocol.Type_Reply)
arpPkt.HWSrc, _ = net.ParseMAC(tgtMac)
arpPkt.IPSrc = arpIn.IPDst
arpPkt.HWDst = arpIn.HWSrc
arpPkt.IPDst = arpIn.IPSrc
log.Debugf("Sending Proxy ARP response: %+v", arpPkt)
// Build the ethernet packet
ethPkt := protocol.NewEthernet()
ethPkt.VLANID.VID = vid
ethPkt.HWDst = arpPkt.HWDst
ethPkt.HWSrc = arpPkt.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = arpPkt
log.Debugf("Sending Proxy ARP response Ethernet: %+v", ethPkt)
// Construct Packet out
pktOut := openflow13.NewPacketOut()
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(inPort))
return pktOut
}
示例8: processArp
/*processArp does the following :
1) Process incoming ARP packets
2) Proxy with Router mac if arp request is from local internal endpoint
3) Proxy with interface mac is arp request is from remote endpoint
4) Learn MAC,Port of the source if its not learnt and it is bgp peer endpoint
*/
func (self *Vlrouter) processArp(pkt protocol.Ethernet, inPort uint32) {
log.Debugf("processing ARP packet on port %d", inPort)
switch t := pkt.Data.(type) {
case *protocol.ARP:
log.Debugf("ARP packet: %+v", *t)
var arpHdr protocol.ARP = *t
var srcMac net.HardwareAddr
var intf *net.Interface
switch arpHdr.Operation {
case protocol.Type_Request:
// Lookup the Dest IP in the endpoint table
endpoint := self.agent.getEndpointByIp(arpHdr.IPDst)
if endpoint == nil {
//If we dont know the IP address, dont send an ARP response
log.Infof("Received ARP request for unknown IP: %v ", arpHdr.IPDst)
return
} else {
if endpoint.EndpointType == "internal" || endpoint.EndpointType == "internal-bgp" {
//srcMac, _ = net.ParseMAC(endpoint.MacAddrStr)
intf, _ = net.InterfaceByName(self.agent.GetRouterInfo().VlanIntf)
srcMac = intf.HardwareAddr
} else if endpoint.EndpointType == "external" || endpoint.EndpointType == "external-bgp" {
endpoint = self.agent.getEndpointByIp(arpHdr.IPSrc)
if endpoint != nil {
if endpoint.EndpointType == "internal" || endpoint.EndpointType == "internal-bgp" {
srcMac = self.myRouterMac
} else {
return
}
} else {
return
}
}
}
//Check if source endpoint is learnt.
endpoint = self.agent.getEndpointByIp(arpHdr.IPSrc)
if endpoint != nil && endpoint.EndpointType == "external-bgp" {
//endpoint exists from where the arp is received.
if endpoint.PortNo == 0 {
log.Infof("Received ARP from BGP Peer on %s: Mac: %s", endpoint.PortNo, endpoint.MacAddrStr)
//learn the mac address and portno for the endpoint
self.RemoveEndpoint(endpoint)
endpoint.PortNo = inPort
endpoint.MacAddrStr = arpHdr.HWSrc.String()
self.agent.endpointDb[endpoint.EndpointID] = endpoint
self.AddEndpoint(endpoint)
self.resolveUnresolvedEPs(endpoint.MacAddrStr, inPort)
}
}
// Form an ARP response
arpResp, _ := protocol.NewARP(protocol.Type_Reply)
arpResp.HWSrc = srcMac
arpResp.IPSrc = arpHdr.IPDst
arpResp.HWDst = arpHdr.HWSrc
arpResp.IPDst = arpHdr.IPSrc
log.Infof("Sending ARP response: %+v", arpResp)
// build the ethernet packet
ethPkt := protocol.NewEthernet()
ethPkt.HWDst = arpResp.HWDst
ethPkt.HWSrc = arpResp.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = arpResp
log.Infof("Sending ARP response Ethernet: %+v", ethPkt)
// Packet out
pktOut := openflow13.NewPacketOut()
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(inPort))
log.Infof("Sending ARP response packet: %+v", pktOut)
// Send it out
self.ofSwitch.Send(pktOut)
case protocol.Type_Reply:
endpoint := self.agent.getEndpointByIp(arpHdr.IPSrc)
if endpoint != nil && endpoint.EndpointType == "external-bgp" {
//endpoint exists from where the arp is received.
if endpoint.PortNo == 0 {
log.Infof("Received ARP from BGP Peer on %s: Mac: %s", endpoint.PortNo, endpoint.MacAddrStr)
//learn the mac address and portno for the endpoint
self.RemoveEndpoint(endpoint)
endpoint.PortNo = inPort
endpoint.MacAddrStr = arpHdr.HWSrc.String()
self.agent.endpointDb[endpoint.EndpointID] = endpoint
self.AddEndpoint(endpoint)
//.........這裏部分代碼省略.........
示例9: processArp
//.........這裏部分代碼省略.........
// No information about the src or dest EP. Drop the pkt.
if srcEp == nil && dstEp == nil {
log.Debugf("No information on source/destination. Ignoring ARP request.")
vl.agent.incrStats("ArpRequestUnknownSrcDst")
return
}
// if it came from uplink and the destination is not local, drop it
if fromUplink {
if dstEp == nil {
vl.agent.incrStats("ArpReqUnknownDestFromUplink")
return
}
if dstEp.OriginatorIp.String() != vl.agent.localIp.String() {
vl.agent.incrStats("ArpReqNonLocalDestFromUplink")
return
}
}
// If we know the dstEp to be present locally, send the Proxy ARP response
if dstEp != nil {
// Container to Container communication. Send proxy ARP response.
// Unknown node to Container communication
// -> Send proxy ARP response only if Endpoint is local.
// -> This is to avoid sending ARP responses from ofnet agent on multiple hosts
if srcEp != nil ||
(srcEp == nil && dstEp.OriginatorIp.String() == vl.agent.localIp.String()) {
// Send the packet out
pktOut := getProxyARPResp(&arpIn, dstEp.MacAddrStr,
pkt.VLANID.VID, inPort)
vl.ofSwitch.Send(pktOut)
vl.agent.incrStats("ArpReqRespSent")
return
}
}
proxyMac := vl.svcProxy.GetSvcProxyMAC(arpIn.IPDst)
if proxyMac != "" {
pktOut := getProxyARPResp(&arpIn, proxyMac,
pkt.VLANID.VID, inPort)
vl.ofSwitch.Send(pktOut)
return
}
if srcEp != nil && dstEp == nil {
// ARP request from local container to unknown IP
// Reinject ARP to uplinks
ethPkt := protocol.NewEthernet()
ethPkt.VLANID.VID = srcEp.EndpointGroupVlan
ethPkt.HWDst = pkt.HWDst
ethPkt.HWSrc = pkt.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = &arpIn
log.Infof("Received ARP request for unknown IP: %v. "+
"Reinjecting ARP request Ethernet to uplinks: %+v", arpIn.IPDst, ethPkt)
// Packet out
pktOut := openflow13.NewPacketOut()
pktOut.InPort = inPort
pktOut.Data = ethPkt
for _, portNo := range vl.uplinkDb {
log.Debugf("Sending to uplink: %+v", portNo)
pktOut.AddAction(openflow13.NewActionOutput(portNo))
}
// Send the packet out
vl.ofSwitch.Send(pktOut)
vl.agent.incrStats("ArpReqReinject")
}
case protocol.Type_Reply:
log.Debugf("Received ARP response packet: %+v from port %d", arpIn, inPort)
vl.agent.incrStats("ArpRespRcvd")
ethPkt := protocol.NewEthernet()
ethPkt.VLANID = pkt.VLANID
ethPkt.HWDst = pkt.HWDst
ethPkt.HWSrc = pkt.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = &arpIn
log.Debugf("Sending ARP response Ethernet: %+v", ethPkt)
// Packet out
pktOut := openflow13.NewPacketOut()
pktOut.InPort = inPort
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(openflow13.P_NORMAL))
log.Debugf("Reinjecting ARP reply packet: %+v", pktOut)
// Send it out
vl.ofSwitch.Send(pktOut)
}
}
}
示例10: processArp
// Process incoming ARP packets
func (self *Vrouter) processArp(pkt protocol.Ethernet, inPort uint32) {
log.Debugf("processing ARP packet on port %d", inPort)
switch t := pkt.Data.(type) {
case *protocol.ARP:
log.Debugf("ARP packet: %+v", *t)
var arpHdr protocol.ARP = *t
self.agent.incrStats("ArpPktRcvd")
switch arpHdr.Operation {
case protocol.Type_Request:
self.agent.incrStats("ArpReqRcvd")
var vlan *uint16
if vlan = self.agent.getPortVlanMap(inPort); vlan == nil {
self.agent.incrStats("ArpReqInvalidPortVlan")
return
}
tgtMac := self.myRouterMac
endpointId := self.agent.getEndpointIdByIpVlan(arpHdr.IPDst, *vlan)
endpoint := self.agent.getEndpointByID(endpointId)
if endpoint == nil {
// Look for a service entry for the target IP
proxyMac := self.svcProxy.GetSvcProxyMAC(arpHdr.IPDst)
if proxyMac == "" {
// If we dont know the IP address, dont send an ARP response
log.Debugf("Received ARP request for unknown IP: %v", arpHdr.IPDst)
self.agent.incrStats("ArpReqUnknownDest")
return
}
tgtMac, _ = net.ParseMAC(proxyMac)
}
// Form an ARP response
arpResp, _ := protocol.NewARP(protocol.Type_Reply)
arpResp.HWSrc = tgtMac
arpResp.IPSrc = arpHdr.IPDst
arpResp.HWDst = arpHdr.HWSrc
arpResp.IPDst = arpHdr.IPSrc
log.Debugf("Sending ARP response: %+v", arpResp)
// build the ethernet packet
ethPkt := protocol.NewEthernet()
ethPkt.HWDst = arpResp.HWDst
ethPkt.HWSrc = arpResp.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = arpResp
log.Debugf("Sending ARP response Ethernet: %+v", ethPkt)
// Packet out
pktOut := openflow13.NewPacketOut()
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(inPort))
log.Debugf("Sending ARP response packet: %+v", pktOut)
// Send it out
self.ofSwitch.Send(pktOut)
self.agent.incrStats("ArpReqRespSent")
default:
log.Debugf("Dropping ARP response packet from port %d", inPort)
self.agent.incrStats("ArpRespRcvd")
}
}
}
示例11: processArp
/*
* Process incoming ARP packets
* ARP request handling in various scenarios:
* Src and Dest EP known:
* - Proxy ARP if Dest EP is present locally on the host
* Src EP known, Dest EP not known:
* - ARP Request to a router/VM scenario. Reinject ARP request to uplinks
* Src EP not known, Dest EP known:
* - Proxy ARP if Dest EP is present locally on the host
* Src and Dest EP not known:
* - Ignore processing the request
*/
func (vl *VlanBridge) processArp(pkt protocol.Ethernet, inPort uint32) {
switch t := pkt.Data.(type) {
case *protocol.ARP:
log.Debugf("Processing ARP packet on port %d: %+v", inPort, *t)
var arpIn protocol.ARP = *t
switch arpIn.Operation {
case protocol.Type_Request:
// If it's a GARP packet, ignore processing
if arpIn.IPSrc.String() == arpIn.IPDst.String() {
log.Debugf("Ignoring GARP packet")
return
}
// Lookup the Source and Dest IP in the endpoint table
//Vrf derivation logic :
var vlan uint16
if vl.uplinkDb[inPort] != 0 {
//arp packet came in from uplink hence tagged
vlan = pkt.VLANID.VID
} else {
//arp packet came from local endpoints - derive vrf from inport
if vl.agent.portVlanMap[inPort] != nil {
vlan = *(vl.agent.portVlanMap[inPort])
} else {
log.Debugf("Invalid port vlan mapping. Ignoring arp packet")
return
}
}
srcEp := vl.agent.getEndpointByIpVlan(arpIn.IPSrc, vlan)
dstEp := vl.agent.getEndpointByIpVlan(arpIn.IPDst, vlan)
// No information about the src or dest EP. Ignore processing.
if srcEp == nil && dstEp == nil {
log.Debugf("No information on source/destination. Ignoring ARP request.")
return
}
// If we know the dstEp to be present locally, send the Proxy ARP response
if dstEp != nil {
// Container to Container communication. Send proxy ARP response.
// Unknown node to Container communication
// -> Send proxy ARP response only if Endpoint is local.
// -> This is to avoid sending ARP responses from ofnet agent on multiple hosts
if srcEp != nil ||
(srcEp == nil && dstEp.OriginatorIp.String() == vl.agent.localIp.String()) {
// Form an ARP response
arpPkt, _ := protocol.NewARP(protocol.Type_Reply)
arpPkt.HWSrc, _ = net.ParseMAC(dstEp.MacAddrStr)
arpPkt.IPSrc = arpIn.IPDst
arpPkt.HWDst = arpIn.HWSrc
arpPkt.IPDst = arpIn.IPSrc
log.Debugf("Sending Proxy ARP response: %+v", arpPkt)
// Build the ethernet packet
ethPkt := protocol.NewEthernet()
ethPkt.VLANID.VID = pkt.VLANID.VID
ethPkt.HWDst = arpPkt.HWDst
ethPkt.HWSrc = arpPkt.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = arpPkt
log.Debugf("Sending Proxy ARP response Ethernet: %+v", ethPkt)
// Construct Packet out
pktOut := openflow13.NewPacketOut()
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(inPort))
// Send the packet out
vl.ofSwitch.Send(pktOut)
return
}
}
if srcEp != nil && dstEp == nil {
// If the ARP request was received from uplink
// Ignore processing the packet
for _, portNo := range vl.uplinkDb {
if portNo == inPort {
log.Debugf("Ignore processing ARP packet from uplink")
return
}
}
// ARP request from local container to unknown IP
// Reinject ARP to uplinks
ethPkt := protocol.NewEthernet()
ethPkt.VLANID.VID = srcEp.EndpointGroupVlan
ethPkt.HWDst = pkt.HWDst
//.........這裏部分代碼省略.........
示例12: processArp
/*
* Process incoming ARP packets
* ARP request handling in various scenarios:
* Src and Dest EP known:
* - Proxy ARP if Dest EP is present locally on the host
* Src EP known, Dest EP not known:
* - ARP Request to a router/VM scenario. Reinject ARP request to VTEPs
* Src EP not known, Dest EP known:
* - Proxy ARP if Dest EP is present locally on the host
* Src and Dest EP not known:
* - Ignore processing the request
*/
func (self *Vxlan) processArp(pkt protocol.Ethernet, inPort uint32) {
switch t := pkt.Data.(type) {
case *protocol.ARP:
log.Debugf("Processing ARP packet on port %d: %+v", inPort, *t)
var arpIn protocol.ARP = *t
switch arpIn.Operation {
case protocol.Type_Request:
// If it's a GARP packet, ignore processing
if arpIn.IPSrc.String() == arpIn.IPDst.String() {
log.Debugf("Ignoring GARP packet")
return
}
if self.agent.portVlanMap[inPort] == nil {
log.Debugf("Invalid port vlan mapping. Ignoring arp packet")
return
}
vlan := self.agent.portVlanMap[inPort]
// Lookup the Source and Dest IP in the endpoint table
srcEp := self.agent.getEndpointByIpVlan(arpIn.IPSrc, *vlan)
dstEp := self.agent.getEndpointByIpVlan(arpIn.IPDst, *vlan)
// No information about the src or dest EP. Ignore processing.
if srcEp == nil && dstEp == nil {
log.Debugf("No information on source/destination. Ignoring ARP request.")
return
}
// If we know the dstEp to be present locally, send the Proxy ARP response
if dstEp != nil {
// Container to Container communication. Send proxy ARP response.
// Unknown node to Container communication
// -> Send proxy ARP response only if Endpoint is local.
// -> This is to avoid sending ARP responses from ofnet agent on multiple hosts
if srcEp != nil ||
(srcEp == nil && dstEp.OriginatorIp.String() == self.agent.localIp.String()) {
// Form an ARP response
arpPkt, _ := protocol.NewARP(protocol.Type_Reply)
arpPkt.HWSrc, _ = net.ParseMAC(dstEp.MacAddrStr)
arpPkt.IPSrc = arpIn.IPDst
arpPkt.HWDst = arpIn.HWSrc
arpPkt.IPDst = arpIn.IPSrc
log.Debugf("Sending Proxy ARP response: %+v", arpPkt)
// Build the ethernet packet
ethPkt := protocol.NewEthernet()
ethPkt.VLANID.VID = pkt.VLANID.VID
ethPkt.HWDst = arpPkt.HWDst
ethPkt.HWSrc = arpPkt.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = arpPkt
log.Debugf("Sending Proxy ARP response Ethernet: %+v", ethPkt)
// Construct Packet out
pktOut := openflow13.NewPacketOut()
pktOut.Data = ethPkt
pktOut.AddAction(openflow13.NewActionOutput(inPort))
// Send the packet out
self.ofSwitch.Send(pktOut)
return
}
}
if srcEp != nil && dstEp == nil {
// If the ARP request was received from VTEP port
// Ignore processing the packet
for _, vtepPort := range self.agent.vtepTable {
if *vtepPort == inPort {
log.Debugf("Received packet from VTEP port. Ignore processing")
return
}
}
// ARP request from local container to unknown IP
// Reinject ARP to VTEP ports
ethPkt := protocol.NewEthernet()
ethPkt.HWDst = pkt.HWDst
ethPkt.HWSrc = pkt.HWSrc
ethPkt.Ethertype = 0x0806
ethPkt.Data = &arpIn
log.Infof("Received ARP request for unknown IP: %v. "+
"Reinjecting ARP request Ethernet to VTEP ports: %+v", arpIn.IPDst, ethPkt)
// Packet out
pktOut := openflow13.NewPacketOut()
//.........這裏部分代碼省略.........
示例13: HandlePkt
// HandlePkt processes a received pkt from a matching table entry
func (proxy *ServiceProxy) HandlePkt(pkt *ofctrl.PacketIn) {
if pkt.TableId != SRV_PROXY_DNAT_TBL_ID {
return // ignore other packets
}
if pkt.Data.Ethertype != protocol.IPv4_MSG {
return // ignore non-IP pkts
}
if pkt.Data.HWSrc.String() == "00:00:11:11:11:11" {
log.Warnf("Pkt received with our src mac. Loop???")
return // pkt we sent
}
ip := pkt.Data.Data.(*protocol.IPv4)
svcIP := ip.NWDst.String()
log.Infof("HandlePkt svcIP: %s", svcIP)
proxy.oMutex.Lock()
defer proxy.oMutex.Unlock()
operEntry, found := proxy.operState[svcIP]
if !found {
return // this means service was just deleted
}
clientIP := ip.NWSrc.String()
provIP, err := operEntry.allocateProvider(clientIP)
if err != nil {
log.Warnf("allocateProvider failed for %s - %v", svcIP, err)
return
}
// use copies of fields from the pkt
ipSrc := net.ParseIP(ip.NWSrc.String())
ipDst := net.ParseIP(ip.NWDst.String())
// setup nat rules in both directions for all ports of the service
for _, p := range operEntry.ports {
// set up outgoing NAT
operEntry.addNATFlow(proxy.dNATTable, proxy.dNATNext, &p,
&ipSrc, &ipDst, &provIP, spDNAT)
// set up incoming NAT
operEntry.addNATFlow(proxy.sNATTable, proxy.sNATNext, &p,
&provIP, &ipSrc, &ipDst, spSNAT)
}
if pkt.Data.HWSrc.String() == "00:00:00:00:00:00" {
return // don't inject crafted pkt
}
// re-inject this pkt, change src mac to allow loop detection
pkt.Data.HWSrc, _ = net.ParseMAC("00:00:11:11:11:11")
// Packet out
pktOut := openflow13.NewPacketOut()
pktOut.InPort = getInPort(pkt)
pktOut.Data = &pkt.Data
pktOut.AddAction(openflow13.NewActionOutput(openflow13.P_TABLE))
// Send it out
proxy.ofSwitch.Send(pktOut)
}