本文整理匯總了Golang中github.com/contiv/ofnet/rpcHub.Client函數的典型用法代碼示例。如果您正苦於以下問題:Golang Client函數的具體用法?Golang Client怎麽用?Golang Client使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Client函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: RegisterNode
// RegisterNode registers an agent
func (self *OfnetMaster) RegisterNode(hostInfo *OfnetNode, ret *bool) error {
// Create a node
node := new(OfnetNode)
node.HostAddr = hostInfo.HostAddr
node.HostPort = hostInfo.HostPort
hostKey := fmt.Sprintf("%s:%d", hostInfo.HostAddr, hostInfo.HostPort)
// Add it to DB
self.masterMutex.Lock()
self.agentDb[hostKey] = node
self.masterMutex.Unlock()
log.Infof("Registered node: %+v", node)
// take a read lock for accessing db
self.masterMutex.RLock()
defer self.masterMutex.RUnlock()
// Send all existing endpoints to the new node
for _, endpoint := range self.endpointDb {
if node.HostAddr != endpoint.OriginatorIp.String() {
var resp bool
log.Infof("Sending endpoint: %+v to node %s:%d", endpoint, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("OfnetAgent.EndpointAdd", endpoint, &resp)
if err != nil {
log.Errorf("Error adding endpoint to %s. Err: %v", node.HostAddr, err)
// continue sending other endpoints
}
}
}
// Send all existing policy rules to the new node
for _, rule := range self.policyDb {
var resp bool
log.Infof("Sending rule: %+v to node %s:%d", rule, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("PolicyAgent.AddRule", rule, &resp)
if err != nil {
log.Errorf("Error adding rule to %s. Err: %v", node.HostAddr, err)
// continue sending other rules
}
}
// increment stats
self.incrAgentStats(hostKey, "registered")
return nil
}
示例2: AddMaster
// Add a master
// ofnet agent tries to connect to the master and download routes
func (self *OfnetAgent) AddMaster(masterInfo *OfnetNode, ret *bool) error {
master := new(OfnetNode)
master.HostAddr = masterInfo.HostAddr
master.HostPort = masterInfo.HostPort
var resp bool
log.Infof("Adding master: %+v", *master)
masterKey := fmt.Sprintf("%s:%d", masterInfo.HostAddr, masterInfo.HostPort)
// Save it in DB
self.masterDb[masterKey] = master
// My info to send to master
myInfo := new(OfnetNode)
myInfo.HostAddr = self.MyAddr
myInfo.HostPort = self.MyPort
// Register the agent with the master
err := rpcHub.Client(master.HostAddr, master.HostPort).Call("OfnetMaster.RegisterNode", &myInfo, &resp)
if err != nil {
log.Fatalf("Failed to register with the master %+v. Err: %v", master, err)
return err
}
// Perform master added callback so that datapaths can send their FDB to master
err = self.datapath.MasterAdded(master)
if err != nil {
log.Errorf("Error making master added callback for %+v. Err: %v", master, err)
}
// Send all local endpoints to new master.
for _, endpoint := range self.localEndpointDb {
if endpoint.OriginatorIp.String() == self.localIp.String() {
var resp bool
log.Infof("Sending endpoint %+v to master %+v", endpoint, master)
// Make the RPC call to add the endpoint to master
client := rpcHub.Client(master.HostAddr, master.HostPort)
err := client.Call("OfnetMaster.EndpointAdd", endpoint, &resp)
if err != nil {
log.Errorf("Failed to add endpoint %+v to master %+v. Err: %v", endpoint, master, err)
return err
}
}
}
return nil
}
示例3: AddMaster
// Add a master
// ofnet agent tries to connect to the master and download routes
func (self *OfnetAgent) AddMaster(masterInfo *OfnetNode, ret *bool) error {
master := new(OfnetNode)
master.HostAddr = masterInfo.HostAddr
master.HostPort = masterInfo.HostPort
var resp bool
log.Infof("Adding master: %+v", *master)
masterKey := fmt.Sprintf("%s:%d", masterInfo.HostAddr, masterInfo.HostPort)
// Save it in DB
self.masterDb[masterKey] = master
// My info to send to master
myInfo := new(OfnetNode)
myInfo.HostAddr = self.MyAddr
myInfo.HostPort = self.MyPort
// Register the agent with the master
err := rpcHub.Client(master.HostAddr, master.HostPort).Call("OfnetMaster.RegisterNode", &myInfo, &resp)
if err != nil {
log.Fatalf("Failed to register with the master %+v. Err: %v", master, err)
return err
}
// Perform master added callback so that datapaths can send their FDB to master
err = self.datapath.MasterAdded(master)
if err != nil {
log.Errorf("Error making master added callback for %+v. Err: %v", master, err)
}
return nil
}
示例4: AddRule
// AddRule adds a new rule to the policyDB
func (self *OfnetMaster) AddRule(rule *OfnetPolicyRule) error {
// Check if we have the rule already
if self.policyDb[rule.RuleId] != nil {
return errors.New("Rule already exists")
}
// Save the rule in DB
self.policyDb[rule.RuleId] = rule
// Publish it to all agents except where it came from
for _, node := range self.agentDb {
var resp bool
log.Infof("Sending rule: %+v to node %s:%d", rule, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("PolicyAgent.AddRule", rule, &resp)
if err != nil {
log.Errorf("Error adding rule to %s. Err: %v", node.HostAddr, err)
return err
}
}
return nil
}
示例5: MacRouteAdd
// Add a mac route
func (self *OfnetMaster) MacRouteAdd(macRoute *MacRoute, ret *bool) error {
// Check if we have the route already and which is more recent
oldRoute := self.macRouteDb[macRoute.MacAddrStr]
if oldRoute != nil {
// If old route has more recent timestamp, nothing to do
if !macRoute.Timestamp.After(oldRoute.Timestamp) {
return nil
}
}
// Save the route in DB
self.macRouteDb[macRoute.MacAddrStr] = macRoute
// Publish it to all agents except where it came from
for _, node := range self.agentDb {
if node.HostAddr != macRoute.OriginatorIp.String() {
var resp bool
log.Infof("Sending MacRoute: %+v to node %s", macRoute, node.HostAddr)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("Vxlan.MacRouteAdd", macRoute, &resp)
if err != nil {
log.Errorf("Error adding route to %s. Err: %v", node.HostAddr, err)
return err
}
}
}
*ret = true
return nil
}
示例6: EndpointDel
// Delete an Endpoint
func (self *OfnetMaster) EndpointDel(ep *OfnetEndpoint, ret *bool) error {
// Check if we have the endpoint, if we dont have the endpoint, nothing to do
oldEp := self.endpointDb[ep.EndpointID]
if oldEp == nil {
return nil
}
// If existing endpoint has more recent timestamp, nothing to do
if oldEp.Timestamp.After(ep.Timestamp) {
return nil
}
// Delete the endpoint from DB
delete(self.endpointDb, ep.EndpointID)
// Publish it to all agents except where it came from
for _, node := range self.agentDb {
if node.HostAddr != ep.OriginatorIp.String() {
var resp bool
log.Infof("Sending DELETE endpoint: %+v to node %s:%d", ep, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("OfnetAgent.EndpointDel", ep, &resp)
if err != nil {
log.Errorf("Error sending DELERE endpoint to %s. Err: %v", node.HostAddr, err)
return err
}
}
}
*ret = true
return nil
}
示例7: DelRule
// DelRule removes a rule from policy DB
func (self *OfnetMaster) DelRule(rule *OfnetPolicyRule) error {
// Check if we have the rule
if self.policyDb[rule.RuleId] == nil {
return errors.New("Rule does not exist")
}
// Remove the rule from DB
delete(self.policyDb, rule.RuleId)
// Publish it to all agents except where it came from
for _, node := range self.agentDb {
var resp bool
log.Infof("Sending DELETE rule: %+v to node %s", rule, node.HostAddr)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("PolicyAgent.DelRule", rule, &resp)
if err != nil {
log.Errorf("Error adding rule to %s. Err: %v", node.HostAddr, err)
return err
}
}
return nil
}
示例8: RemoveLocalEndpoint
// Remove local endpoint
func (self *OfnetAgent) RemoveLocalEndpoint(portNo uint32) error {
// Clear it from DB
delete(self.portVlanMap, portNo)
epreg := self.localEndpointDb[portNo]
if epreg == nil {
log.Errorf("Endpoint not found for port %d", portNo)
return errors.New("Endpoint not found")
}
// Call the datapath
err := self.datapath.RemoveLocalEndpoint(*epreg)
if err != nil {
log.Errorf("Error deleting endpointon port %d. Err: %v", portNo, err)
}
// delete the endpoint from local endpoint table
delete(self.endpointDb, epreg.EndpointID)
// Send the DELETE to all known masters
for _, master := range self.masterDb {
var resp bool
log.Infof("Sending DELETE endpoint %+v to master %+v", epreg, master)
// Make the RPC call to delete the endpoint on master
client := rpcHub.Client(master.HostAddr, master.HostPort)
err := client.Call("OfnetMaster.EndpointDel", epreg, &resp)
if err != nil {
log.Errorf("Failed to DELETE endpoint %+v on master %+v. Err: %v", epreg, master, err)
}
}
return nil
}
示例9: EndpointAdd
// Add an Endpoint
func (self *OfnetMaster) EndpointAdd(ep *OfnetEndpoint, ret *bool) error {
// Check if we have the endpoint already and which is more recent
oldEp := self.endpointDb[ep.EndpointID]
if oldEp != nil {
// If old endpoint has more recent timestamp, nothing to do
if !ep.Timestamp.After(oldEp.Timestamp) {
return nil
}
}
// Save the endpoint in DB
self.endpointDb[ep.EndpointID] = ep
// Publish it to all agents except where it came from
for _, node := range self.agentDb {
if node.HostAddr != ep.OriginatorIp.String() {
var resp bool
log.Infof("Sending endpoint: %+v to node %s:%d", ep, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("OfnetAgent.EndpointAdd", ep, &resp)
if err != nil {
log.Errorf("Error adding endpoint to %s. Err: %v", node.HostAddr, err)
return err
}
}
}
*ret = true
return nil
}
示例10: MacRouteDel
// Delete a mac route
func (self *OfnetMaster) MacRouteDel(macRoute *MacRoute, ret *bool) error {
// Check if we have the route, if we dont have the route, nothing to do
oldRoute := self.macRouteDb[macRoute.MacAddrStr]
if oldRoute == nil {
return nil
}
// If existing route has more recent timestamp, nothing to do
if oldRoute.Timestamp.After(macRoute.Timestamp) {
return nil
}
// Delete the route from DB
delete(self.macRouteDb, macRoute.MacAddrStr)
// Publish it to all agents except where it came from
for _, node := range self.agentDb {
if node.HostAddr != macRoute.OriginatorIp.String() {
var resp bool
log.Infof("Sending DELETE MacRoute: %+v to node %s", macRoute, node.HostAddr)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("Vxlan.MacRouteDel", macRoute, &resp)
if err != nil {
log.Errorf("Error sending DELERE mac route to %s. Err: %v", node.HostAddr, err)
return err
}
}
}
*ret = true
return nil
}
示例11: RegisterNode
// Register an agent
func (self *OfnetMaster) RegisterNode(hostInfo *OfnetNode, ret *bool) error {
// Create a node
node := new(OfnetNode)
node.HostAddr = hostInfo.HostAddr
node.HostPort = hostInfo.HostPort
hostKey := fmt.Sprintf("%s:%d", hostInfo.HostAddr, hostInfo.HostPort)
// Add it to DB
self.agentDb[hostKey] = node
log.Infof("Registered node: %+v", node)
// Send all existing routes
for _, route := range self.routeDb {
if node.HostAddr != route.OriginatorIp.String() {
var resp bool
log.Infof("Sending Route: %+v to node %s", route, node.HostAddr)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("Vrouter.RouteAdd", route, &resp)
if err != nil {
log.Errorf("Error adding route to %s. Err: %v", node.HostAddr, err)
}
}
}
// Send all mac routes
for _, macRoute := range self.macRouteDb {
if node.HostAddr != macRoute.OriginatorIp.String() {
var resp bool
log.Infof("Sending MacRoute: %+v to node %s", macRoute, node.HostAddr)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("Vxlan.MacRouteAdd", macRoute, &resp)
if err != nil {
log.Errorf("Error adding route to %s. Err: %v", node.HostAddr, err)
}
}
}
return nil
}
示例12: RegisterNode
// Register an agent
func (self *OfnetMaster) RegisterNode(hostInfo *OfnetNode, ret *bool) error {
// Create a node
node := new(OfnetNode)
node.HostAddr = hostInfo.HostAddr
node.HostPort = hostInfo.HostPort
hostKey := fmt.Sprintf("%s:%d", hostInfo.HostAddr, hostInfo.HostPort)
// Add it to DB
self.agentDb[hostKey] = node
log.Infof("Registered node: %+v", node)
// Send all existing endpoints to the new node
for _, endpoint := range self.endpointDb {
if node.HostAddr != endpoint.OriginatorIp.String() {
var resp bool
log.Infof("Sending endpoint: %+v to node %s:%d", endpoint, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("OfnetAgent.EndpointAdd", endpoint, &resp)
if err != nil {
log.Errorf("Error adding endpoint to %s. Err: %v", node.HostAddr, err)
}
}
}
// Send all existing policy rules to the new node
for _, rule := range self.policyDb {
var resp bool
log.Infof("Sending rule: %+v to node %s:%d", rule, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("PolicyAgent.AddRule", rule, &resp)
if err != nil {
log.Errorf("Error adding rule to %s. Err: %v", node.HostAddr, err)
return err
}
}
return nil
}
示例13: AddLocalEndpoint
// Add a local endpoint.
// This takes ofp port number, mac address, vlan and IP address of the port.
func (self *OfnetAgent) AddLocalEndpoint(endpoint EndpointInfo) error {
// Add port vlan mapping
self.portVlanMap[endpoint.PortNo] = &endpoint.Vlan
// Map Vlan to VNI
vni := self.vlanVniMap[endpoint.Vlan]
if vni == nil {
log.Errorf("VNI for vlan %d is not known", endpoint.Vlan)
return errors.New("Unknown Vlan")
}
epId := self.getEndpointId(endpoint)
// Build endpoint registry info
epreg := &OfnetEndpoint{
EndpointID: epId,
EndpointType: "internal",
EndpointGroup: endpoint.EndpointGroup,
IpAddr: endpoint.IpAddr,
VrfId: 0, // FIXME set VRF correctly
MacAddrStr: endpoint.MacAddr.String(),
Vlan: endpoint.Vlan,
Vni: *vni,
OriginatorIp: self.localIp,
PortNo: endpoint.PortNo,
Timestamp: time.Now(),
}
// Call the datapath
err := self.datapath.AddLocalEndpoint(*epreg)
if err != nil {
log.Errorf("Adding endpoint (%+v) to datapath. Err: %v", epreg, err)
return err
}
// Add the endpoint to local routing table
self.endpointDb[epId] = epreg
self.localEndpointDb[endpoint.PortNo] = epreg
// Send the endpoint to all known masters
for _, master := range self.masterDb {
var resp bool
log.Infof("Sending endpoint %+v to master %+v", epreg, master)
// Make the RPC call to add the endpoint to master
err := rpcHub.Client(master.HostAddr, master.HostPort).Call("OfnetMaster.EndpointAdd", epreg, &resp)
if err != nil {
log.Errorf("Failed to add endpoint %+v to master %+v. Err: %v", epreg, master, err)
return err
}
}
return nil
}
示例14: EndpointDel
// Delete an Endpoint
func (self *OfnetMaster) EndpointDel(ep *OfnetEndpoint, ret *bool) error {
// Check if we have the endpoint, if we dont have the endpoint, nothing to do
self.masterMutex.RLock()
oldEp := self.endpointDb[ep.EndpointID]
self.masterMutex.RUnlock()
if oldEp == nil {
log.Errorf("Received endpoint DELETE on a non existing endpoint %+v", ep)
return nil
}
// If existing endpoint has more recent timestamp, nothing to do
if oldEp.Timestamp.After(ep.Timestamp) {
return nil
}
// Delete the endpoint from DB
self.masterMutex.Lock()
delete(self.endpointDb, ep.EndpointID)
self.masterMutex.Unlock()
// take a read lock for accessing db
self.masterMutex.RLock()
defer self.masterMutex.RUnlock()
// Publish it to all agents except where it came from
for nodeKey, node := range self.agentDb {
if node.HostAddr != ep.OriginatorIp.String() {
var resp bool
log.Infof("Sending DELETE endpoint: %+v to node %s:%d", ep, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("OfnetAgent.EndpointDel", ep, &resp)
if err != nil {
log.Errorf("Error sending DELERE endpoint to %s. Err: %v", node.HostAddr, err)
// Continue sending the message to other nodes
// increment stats
self.incrAgentStats(nodeKey, "EndpointDelFailure")
} else {
// increment stats
self.incrAgentStats(nodeKey, "EndpointDelSent")
}
}
}
*ret = true
return nil
}
示例15: EndpointAdd
// Add an Endpoint
func (self *OfnetMaster) EndpointAdd(ep *OfnetEndpoint, ret *bool) error {
log.Infof("Received Endpoint CReate from Remote netplugin")
// Check if we have the endpoint already and which is more recent
self.masterMutex.RLock()
oldEp := self.endpointDb[ep.EndpointID]
self.masterMutex.RUnlock()
if oldEp != nil {
// If old endpoint has more recent timestamp, nothing to do
if !ep.Timestamp.After(oldEp.Timestamp) {
return nil
}
}
// Save the endpoint in DB
self.masterMutex.Lock()
self.endpointDb[ep.EndpointID] = ep
self.masterMutex.Unlock()
// take a read lock for accessing db
self.masterMutex.RLock()
defer self.masterMutex.RUnlock()
// Publish it to all agents except where it came from
for nodeKey, node := range self.agentDb {
if node.HostAddr != ep.OriginatorIp.String() {
var resp bool
log.Infof("Sending endpoint: %+v to node %s:%d", ep, node.HostAddr, node.HostPort)
client := rpcHub.Client(node.HostAddr, node.HostPort)
err := client.Call("OfnetAgent.EndpointAdd", ep, &resp)
if err != nil {
log.Errorf("Error adding endpoint to %s. Err: %v", node.HostAddr, err)
// Continue sending the message to other nodes
// increment stats
self.incrAgentStats(nodeKey, "EndpointAddFailure")
} else {
// increment stats
self.incrAgentStats(nodeKey, "EndpointAddSent")
}
}
}
*ret = true
return nil
}