本文整理匯總了Golang中github.com/Sirupsen/logrus.Printf函數的典型用法代碼示例。如果您正苦於以下問題:Golang Printf函數的具體用法?Golang Printf怎麽用?Golang Printf使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Printf函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: EnsurePublisherNum
func (c *consulCoordinator) EnsurePublisherNum(topic StreamID, n int, stop chan struct{}) chan error {
prefix := fmt.Sprintf("dagger/publishers/%s", topic)
lastNumPublishers := -1
kv := c.client.KV()
new, errc := c.watchSet(prefix, nil)
go func() {
for {
select {
case <-stop:
return
case keys := <-new:
// if there are no publishers registered, post a new job
if len(keys) != lastNumPublishers && len(keys) < 2 {
log.Printf("[coordinator] Number of publishers of %s is %d, posting a job.", topic, len(keys))
// log.Println("Publishers: ", keys)
pair := &api.KVPair{
Key: taskPrefix + string(topic),
}
_, err := kv.Put(pair, nil)
if err != nil {
errc <- fmt.Errorf("consul error: %s", err)
}
} else { // FIXME: do this more elegantly
if len(keys) == 2 {
log.Printf("[coordinator] Number of publishers of %s is %d, not posting a job.", topic, len(keys))
// log.Println("Publishers: ", keys)
}
}
lastNumPublishers = len(keys)
}
}
}()
return errc
}
示例2: loadAsset
func loadAsset(path, defaultValue string) string {
devPath := fmt.Sprintf(
"%s/src/github.com/emccode/rexray/daemon/module/admin/html/%s",
os.Getenv("GOPATH"),
path)
if util.FileExists(devPath) {
v, _ := ioutil.ReadFile(devPath)
log.Printf("Loaded %s from %s\n", path, devPath)
return string(v)
}
exeDir, _, _ := util.GetThisPathParts()
relPath := fmt.Sprintf(
"%s/html/%s",
exeDir,
path)
if util.FileExists(relPath) {
v, _ := ioutil.ReadFile(devPath)
log.Printf("Loaded %s from %s\n", path, relPath)
return string(v)
}
return defaultValue
}
示例3: StatsListener
//StatsListener Listen for requests to serve server stats
func (s *StatsMgr) StatsListener(ip net.IP, port int, ctrlChan chan int) {
s.wg.Add(1)
go func() {
r := mux.NewRouter()
r.HandleFunc("/api/v1/stats/all", s.StatsAllJSON)
svr := &http.Server{}
svr.Handler = r
tcpaddr, err := net.ResolveTCPAddr("tcp", net.JoinHostPort(ip.String(), strconv.Itoa(port)))
if err != nil {
log.Error("Stats Listener ", err)
return
}
l, err := net.ListenTCP("tcp", tcpaddr)
log.Printf("%s now listening on %s for incoming connections", strings.Join([]string{AppName, "Stats Listener"}, " "), tcpaddr.String())
if err != nil {
log.Error("Stats Listener ", err)
return
}
if err := svr.Serve(l); err != nil {
log.Errorln(err)
}
for item := range ctrlChan {
if item == -1 {
err = l.Close()
if err != nil {
log.Println(err)
}
s.wg.Done()
log.Printf("%s shutting down", strings.Join([]string{AppName, "Stats Listener"}, " "))
return
}
}
}()
}
示例4: updatePkgSrc
// Check and update if a newer source exist for the package.
func (b *Builder) updatePkgSrc(pkg *SrcPkg) (*SrcPkg, error) {
p := pkg.PKGBUILD
if len(p.Pkgnames) > 1 || p.Pkgnames[0] != p.Pkgbase {
log.Printf("Checking for new version of %s:(%s)", p.Pkgbase, strings.Join(p.Pkgnames, ", "))
} else {
log.Printf("Checking for new version of %s", p.Pkgbase)
}
err := runCmd(pkg.Path, nil, "makepkg", "--nobuild", "--nodeps", "--noprepare", "--noconfirm")
if err != nil {
return nil, err
}
cmd := exec.Command("mksrcinfo")
cmd.Dir = pkg.Path
err = cmd.Run()
if err != nil {
return nil, err
}
filePath := path.Join(pkg.Path, ".SRCINFO")
pkgb, err := pkgbuild.ParseSRCINFO(filePath)
if err != nil {
return nil, err
}
pkg.PKGBUILD = pkgb
return pkg, nil
}
示例5: CmdDeploy
func CmdDeploy(svcName, target string, iw IWorker, is services.IServices, ij jobs.IJobs) error {
service, err := is.RetrieveByLabel(svcName)
if err != nil {
return err
}
if service == nil {
return fmt.Errorf("Could not find a service with the label \"%s\". You can list services with the \"catalyze services list\" command.", svcName)
}
logrus.Printf("Initiating a worker for service %s (procfile target = \"%s\")", svcName, target)
workers, err := iw.Retrieve(service.ID)
if err != nil {
return err
}
if _, ok := workers.Workers[target]; ok {
logrus.Printf("Worker with target %s for service %s is already running, deploying another worker", target, svcName)
}
workers.Workers[target]++
err = iw.Update(service.ID, workers)
if err != nil {
return err
}
err = ij.DeployTarget(target, service.ID)
if err != nil {
return err
}
logrus.Printf("Successfully deployed a worker for service %s with target %s", svcName, target)
return nil
}
示例6: HandleError
// HandleError parses an AWS error and exits the program
func HandleError(err error) {
if err == nil {
return
}
if awsErr, ok := err.(awserr.Error); ok {
log.Print("Code: " + awsErr.Code())
log.Print("Message: " + awsErr.Message())
if awsErr.OrigErr() != nil {
log.Printf("Orginal Error: %v", awsErr.OrigErr())
}
if reqErr, ok := err.(awserr.RequestFailure); ok {
log.Printf("Status Code: %d", reqErr.StatusCode())
if reqErr.RequestID() != "" {
log.Print("Request ID: " + reqErr.RequestID())
}
}
} else {
log.Print(err.Error())
}
os.Exit(1)
}
示例7: spProgramRW
func spProgramRW(portname string, boardname string, filePath string, commandline string, extraInfo boardExtraInfo) {
compiling = true
defer func() {
time.Sleep(1500 * time.Millisecond)
compiling = false
}()
var err error
if extraInfo.Network {
err = spProgramNetwork(portname, boardname, filePath, extraInfo.Auth)
if err != nil {
// no http method available, try ssh upload
err = spProgramSSHNetwork(portname, boardname, filePath, commandline, extraInfo.Auth)
}
} else {
err = spProgramLocal(portname, boardname, filePath, commandline, extraInfo)
}
if err != nil {
log.Printf("Command finished with error: %v", err)
mapD := map[string]string{"ProgrammerStatus": "Error", "Msg": "Could not program the board"}
mapB, _ := json.Marshal(mapD)
h.broadcastSys <- mapB
} else {
log.Printf("Finished without error. Good stuff")
mapD := map[string]string{"ProgrammerStatus": "Done", "Flash": "Ok"}
mapB, _ := json.Marshal(mapD)
h.broadcastSys <- mapB
// analyze stdin
}
}
示例8: CmdBackup
func CmdBackup(databaseName string, skipPoll bool, id IDb, is services.IServices, ij jobs.IJobs) error {
service, err := is.RetrieveByLabel(databaseName)
if err != nil {
return err
}
if service == nil {
return fmt.Errorf("Could not find a service with the label \"%s\". You can list services with the \"catalyze services\" command.", databaseName)
}
job, err := id.Backup(service)
if err != nil {
return err
}
logrus.Printf("Backup started (job ID = %s)", job.ID)
if !skipPoll {
// all because logrus treats print, println, and printf the same
logrus.StandardLogger().Out.Write([]byte("Polling until backup finishes."))
status, err := ij.PollTillFinished(job.ID, service.ID)
if err != nil {
return err
}
job.Status = status
logrus.Printf("\nEnded in status '%s'", job.Status)
err = id.DumpLogs("backup", job, service)
if err != nil {
return err
}
if job.Status != "finished" {
return fmt.Errorf("Job finished with invalid status %s", job.Status)
}
}
logrus.Printf("You can download your backup with the \"catalyze db download %s %s ./output_file_path\" command", databaseName, job.ID)
return nil
}
示例9: setupSSHListener
func setupSSHListener(port string, hostKey string) (ssh.ServerConfig, net.Listener) {
sshConfig := &ssh.ServerConfig{
PasswordCallback: func(c ssh.ConnMetadata, pass []byte) (*ssh.Permissions, error) {
remoteAddr := c.RemoteAddr().String()
ip := remoteAddr[0:strings.Index(remoteAddr, ":")]
log.Printf("SSH connection from ip=[%s], username=[%s], password=[%s], version=[%s]", ip, c.User(), pass, c.ClientVersion())
return nil, fmt.Errorf("invalid credentials")
},
}
privateBytes, err := ioutil.ReadFile(hostKey)
if err != nil {
log.Fatalf("Failed to load private key %s. Run make gen_ssh_key %s", hostKey, hostKey)
}
private, err := ssh.ParsePrivateKey(privateBytes)
if err != nil {
log.Fatal("Failed to parse private key")
}
sshConfig.AddHostKey(private)
portComplete := fmt.Sprintf(":%s", port)
listener, err := net.Listen("tcp4", portComplete)
if err != nil {
log.Fatalf("failed to listen on *:%s", port)
}
log.Printf("listening on %s", port)
return *sshConfig, listener
}
示例10: LineByLinePipe
func LineByLinePipe(cb func(string)) io.Writer {
r, w, err := os.Pipe()
if err != nil {
panic(err)
}
pipeId := RandomNumericString(5)
go func() {
log.Printf("[pipe:%s] Pipe created", pipeId)
reader := bufio.NewReader(r)
msg := ""
for {
bytes, ispr, err := reader.ReadLine()
if err != nil && err != io.EOF {
panic(err)
}
msg += string(bytes)
log.Print()
if ispr {
continue
}
line := msg
msg = ""
cb(line)
if err == io.EOF {
log.Printf("[pipe:%s] Pipe closed", pipeId)
break
}
}
}()
return w
}
示例11: main
func main() {
kingpin.Parse()
me := ec2metadata.New(session.New(), &aws.Config{})
region, err := me.Region()
if err != nil {
fmt.Println(err)
os.Exit(1)
}
cw := cloudwatch.New(session.New(&aws.Config{Region: aws.String(region)}))
as := autoscaling.New(session.New(&aws.Config{Region: aws.String(region)}))
// Get the name of this instance.
instance, err := me.GetMetadata("instance-id")
if err != nil {
fmt.Println(err)
os.Exit(1)
}
log.Printf("Instance: %s", instance)
// Check if this instance is in an auto scaling group.
gps, err := as.DescribeAutoScalingInstances(&autoscaling.DescribeAutoScalingInstancesInput{
InstanceIds: []*string{
aws.String(instance),
},
})
if err == nil && len(gps.AutoScalingInstances) > 0 {
group = *gps.AutoScalingInstances[0].AutoScalingGroupName
log.Printf("AutoScaling group: %s", group)
}
// Loop and send to the backend.
limiter := time.Tick(time.Second * 60)
for {
<-limiter
// Submit all the values.
for _, mn := range strings.Split(*cliMetrics, ",") {
m, err := metric.New(mn)
if err != nil {
log.Printf("Cannot find metric: %s" + mn)
continue
}
v, err := m.Value()
if err != nil {
log.Println("Cannot get metric.")
}
// Send the instance metrics.
Send(cw, "InstanceId", instance, m.Name(), v)
// Send the autoscaling.
if group != "" {
Send(cw, "AutoScalingGroupName", group, m.Name(), v)
}
}
}
}
示例12: UnmarshalRQL
func (r *Retain) UnmarshalRQL(data interface{}) error {
log.Printf("data %v %T", data, data)
//var rData map[string]interface{}
rData, ok := data.(map[string]interface{})
if !ok {
return fmt.Errorf("pseudo-type Retain object is not valid")
}
log.Printf("[DEBUG] %T - %v\n", rData, rData)
//if rData, ok := rData.(*retain); ok {
topic, ok := rData["topic"].(string)
if !ok {
return fmt.Errorf("Topic is not valid string")
}
r.Topic = topic
newMsg := &proto.Publish{}
r.Msg = newMsg
msg, ok := rData["msg"].(map[string]interface{})
if !ok {
return fmt.Errorf("Msg is not valid map[string]interface{} type")
}
//r.Msg = &msg
log.Printf("msg %T - %v\n", msg, msg)
log.Printf("msg %T - %v\n", msg["TopicName"], msg["TopicName"])
r.Msg.TopicName = msg["TopicName"].(string)
qos := msg["QosLevel"].(float64)
//switch?
if qos == 0 {
r.Msg.QosLevel = proto.QosAtMostOnce
} else if qos == 1 {
r.Msg.QosLevel = proto.QosAtLeastOnce
} else if qos == 2 {
r.Msg.QosLevel = proto.QosExactlyOnce
} else {
return fmt.Errorf("QosLevel is not valid QosLevel type")
}
r.Msg.DupFlag = msg["DupFlag"].(bool)
r.Msg.Retain = msg["Retain"].(bool)
msgID := msg["MessageId"].(float64)
r.Msg.MessageId = uint16(msgID)
log.Printf("payload %v", msg["Payload"])
payloadArray := msg["Payload"].([]uint8)
w := bytes.NewBuffer(payloadArray)
pay := &proto.BytesPayload{}
r.Msg.Payload = pay
r.Msg.Payload.WritePayload(w)
return nil
}
示例13: New
func New(quiet bool) *SysInfo {
sysInfo := &SysInfo{}
if cgroupMemoryMountpoint, err := cgroups.FindCgroupMountpoint("memory"); err != nil {
if !quiet {
log.Printf("WARNING: %s\n", err)
}
} else {
_, err1 := ioutil.ReadFile(path.Join(cgroupMemoryMountpoint, "memory.limit_in_bytes"))
_, err2 := ioutil.ReadFile(path.Join(cgroupMemoryMountpoint, "memory.soft_limit_in_bytes"))
sysInfo.MemoryLimit = err1 == nil && err2 == nil
if !sysInfo.MemoryLimit && !quiet {
log.Printf("WARNING: Your kernel does not support cgroup memory limit.")
}
_, err = ioutil.ReadFile(path.Join(cgroupMemoryMountpoint, "memory.memsw.limit_in_bytes"))
sysInfo.SwapLimit = err == nil
if !sysInfo.SwapLimit && !quiet {
log.Printf("WARNING: Your kernel does not support cgroup swap limit.")
}
}
// Check if AppArmor seems to be enabled on this system.
if _, err := os.Stat("/sys/kernel/security/apparmor"); os.IsNotExist(err) {
sysInfo.AppArmor = false
} else {
sysInfo.AppArmor = true
}
return sysInfo
}
示例14: Save
func (f *SFiles) Save(output string, force bool, file *models.ServiceFile) error {
filePerms, err := strconv.ParseUint(file.Mode, 8, 32)
if err != nil {
filePerms = 0644
}
var wr io.Writer
if output != "" {
if force {
os.Remove(output)
}
outFile, err := os.OpenFile(output, os.O_CREATE|os.O_RDWR, os.FileMode(filePerms))
if err != nil {
logrus.Printf("Warning! Could not apply %s file permissions. Attempting to apply defaults %s", fileModeToRWXString(filePerms), fileModeToRWXString(uint64(0644)))
outFile, err = os.OpenFile(output, os.O_CREATE|os.O_RDWR, 0644)
if err != nil {
return fmt.Errorf("Could not open %s for writing: %s", output, err.Error())
}
}
defer outFile.Close()
wr = outFile
} else {
logrus.Printf("Mode: %s\n\nContent:", fileModeToRWXString(filePerms))
wr = os.Stdout
}
wr.Write([]byte(file.Contents))
return nil
}
示例15: CmdDownload
func CmdDownload(databaseName, backupID, filePath string, force bool, id IDb, ip prompts.IPrompts, is services.IServices) error {
err := ip.PHI()
if err != nil {
return err
}
if !force {
if _, err := os.Stat(filePath); err == nil {
return fmt.Errorf("File already exists at path '%s'. Specify `--force` to overwrite", filePath)
}
} else {
os.Remove(filePath)
}
service, err := is.RetrieveByLabel(databaseName)
if err != nil {
return err
}
if service == nil {
return fmt.Errorf("Could not find a service with the label \"%s\". You can list services with the \"catalyze services\" command.", databaseName)
}
err = id.Download(backupID, filePath, service)
if err != nil {
return err
}
logrus.Printf("%s backup downloaded successfully to %s", databaseName, filePath)
logrus.Printf("You can also view logs for this backup with the \"catalyze db logs %s %s\" command", databaseName, backupID)
return nil
}