本文整理匯總了Golang中github.com/Sirupsen/logrus.Infof函數的典型用法代碼示例。如果您正苦於以下問題:Golang Infof函數的具體用法?Golang Infof怎麽用?Golang Infof使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Infof函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: Release
// Release an interface for a select ip
func Release(job *engine.Job) error {
var (
id = job.Args[0]
containerInterface = currentInterfaces.Get(id)
)
if containerInterface == nil {
return fmt.Errorf("No network information to release for %s", id)
}
for _, nat := range containerInterface.PortMappings {
if err := portmapper.Unmap(nat); err != nil {
logrus.Infof("Unable to unmap port %s: %s", nat, err)
}
}
if err := ipAllocator.ReleaseIP(bridgeIPv4Network, containerInterface.IP); err != nil {
logrus.Infof("Unable to release IPv4 %s", err)
}
if globalIPv6Network != nil {
if err := ipAllocator.ReleaseIP(globalIPv6Network, containerInterface.IPv6); err != nil {
logrus.Infof("Unable to release IPv6 %s", err)
}
}
return nil
}
示例2: checkConnectionRetry
func (k *kubernetes) checkConnectionRetry(c *container, ipaddr, protocol string, port, delay, retries int) error {
var protoStr string
var err error
err = nil
if protocol == "udp" {
protoStr = "-u"
}
logrus.Infof("Checking connection from %s to ip %s on port %d, delay: %d, retries: %d",
c, ipaddr, port, delay, retries)
for i := 0; i < retries; i++ {
_, err = k.exec(c, fmt.Sprintf("nc -z -n -v -w 1 %s %s %v", protoStr, ipaddr, port))
if err == nil {
logrus.Infof("Connection to ip %s on port %d SUCCEEDED, tries: %d", ipaddr, port, i+1)
return nil
}
time.Sleep(2 * time.Second)
}
logrus.Errorf("Connection to ip %s on port %d FAILED %v", ipaddr, port, err)
return err
}
示例3: setupTestServer
// setupTestServer creates a listener for the rest requests.
func setupTestServer() {
router := mux.NewRouter()
// register handlers for cni
t := router.Headers("Content-Type", "application/json").Methods("POST").Subrouter()
t.HandleFunc(cniapi.EPAddURL, httpWrapper(stubAddPod))
t.HandleFunc(cniapi.EPDelURL, httpWrapper(stubDeletePod))
driverPath := cniapi.ContivCniSocket
os.Remove(driverPath)
os.MkdirAll(cniapi.PluginPath, 0700)
go func() {
l, err := net.ListenUnix("unix", &net.UnixAddr{Name: driverPath, Net: "unix"})
if err != nil {
panic(err)
}
logger.Infof("k8s test plugin listening on %s", driverPath)
http.Serve(l, router)
l.Close()
logger.Infof("k8s test plugin closing %s", driverPath)
}()
}
示例4: main
func main() {
startTime := currentTimeMillis()
transportFactory := thrift.NewTFramedTransportFactory(thrift.NewTTransportFactory())
protocolFactory := thrift.NewTBinaryProtocolFactoryDefault()
transport, err := thrift.NewTSocket(NETWORK_ADDR)
if err != nil {
logrus.Fatal(os.Stderr, "error resolving address:", err)
}
useTransport := transportFactory.GetTransport(transport)
client := rpc.NewSessionManagerClientFactory(useTransport, protocolFactory)
if err := transport.Open(); err != nil {
logrus.Fatal(os.Stderr, "Error opening socket to "+NETWORK_ADDR, err)
}
defer transport.Close()
// 開始調用服務的接口
ctx := rpc.NewSessionContext()
sid, _ := client.CreateSession(ctx)
logrus.Infof("創新新的會話id => %s", sid)
ctx, _ = client.GetSession(sid)
logrus.Infof("獲取會話上下文 => %+v", ctx)
endTime := currentTimeMillis()
logrus.Infof("本次調用用時: %d 毫秒", endTime-startTime)
}
示例5: AddNodesHandler
func (p *Resource) AddNodesHandler(req *restful.Request, resp *restful.Response) {
logrus.Infof("AddNodesHandler is called!")
// Stub an repairpolicy to be populated from the body
request := entity.AddNodeRequest{}
// Populate the user data
err := json.NewDecoder(req.Request.Body).Decode(&request)
logrus.Infof("Username is %v", request.UserName)
logrus.Infof("Cluster is %v", request.ClusterName)
logrus.Infof("CreateNumber is %v", request.CreateNumber)
if err != nil {
logrus.Errorf("convert body to AddNodesRequest failed, error is %v", err)
response.WriteStatusError(services.COMMON_ERROR_INVALIDATE, err, resp)
return
}
servers, code, err := services.GetDeployService().CreateNode(request)
var res response.Response
if err != nil {
errObj := response.Error{Code: code, ErrorMsg: fmt.Sprintf("%v", err)}
res = response.Response{Success: true, Error: &errObj, Data: servers}
} else {
res = response.Response{Success: true, Data: servers}
}
resp.WriteEntity(res)
return
}
示例6: DeleteClusterHandler
func (p *Resource) DeleteClusterHandler(req *restful.Request, resp *restful.Response) {
logrus.Infof("DeleteClusterHandler is called!")
// Stub an repairpolicy to be populated from the body
request := entity.DeleteRequest{}
// Populate the user data
err := json.NewDecoder(req.Request.Body).Decode(&request)
logrus.Infof("Username is %v", request.UserName)
logrus.Infof("Cluster is %v", request.ClusterName)
logrus.Infof("Servers is %v", request.Servers)
if err != nil {
logrus.Errorf("convert body to DeleteClusterRequest failed, error is %v", err)
response.WriteStatusError(services.COMMON_ERROR_INVALIDATE, err, resp)
return
}
code, err := services.GetDeployService().DeleteCluster(request.UserName, request.ClusterName, request.Servers)
if err != nil {
response.WriteStatusError(code, err, resp)
return
}
res := response.Response{Success: true}
resp.WriteEntity(res)
return
}
示例7: NewRpcServer
// Create a new RPC server
func NewRpcServer(portNo uint16) (*rpc.Server, net.Listener) {
server := rpc.NewServer()
// Listens on a port
l, e := net.Listen("tcp", fmt.Sprintf(":%d", portNo))
if e != nil {
log.Fatal("listen error:", e)
}
log.Infof("RPC Server is listening on %s\n", l.Addr())
// run in background
go func() {
for {
conn, err := l.Accept()
if err != nil {
// if listener closed, just exit the groutine
if strings.Contains(err.Error(), "use of closed network connection") {
return
}
log.Fatal(err)
}
log.Infof("Server accepted connection to %s from %s\n", conn.LocalAddr(), conn.RemoteAddr())
go server.ServeCodec(jsonrpc.NewServerCodec(conn))
}
}()
return server, l
}
示例8: dialRpcClient
// Create a new client
func dialRpcClient(servAddr string, portNo uint16) (*rpc.Client, net.Conn) {
var client *rpc.Client
var conn net.Conn
var err error
log.Infof("Connecting to RPC server: %s:%d", servAddr, portNo)
// Retry connecting for 10sec
for i := 0; i < 10; i++ {
// Connect to the server
conn, err = net.Dial("tcp", fmt.Sprintf("%s:%d", servAddr, portNo))
if err == nil {
log.Infof("Connected to RPC server: %s:%d", servAddr, portNo)
// Create an RPC client
client = jsonrpc.NewClient(conn)
break
}
log.Warnf("Error %v connecting to %s:%s. Retrying..", err, servAddr, portNo)
// Sleep for a second and retry again
time.Sleep(1 * time.Second)
}
// If we failed to connect, report error
if client == nil {
log.Errorf("Failed to connect to Rpc server %s:%d", servAddr, portNo)
return nil, nil
}
return client, conn
}
示例9: RequestAddress
func (driver *driver) RequestAddress(a *ipamApi.RequestAddressRequest) (*ipamApi.RequestAddressResponse, error) {
log.Debugf("Address Request request: %+v", a)
if len(a.Address) > 0 {
addr := fmt.Sprintf("%s/32", a.Address)
if _, ok := driver.pool.allocatedIPs[addr]; ok {
return nil, fmt.Errorf("%s already allocated", addr)
}
resp := &ipamApi.RequestAddressResponse{
Address: addr,
}
log.Infof("Addresse request response: %+v", resp)
return resp, nil
}
again:
// just generate a random address
rand.Seed(time.Now().UnixNano())
ip := driver.pool.subnet.IP.To4()
ip[3] = byte(rand.Intn(254))
netIP := fmt.Sprintf("%s/32", ip)
log.Infof("ip:%s", netIP)
_, ok := driver.pool.allocatedIPs[netIP]
if ok {
goto again
}
driver.pool.allocatedIPs[netIP] = true
resp := &ipamApi.RequestAddressResponse{
Address: fmt.Sprintf("%s", netIP),
}
log.Infof("Addresse request response: %+v", resp)
return resp, nil
}
示例10: pluginInstall
func pluginInstall(c *cli.Context) error {
// Input validation
pluginSource := c.String("source")
if pluginSource == "" {
log.Fatal("Missing required input: source")
}
pluginBinary := c.String("bin-source")
pluginVersionTag := c.String("version")
// Install
if pluginVersionTag == "" {
log.Infof("=> Installing plugin from (%s) with latest version...", pluginSource)
} else {
log.Infof("=> Installing plugin (%s) with version (%s)...", pluginSource, pluginVersionTag)
}
plugin, version, err := plugins.InstallPlugin(pluginSource, pluginBinary, pluginVersionTag)
if err != nil {
log.Fatalf("Failed to install plugin from (%s), error: %s", pluginSource, err)
}
fmt.Println()
log.Infoln(colorstring.Greenf("Plugin (%s) with version (%s) installed ", plugin.Name, version))
if len(plugin.Description) > 0 {
fmt.Println()
fmt.Println(plugin.Description)
fmt.Println()
}
return nil
}
示例11: CopyIsoToMachineDir
func (b *B2dUtils) CopyIsoToMachineDir(isoURL, machineName string) error {
machinesDir := GetMachineDir()
machineIsoPath := filepath.Join(machinesDir, machineName, b.isoFilename)
// just in case the cache dir has been manually deleted,
// check for it and recreate it if it's gone
if _, err := os.Stat(b.imgCachePath); os.IsNotExist(err) {
log.Infof("Image cache does not exist, creating it at %s...", b.imgCachePath)
if err := os.Mkdir(b.imgCachePath, 0700); err != nil {
return err
}
}
// By default just copy the existing "cached" iso to
// the machine's directory...
if isoURL == "" {
if err := b.copyDefaultIsoToMachine(machineIsoPath); err != nil {
return err
}
} else {
// But if ISO is specified go get it directly
log.Infof("Downloading %s from %s...", b.isoFilename, isoURL)
if err := b.DownloadISO(filepath.Join(machinesDir, machineName), b.isoFilename, isoURL); err != nil {
return err
}
}
return nil
}
示例12: createSchema
// Create schema
func createSchema() {
dbDir := filepath.Dir(*flags.DBPath)
if _, err := os.Stat(dbDir); os.IsNotExist(err) {
os.MkdirAll(dbDir, 0777)
log.Infof("Created directory path=%s", dbDir)
}
db, _ := connection()
defer db.Close()
stmt, err := db.Prepare(`
CREATE TABLE notes (
uid string,
created string,
updated string,
tags string,
content string,
encrypted INTEGER DEFAULT 0,
subject TEXT
);`)
if err != nil {
if err.Error() != "table notes already exists" {
log.Panicf("Unable to prepare schema path=%s, err=%v", *flags.DBPath, err)
}
return
}
_, err = stmt.Exec()
if err != nil {
log.Errorf("Unable to create schema err=%v", err)
}
log.Infof("Schema created path=%s", *flags.DBPath)
}
示例13: Verify
// Verify does the actual check.
func (v RSAPSSVerifier) Verify(key data.Key, sig []byte, msg []byte) error {
algorithm := key.Algorithm()
var pubKey crypto.PublicKey
switch algorithm {
case data.RSAx509Key:
pemCert, _ := pem.Decode([]byte(key.Public()))
if pemCert == nil {
logrus.Infof("failed to decode PEM-encoded x509 certificate")
return ErrInvalid
}
cert, err := x509.ParseCertificate(pemCert.Bytes)
if err != nil {
logrus.Infof("failed to parse x509 certificate: %s\n", err)
return ErrInvalid
}
pubKey = cert.PublicKey
case data.RSAKey:
var err error
pubKey, err = x509.ParsePKIXPublicKey(key.Public())
if err != nil {
logrus.Infof("failed to parse public key: %s\n", err)
return ErrInvalid
}
default:
logrus.Infof("invalid key type for RSAPSS verifier: %s", algorithm)
return ErrInvalid
}
digest := sha256.Sum256(msg)
return verifyPSS(pubKey, digest[:], sig)
}
示例14: Terminate
// Terminate kills the application
func (a *App) Terminate() {
a.signalLock.Lock()
defer a.signalLock.Unlock()
a.stopPolling()
a.forAllServices(deregisterService)
// Run and wait for preStop command to exit (continues
// unconditionally so we don't worry about returned errors here)
commands.RunAndWait(a.PreStopCmd, log.Fields{"process": "PreStop"})
if a.Command == nil || a.Command.Cmd == nil ||
a.Command.Cmd.Process == nil {
// Not managing the process, so don't do anything
return
}
cmd := a.Command.Cmd // get the underlying process
if a.StopTimeout > 0 {
if err := cmd.Process.Signal(syscall.SIGTERM); err != nil {
log.Warnf("Error sending SIGTERM to application: %s", err)
} else {
time.AfterFunc(time.Duration(a.StopTimeout)*time.Second, func() {
log.Infof("Killing Process %#v", cmd.Process)
cmd.Process.Kill()
})
return
}
}
log.Infof("Killing Process %#v", a.Command.Cmd.Process)
cmd.Process.Kill()
}
示例15: handleConflict
// handleConflict takes a candidate and adds it as conflict file.
// If the conflict file already exists, it will be updated.
func handleConflict(cnd candidate) error {
log.Infof("Conflicting files: %s (own) <-> %s (remote)", cnd.ownPath, cnd.bobPath)
bobOwner, err := cnd.bobStore.Owner()
if err != nil {
return err
}
bobFile, err := cnd.bobStore.fs.LookupFile(cnd.bobPath)
if err != nil {
return err
}
conflictPath := cnd.ownPath + "." + bobOwner.ID().User() + ".conflict"
log.Infof("Creating conflict file: %s", conflictPath)
bobHash := bobFile.Hash()
bobSize := bobFile.Size()
bobKey := bobFile.Key()
_, err = stageFile(
cnd.ownStore.fs,
conflictPath,
bobHash,
bobKey,
bobSize,
bobOwner.ID(),
)
if err == ErrNoChange {
return nil
}
return err
}