2015-07-03 61 views
1

我需要看網絡的變化,並設置一些路由規則只要網絡狀態更改(例如,如果一個接口被重新啓動,我需要重新設置IP路由表B/C的SRC是動態的,所以我不能硬編碼)。 要做到這一點,我試圖用networkmanager包,但WatchState恐慌。任何想法爲什麼?爲什麼networkmanager.WatchState恐慌?

package main 

import(
    "flag" 
    "os" 
    "launchpad.net/ubuntu-push/bus" 
    "launchpad.net/ubuntu-push/bus/networkmanager" 
    "launchpad.net/ubuntu-push/logger" 

) 

func main(){ 
    flag.Parse() 

    lg := logger.NewSimpleLogger(os.Stderr, "info") 
    endp := bus.SystemBus.Endpoint(networkmanager.BusAddress, lg) 
    nm := networkmanager.New(endp, lg) 
    watchState, cancel, err := nm.WatchState() 
    if err !=nil{ 
     log.Printf("error %v", err) 
     return 
    } 
    defer cancel.Cancel() 
    for state := range watchState{ 
     log.Printf.("state is %v", state) 
    } 
} 

恐慌跟蹤

panic: runtime error: invalid memory address or nil pointer dereference 
[signal 0xb code=0x1 addr=0x0 pc=0x488788] 

    goroutine 1 [running]: 
    launchpad.net/go-dbus/v1.(*ObjectProxy).WatchSignal(0x0, 0x616cd0, 0x1e, 0x5f0af0, 0xc, 0x7f9733d0e478, 0x0, 0x0) 
     /root/go/src/launchpad.net/go-dbus/v1/dbus.go:97 +0x198 
    launchpad.net/ubuntu-push/bus.(*endpoint).WatchSignal(0xc20803e0c0, 0x5f0af0, 0xc, 0xc20800a0e0, 0xc20802a530, 0x0, 0x0, 0x0, 0x0) 
     /root/go/src/launchpad.net/ubuntu-push/bus/endpoint.go:133 +0x91 
    launchpad.net/ubuntu-push/bus/networkmanager.(*networkManager).WatchState(0xc20800a0c0, 0x5bce80, 0x0, 0x0, 0x0, 0x0) 
     /root/go/src/launchpad.net/ubuntu-push/bus/networkmanager/networkmanager.go:108 +0x1cf 
    main.main() 
     /root/go/src/github.com/vinkoo/net/main.go:16 +0x1f9 

    goroutine 2 [runnable]: 
    runtime.forcegchelper() 
     /usr/local/go/src/runtime/proc.go:90 
    runtime.goexit() 
     /usr/local/go/src/runtime/asm_amd64.s:2232 +0x1 

    goroutine 3 [runnable]: 
    runtime.bgsweep() 
     /usr/local/go/src/runtime/mgc0.go:82 
    runtime.goexit() 
     /usr/local/go/src/runtime/asm_amd64.s:2232 +0x1 

    goroutine 4 [runnable]: 
    runtime.runfinq() 
     /usr/local/go/src/runtime/malloc.go:712 
    runtime.goexit() 
     /usr/local/go/src/runtime/asm_amd64.s:2232 +0x1 
    exit status 2 

編輯:似乎從NetworkManager的任何方法的程序恐慌。 GetState恐慌如下。

goroutine 1 [running]: 
launchpad.net/go-dbus/v1.(*ObjectProxy).Call(0x0, 0x616c90, 0x1f, 0x5e26d0, 0x3, 0xc20801d5a0, 0x2, 0x2, 0x7f13a95d0b50, 0x0, ...) 
    /root/go/src/launchpad.net/go-dbus/v1/dbus.go:77 +0x1d1 
launchpad.net/ubuntu-push/bus.(*endpoint).GetProperty(0xc20803e0c0, 0x5eac50, 0x5, 0x0, 0x0, 0x0, 0x0) 
    /root/go/src/launchpad.net/ubuntu-push/bus/endpoint.go:169 +0x1cf 
launchpad.net/ubuntu-push/bus/networkmanager.(*networkManager).GetState(0xc20800a0c0, 0x5bce80) 
    /root/go/src/launchpad.net/ubuntu-push/bus/networkmanager/networkmanager.go:79 +0x62 
main.main() 

回答

0
我沒有用的包自己

,但是從檢查the source code,好像你應該,否則,endpoint.proxy撐未初始化networkmanager.New之前調用endp.Dial

endp := bus.SystemBus.Endpoint(networkmanager.BusAddress, lg) 
err := endp.Dial() 
if err != nil{ 
    log.Printf("dial error %v", err) 
    return 
} 
defer endp.Close() 
nm := networkmanager.New(endp, lg) 
+0

這就是它!非常感謝! –

+0

雖然nm.WatchState()不工作(即我沒有得到任何通知),所以我想這是相當錯誤,因爲GETSTATE工作。 –

+0

這可能是。該軟件包幾乎沒有任何文檔或示例,這是它自己的錯誤。 –