Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[CNI] zap logger for platform package #2233

Merged
merged 38 commits into from
Oct 13, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
bfa6183
zap logger for platform package
paulyufan2 Sep 21, 2023
0be7e3d
fix linter issues
paulyufan2 Sep 21, 2023
fbc2b7d
fix comments
paulyufan2 Sep 21, 2023
47ea415
remove log from GetLastRebootTime
paulyufan2 Sep 21, 2023
a0801a3
fix linter issue
paulyufan2 Sep 21, 2023
3c839bf
fix comments
paulyufan2 Sep 21, 2023
a0c6916
fix comment
paulyufan2 Sep 25, 2023
4cdeb8e
fix comments
paulyufan2 Sep 25, 2023
1176a8e
fix comments
paulyufan2 Sep 25, 2023
c9ebccd
fix an issue
paulyufan2 Sep 25, 2023
9eb5c15
fix comments
paulyufan2 Sep 25, 2023
d18204f
fix comments
paulyufan2 Sep 27, 2023
4cdf000
fix comments
paulyufan2 Sep 28, 2023
a747211
fix comments
paulyufan2 Sep 29, 2023
eff34bb
fix comments
paulyufan2 Oct 4, 2023
7e4f94e
fix comments
paulyufan2 Oct 4, 2023
2134007
fix issue
paulyufan2 Oct 4, 2023
e63e857
fix issue
paulyufan2 Oct 4, 2023
29d50cb
fix linter issue
paulyufan2 Oct 4, 2023
cda3363
fix an issue
paulyufan2 Oct 4, 2023
732efca
fix linter issue
paulyufan2 Oct 4, 2023
854cde7
fix linter issue
paulyufan2 Oct 4, 2023
9fc5549
fix mockexeclient
paulyufan2 Oct 4, 2023
89bdabe
fix mockexeclient
paulyufan2 Oct 4, 2023
3e11ad5
fix linter issue
paulyufan2 Oct 4, 2023
0064e33
fix linter issue
paulyufan2 Oct 4, 2023
b6728ad
fix comments
paulyufan2 Oct 5, 2023
acb266c
fix comments
paulyufan2 Oct 5, 2023
0fa625d
fix linter issue
paulyufan2 Oct 5, 2023
65f3d65
fix comments
paulyufan2 Oct 5, 2023
af55d6c
fix comments
paulyufan2 Oct 5, 2023
0f12711
fix issues
paulyufan2 Oct 5, 2023
db47b63
fix comments
paulyufan2 Oct 6, 2023
be3fad6
fix windows linter issue
paulyufan2 Oct 6, 2023
1f966f8
fix comments
paulyufan2 Oct 12, 2023
115f826
add dump codes
paulyufan2 Oct 12, 2023
682977b
fix comments
paulyufan2 Oct 12, 2023
cfd4781
fix comments
paulyufan2 Oct 12, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion aitelemetry/telemetrywrapper_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ func TestMain(m *testing.M) {
fmt.Printf("TestST LogDir configuration succeeded\n")
}

p := platform.NewExecClient()
p := platform.NewExecClient(nil)
if runtime.GOOS == "linux" {
//nolint:errcheck // initial test setup
p.ExecuteCommand("cp metadata_test.json /tmp/azuremetadata.json")
Expand Down
2 changes: 1 addition & 1 deletion cni/network/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -117,7 +117,7 @@ func NewPlugin(name string,

nl := netlink.NewNetlink()
// Setup network manager.
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(), &netio.NetIO{})
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(logger), &netio.NetIO{})
if err != nil {
return nil, err
}
Expand Down
4 changes: 3 additions & 1 deletion cni/network/plugin/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -157,6 +157,7 @@ func rootExecute() error {
InterfaceDetails: telemetry.InterfaceInfo{},
BridgeDetails: telemetry.BridgeInfo{},
Version: version,
Logger: logger,
},
}

Expand All @@ -182,7 +183,8 @@ func rootExecute() error {
cniReport.GetReport(pluginName, version, ipamQueryURL)

var upTime time.Time
upTime, err = platform.GetLastRebootTime()
p := platform.NewExecClient(logger)
upTime, err = p.GetLastRebootTime()
if err == nil {
cniReport.VMUptime = upTime.Format("2006-01-02 15:04:05")
}
Expand Down
1 change: 0 additions & 1 deletion cni/telemetry/service/telemetrymain.go
Original file line number Diff line number Diff line change
Expand Up @@ -143,7 +143,6 @@ func main() {
tbtemp.Cleanup(telemetry.FdName)

tb = telemetry.NewTelemetryBuffer(logger)

for {
logger.Info("Starting telemetry server")
err = tb.StartServer()
Expand Down
2 changes: 1 addition & 1 deletion cnm/network/network.go
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ func NewPlugin(config *common.PluginConfig) (NetPlugin, error) {

nl := netlink.NewNetlink()
// Setup network manager.
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(), &netio.NetIO{})
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(nil), &netio.NetIO{})
if err != nil {
return nil, err
}
Expand Down
2 changes: 1 addition & 1 deletion cnms/service/networkmonitor.go
Original file line number Diff line number Diff line change
Expand Up @@ -157,7 +157,7 @@ func main() {
}

nl := netlink.NewNetlink()
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(), &netio.NetIO{})
nm, err := network.NewNetworkManager(nl, platform.NewExecClient(nil), &netio.NetIO{})
if err != nil {
log.Printf("[monitor] Failed while creating network manager")
return
Expand Down
2 changes: 1 addition & 1 deletion cns/dockerclient/dockerclient.go
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ func (c *Client) CreateNetwork(networkName string, nicInfo *wireserver.Interface

// DeleteNetwork creates a network using docker network create.
func (c *Client) DeleteNetwork(networkName string) error {
p := platform.NewExecClient()
p := platform.NewExecClient(nil)
logger.Printf("[Azure CNS] DeleteNetwork")

url := c.connectionURL + inspectNetworkPath + networkName
Expand Down
4 changes: 2 additions & 2 deletions cns/restserver/util.go
Original file line number Diff line number Diff line change
Expand Up @@ -539,8 +539,8 @@ func (service *HTTPRestService) restoreNetworkState() error {

if err == nil {
logger.Printf("[Azure CNS] Store timestamp is %v.", modTime)

rebootTime, err := platform.GetLastRebootTime()
p := platform.NewExecClient(nil)
rebootTime, err := p.GetLastRebootTime()
if err == nil && rebootTime.After(modTime) {
logger.Printf("[Azure CNS] reboot time %v mod time %v", rebootTime, modTime)
rebooted = true
Expand Down
4 changes: 2 additions & 2 deletions ebtables/ebtables.go
Original file line number Diff line number Diff line change
Expand Up @@ -129,7 +129,7 @@ func GetEbtableRules(tableName, chainName string) ([]string, error) {
inChain bool
rules []string
)
p := platform.NewExecClient()
p := platform.NewExecClient(nil)
command := fmt.Sprintf(
"ebtables -t %s -L %s --Lmac2",
tableName, chainName)
Expand Down Expand Up @@ -226,7 +226,7 @@ func EbTableRuleExists(tableName, chainName, matchSet string) (bool, error) {

// runEbCmd runs an EB rule command.
func runEbCmd(table, action, chain, rule string) error {
p := platform.NewExecClient()
p := platform.NewExecClient(nil)
command := fmt.Sprintf("ebtables -t %s %s %s %s", table, action, chain, rule)
_, err := p.ExecuteCommand(command)

Expand Down
3 changes: 2 additions & 1 deletion ipam/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -134,7 +134,8 @@ func (am *addressManager) restore(rehydrateIpamInfoOnReboot bool) error {
// Check if the VM is rebooted.
modTime, err := am.store.GetModificationTime()
if err == nil {
rebootTime, err := platform.GetLastRebootTime()
p := platform.NewExecClient(nil)
rebootTime, err := p.GetLastRebootTime()
log.Printf("[ipam] reboot time %v store mod time %v", rebootTime, modTime)

if err == nil && rebootTime.After(modTime) {
Expand Down
3 changes: 2 additions & 1 deletion ipam/manager_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -229,7 +229,8 @@ var _ = Describe("Test Manager", func() {
am := &addressManager{
AddrSpaces: make(map[string]*addressSpace),
}
timeReboot, _ := platform.GetLastRebootTime()
p := platform.NewExecClient(nil)
timeReboot, _ := p.GetLastRebootTime()
am.store = &testutils.KeyValueStoreMock{
ModificationTime: timeReboot.Add(time.Hour),
}
Expand Down
13 changes: 8 additions & 5 deletions iptables/iptables.go
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,13 @@ package iptables
import (
"fmt"

"github.com/Azure/azure-container-networking/log"
"github.com/Azure/azure-container-networking/cni/log"
"github.com/Azure/azure-container-networking/platform"
"go.uber.org/zap"
)

var logger = log.CNILogger.With(zap.String("component", "cni-iptables"))

// cni iptable chains
const (
CNIInputChain = "AZURECNIINPUT"
Expand Down Expand Up @@ -88,7 +91,7 @@ type IPTableEntry struct {
func RunCmd(version, params string) error {
var cmd string

p := platform.NewExecClient()
p := platform.NewExecClient(logger)
iptCmd := iptables
if version == V6 {
iptCmd = ip6tables
Expand Down Expand Up @@ -132,7 +135,7 @@ func CreateChain(version, tableName, chainName string) error {
cmd := GetCreateChainCmd(version, tableName, chainName)
err = RunCmd(version, cmd.Params)
} else {
log.Printf("%s Chain exists in table %s", chainName, tableName)
logger.Info("Chain exists in table", zap.String("chainName", chainName), zap.String("tableName", tableName))
}

return err
Expand All @@ -157,7 +160,7 @@ func GetInsertIptableRuleCmd(version, tableName, chainName, match, target string
// Insert iptable rule at beginning of iptable chain
func InsertIptableRule(version, tableName, chainName, match, target string) error {
if RuleExists(version, tableName, chainName, match, target) {
log.Printf("Rule already exists")
logger.Info("Rule already exists")
return nil
}

Expand All @@ -175,7 +178,7 @@ func GetAppendIptableRuleCmd(version, tableName, chainName, match, target string
// Append iptable rule at end of iptable chain
func AppendIptableRule(version, tableName, chainName, match, target string) error {
if RuleExists(version, tableName, chainName, match, target) {
log.Printf("Rule already exists")
logger.Info("Rule already exists")
return nil
}

Expand Down
13 changes: 7 additions & 6 deletions network/endpoint_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ func ConstructEndpointID(containerID string, netNsPath string, ifName string) (s
}

// newEndpointImpl creates a new endpoint in the network.
func (nw *network) newEndpointImpl(cli apipaClient, _ netlink.NetlinkInterface, _ platform.ExecClient, _ netio.NetIOInterface, _ EndpointClient, epInfo *EndpointInfo) (*endpoint, error) {
func (nw *network) newEndpointImpl(cli apipaClient, _ netlink.NetlinkInterface, plc platform.ExecClient, _ netio.NetIOInterface, _ EndpointClient, epInfo *EndpointInfo) (*endpoint, error) {
if useHnsV2, err := UseHnsV2(epInfo.NetNsPath); useHnsV2 {
if err != nil {
return nil, err
Expand All @@ -73,11 +73,11 @@ func (nw *network) newEndpointImpl(cli apipaClient, _ netlink.NetlinkInterface,
return nw.newEndpointImplHnsV2(cli, epInfo)
}

return nw.newEndpointImplHnsV1(epInfo)
return nw.newEndpointImplHnsV1(epInfo, plc)
}

// newEndpointImplHnsV1 creates a new endpoint in the network using HnsV1
func (nw *network) newEndpointImplHnsV1(epInfo *EndpointInfo) (*endpoint, error) {
func (nw *network) newEndpointImplHnsV1(epInfo *EndpointInfo, plc platform.ExecClient) (*endpoint, error) {
var vlanid int

if epInfo.Data != nil {
Expand Down Expand Up @@ -141,7 +141,7 @@ func (nw *network) newEndpointImplHnsV1(epInfo *EndpointInfo) (*endpoint, error)
}

// add ipv6 neighbor entry for gateway IP to default mac in container
if err := nw.addIPv6NeighborEntryForGateway(epInfo); err != nil {
if err := nw.addIPv6NeighborEntryForGateway(epInfo, plc); err != nil {
return nil, err
}

Expand Down Expand Up @@ -169,7 +169,7 @@ func (nw *network) newEndpointImplHnsV1(epInfo *EndpointInfo) (*endpoint, error)
return ep, nil
}

func (nw *network) addIPv6NeighborEntryForGateway(epInfo *EndpointInfo) error {
func (nw *network) addIPv6NeighborEntryForGateway(epInfo *EndpointInfo, plc platform.ExecClient) error {
var (
err error
out string
Expand All @@ -183,7 +183,8 @@ func (nw *network) addIPv6NeighborEntryForGateway(epInfo *EndpointInfo) error {
// run powershell cmd to set neighbor entry for gw ip to 12-34-56-78-9a-bc
cmd := fmt.Sprintf("New-NetNeighbor -IPAddress %s -InterfaceAlias \"%s (%s)\" -LinkLayerAddress \"%s\"",
nw.Subnets[1].Gateway.String(), containerIfNamePrefix, epInfo.Id, defaultGwMac)
if out, err = platform.ExecutePowershellCommand(cmd); err != nil {

if out, err = plc.ExecutePowershellCommand(cmd); err != nil {
logger.Error("Adding ipv6 gw neigh entry failed", zap.Any("out", out), zap.Error(err))
return err
}
Expand Down
4 changes: 2 additions & 2 deletions network/endpoint_windows_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -159,7 +159,7 @@ func TestCreateEndpointImplHnsv1Timeout(t *testing.T) {
},
MacAddress: net.HardwareAddr("00:00:5e:00:53:01"),
}
_, err := nw.newEndpointImplHnsV1(epInfo)
_, err := nw.newEndpointImplHnsV1(epInfo, nil)

if err == nil {
t.Fatal("Failed to timeout HNS calls for creating endpoint")
Expand All @@ -186,7 +186,7 @@ func TestDeleteEndpointImplHnsv1Timeout(t *testing.T) {
},
MacAddress: net.HardwareAddr("00:00:5e:00:53:01"),
}
endpoint, err := nw.newEndpointImplHnsV1(epInfo)
endpoint, err := nw.newEndpointImplHnsV1(epInfo, nil)
if err != nil {
fmt.Printf("+%v", err)
t.Fatal(err)
Expand Down
4 changes: 2 additions & 2 deletions network/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -154,12 +154,12 @@ func (nm *networkManager) restore(isRehydrationRequired bool) error {
if isRehydrationRequired {
modTime, err := nm.store.GetModificationTime()
if err == nil {
rebootTime, err := platform.GetLastRebootTime()
rebootTime, err := nm.plClient.GetLastRebootTime()
logger.Info("reboot time, store mod time", zap.Any("rebootTime", rebootTime), zap.Any("modTime", modTime))
if err == nil && rebootTime.After(modTime) {
logger.Info("Detected Reboot")
rebooted = true
if clearNwConfig, err := platform.ClearNetworkConfiguration(); clearNwConfig {
if clearNwConfig, err := nm.plClient.ClearNetworkConfiguration(); clearNwConfig {
if err != nil {
logger.Error("Failed to clear network configuration", zap.Error(err))
return err
Expand Down
23 changes: 10 additions & 13 deletions network/network_linux.go
Original file line number Diff line number Diff line change
Expand Up @@ -243,12 +243,11 @@ func isGreaterOrEqaulUbuntuVersion(versionToMatch int) bool {
return false
}

func readDnsInfo(ifName string) (DNSInfo, error) {
func (nm *networkManager) readDNSInfo(ifName string) (DNSInfo, error) {
var dnsInfo DNSInfo

p := platform.NewExecClient()
cmd := fmt.Sprintf("systemd-resolve --status %s", ifName)
out, err := p.ExecuteCommand(cmd)
out, err := nm.plClient.ExecuteCommand(cmd)
if err != nil {
return dnsInfo, err
}
Expand Down Expand Up @@ -289,8 +288,8 @@ func readDnsInfo(ifName string) (DNSInfo, error) {
return dnsInfo, nil
}

func saveDnsConfig(extIf *externalInterface) error {
dnsInfo, err := readDnsInfo(extIf.Name)
func (nm *networkManager) saveDNSConfig(extIf *externalInterface) error {
dnsInfo, err := nm.readDNSInfo(extIf.Name)
if err != nil || len(dnsInfo.Servers) == 0 || dnsInfo.Suffix == "" {
logger.Info("Failed to read dns info from interface", zap.Any("dnsInfo", dnsInfo), zap.String("extIfName", extIf.Name),
zap.Error(err))
Expand Down Expand Up @@ -332,12 +331,11 @@ func (nm *networkManager) applyIPConfig(extIf *externalInterface, targetIf *net.
return nil
}

func applyDnsConfig(extIf *externalInterface, ifName string) error {
func (nm *networkManager) applyDNSConfig(extIf *externalInterface, ifName string) error {
var (
setDnsList string
err error
)
p := platform.NewExecClient()

if extIf != nil {
for _, server := range extIf.DNSInfo.Servers {
Expand All @@ -352,15 +350,15 @@ func applyDnsConfig(extIf *externalInterface, ifName string) error {

if setDnsList != "" {
cmd := fmt.Sprintf("systemd-resolve --interface=%s%s", ifName, setDnsList)
_, err = p.ExecuteCommand(cmd)
_, err = nm.plClient.ExecuteCommand(cmd)
if err != nil {
return err
}
}

if extIf.DNSInfo.Suffix != "" {
cmd := fmt.Sprintf("systemd-resolve --interface=%s --set-domain=%s", ifName, extIf.DNSInfo.Suffix)
_, err = p.ExecuteCommand(cmd)
_, err = nm.plClient.ExecuteCommand(cmd)
}

}
Expand Down Expand Up @@ -443,12 +441,11 @@ func (nm *networkManager) connectExternalInterface(extIf *externalInterface, nwI
isGreaterOrEqualUbuntu17 := isGreaterOrEqaulUbuntuVersion(ubuntuVersion17)
isSystemdResolvedActive := false
if isGreaterOrEqualUbuntu17 {
p := platform.NewExecClient()
// Don't copy dns servers if systemd-resolved isn't available
if _, cmderr := p.ExecuteCommand("systemctl status systemd-resolved"); cmderr == nil {
if _, cmderr := nm.plClient.ExecuteCommand("systemctl status systemd-resolved"); cmderr == nil {
isSystemdResolvedActive = true
logger.Info("Saving dns config from", zap.String("Name", hostIf.Name))
if err = saveDnsConfig(extIf); err != nil {
if err = nm.saveDNSConfig(extIf); err != nil {
logger.Error("Failed to save dns config", zap.Error(err))
return err
}
Expand Down Expand Up @@ -506,7 +503,7 @@ func (nm *networkManager) connectExternalInterface(extIf *externalInterface, nwI
if isGreaterOrEqualUbuntu17 && isSystemdResolvedActive {
logger.Info("Applying dns config on", zap.String("bridgeName", bridgeName))

if err = applyDnsConfig(extIf, bridgeName); err != nil {
if err = nm.applyDNSConfig(extIf, bridgeName); err != nil {
logger.Error("Failed to apply DNS configuration with", zap.Error(err))
return err
}
Expand Down
2 changes: 1 addition & 1 deletion ovsctl/ovsctl.go
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,7 @@ type Ovsctl struct {
}

func NewOvsctl() Ovsctl {
return Ovsctl{execcli: platform.NewExecClient()}
return Ovsctl{execcli: platform.NewExecClient(logger)}
}

func (o Ovsctl) CreateOVSBridge(bridgeName string) error {
Expand Down
21 changes: 20 additions & 1 deletion platform/mockexec.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
package platform

import "errors"
import (
"errors"
"time"
)

type MockExecClient struct {
returnError bool
Expand Down Expand Up @@ -33,3 +36,19 @@ func (e *MockExecClient) ExecuteCommand(cmd string) (string, error) {
func (e *MockExecClient) SetExecCommand(fn execCommandValidator) {
e.setExecCommand = fn
}

func (e *MockExecClient) ClearNetworkConfiguration() (bool, error) {
return true, nil
}

func (e *MockExecClient) ExecutePowershellCommand(_ string) (string, error) {
return "", nil
}

func (e *MockExecClient) GetLastRebootTime() (time.Time, error) {
return time.Time{}, nil
}

func (e *MockExecClient) KillProcessByName(_ string) error {
return nil
}
3 changes: 2 additions & 1 deletion platform/os.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,9 @@ import (
"bufio"
"fmt"
"io"
"log"
"os"

"github.com/Azure/azure-container-networking/log"
paulyufan2 marked this conversation as resolved.
Show resolved Hide resolved
)

// ReadFileByLines reads file line by line and return array of lines.
Expand Down
Loading