本文整理匯總了Golang中github.com/pivotal-golang/lager.NewLogger函數的典型用法代碼示例。如果您正苦於以下問題:Golang NewLogger函數的具體用法?Golang NewLogger怎麽用?Golang NewLogger使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了NewLogger函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: main
func main() {
configPath := flag.String("agentConfig", "", "Agent config yaml")
flag.Parse()
logger := lager.NewLogger("redis-agent")
logger.RegisterSink(lager.NewWriterSink(os.Stdout, lager.DEBUG))
logger.RegisterSink(lager.NewWriterSink(os.Stderr, lager.ERROR))
config, err := agentconfig.Load(*configPath)
if err != nil {
logger.Fatal("Error loading config file", err, lager.Data{
"path": *configPath,
})
}
templateRedisConf(config, logger)
redisResetter := resetter.New(
config.DefaultConfPath,
config.ConfPath,
portChecker{},
commandRunner{},
config.MonitExecutablePath,
)
handler := auth.NewWrapper(
config.AuthConfiguration.Username,
config.AuthConfiguration.Password,
).Wrap(
agentapi.New(redisResetter, config.ConfPath),
)
http.Handle("/", handler)
logger.Fatal("http-listen", http.ListenAndServe("localhost:"+config.Port, nil))
}
示例2: NewBroker
// NewBroker is a constructor for a Broker webapp struct
func NewBroker() (subway *Broker) {
subway = &Broker{}
subway.Logger = lager.NewLogger("cf-subway")
subway.Logger.RegisterSink(lager.NewWriterSink(os.Stdout, lager.DEBUG))
subway.Logger.RegisterSink(lager.NewWriterSink(os.Stderr, lager.ERROR))
return subway
}
示例3: SpinUp
func (f *FakeCell) SpinUp(serviceClient bbs.ServiceClient) {
//make a test-friendly AuctionRepDelegate using the auction package's SimulationRepDelegate
f.SimulationRep = simulationrep.New(f.stack, "Z0", rep.Resources{
DiskMB: 100,
MemoryMB: 100,
Containers: 100,
})
//spin up an http auction server
logger := lager.NewLogger(f.cellID)
logger.RegisterSink(lager.NewWriterSink(GinkgoWriter, lager.INFO))
fakeLRPStopper := new(fake_lrp_stopper.FakeLRPStopper)
fakeExecutorClient := new(executorfakes.FakeClient)
fakeEvacuatable := new(fake_evacuation_context.FakeEvacuatable)
handlers := rephandlers.New(f.SimulationRep, fakeLRPStopper, fakeExecutorClient, fakeEvacuatable, logger)
router, err := rata.NewRouter(rep.Routes, handlers)
Expect(err).NotTo(HaveOccurred())
f.server = httptest.NewServer(router)
presence := models.NewCellPresence(
f.cellID,
f.server.URL,
"az1",
models.NewCellCapacity(512, 1024, 124),
[]string{},
[]string{})
f.heartbeater = ifrit.Invoke(serviceClient.NewCellPresenceRunner(logger, &presence, time.Second))
}
示例4: main
func main() {
logger = lager.NewLogger("nats-to-syslog")
stop = make(chan bool)
buffer := make(chan *nats.Msg, 1000)
trapSignals()
var natsUri = flag.String("nats-uri", "nats://localhost:4222", "The NATS server URI")
var natsSubject = flag.String("nats-subject", ">", "The NATS subject to subscribe to")
var syslogEndpoint = flag.String("syslog-endpoint", "localhost:514", "The remote syslog server host:port")
var debug = flag.Bool("debug", false, "debug logging true/false")
flag.Parse()
setupLogger(*debug)
syslog := connectToSyslog(*syslogEndpoint)
defer syslog.Close()
natsClient := connectToNATS(*natsUri)
defer natsClient.Close()
go func() {
for message := range buffer {
sendToSyslog(message, syslog)
}
}()
natsClient.Subscribe(*natsSubject, func(message *nats.Msg) {
buffer <- message
})
logger.Info("subscribed-to-subject", lager.Data{"subject": *natsSubject})
<-stop
logger.Info("bye.")
}
示例5: main
func main() {
flag.Parse()
logger := lager.NewLogger("cf-rabbitmq-broker")
logger.RegisterSink(lager.NewWriterSink(os.Stdout, lager.INFO))
logger.RegisterSink(lager.NewWriterSink(os.Stderr, lager.ERROR))
rand.Seed(time.Now().UTC().UnixNano())
config, err := rabbitbroker.ReadConfig(configPath)
if err != nil {
logger.Fatal("read-config", err)
}
client, _ := rabbithole.NewClient(
fmt.Sprintf("http://%s:15672", config.Rabbitmq.Hosts[0]),
config.Rabbitmq.Administrator.Username,
config.Rabbitmq.Administrator.Password)
serviceBroker := rabbitbroker.New(config, client, rabbitbroker.RandomCredentialsGenerator{}, logger, rabbitbroker.BindingInfoResource{ProtocolInfo: rabbitbroker.ProtocolInfoResource{}})
credentials := brokerapi.BrokerCredentials{
Username: config.Service.Username,
Password: config.Service.Password,
}
http.Handle("/", brokerapi.New(serviceBroker, logger, credentials))
logger.Info("starting-server")
if err := http.ListenAndServe(":4567", nil); err != nil {
logger.Fatal("starting-server-failed", err)
}
}
示例6: New
func New(writer io.Writer) *GinkgoReporter {
logger := lager.NewLogger("ginkgo")
logger.RegisterSink(lager.NewWriterSink(writer, lager.DEBUG))
return &GinkgoReporter{
writer: writer,
logger: logger,
}
}
示例7: NewTestLogger
func NewTestLogger(component string) *TestLogger {
logger := lager.NewLogger(component)
testSink := NewTestSink()
logger.RegisterSink(testSink)
logger.RegisterSink(lager.NewWriterSink(ginkgo.GinkgoWriter, lager.DEBUG))
return &TestLogger{logger, testSink}
}
示例8: NewTestLogger
func NewTestLogger(component string) *TestLogger {
logger := lager.NewLogger(component)
testSink := NewTestSink()
logger.RegisterSink(testSink)
return &TestLogger{logger, testSink}
}
示例9: main
// initd listens on a socket, spawns requested processes and reaps their
// exit statuses.
func main() {
defer func() {
if r := recover(); r != nil {
fmt.Fprintf(os.Stderr, "initd: panicked: %s\n", r)
os.Exit(4)
}
}()
dropCaps := flag.Bool("dropCapabilities", false, "drop capabilities before running processes")
flag.Parse()
container_daemon.Detach("/dev/null", "/dev/null")
logger := lager.NewLogger("initd")
syncWriter := os.NewFile(uintptr(4), "/dev/sync_writer")
syscall.RawSyscall(syscall.SYS_FCNTL, uintptr(4), syscall.F_SETFD, syscall.FD_CLOEXEC)
defer syncWriter.Close()
sync := &containerizer.PipeSynchronizer{
Writer: syncWriter,
}
reaper := system.StartReaper(logger)
defer reaper.Stop()
daemon := &container_daemon.ContainerDaemon{
CmdPreparer: &container_daemon.ProcessSpecPreparer{
Users: container_daemon.LibContainerUser{},
Rlimits: &container_daemon.RlimitsManager{},
ProcStarterPath: "/sbin/proc_starter",
AlwaysDropCapabilities: *dropCaps,
},
Spawner: &container_daemon.Spawn{
Runner: reaper,
PTY: system.KrPty,
},
}
socketFile := os.NewFile(uintptr(5), "/dev/host.sock")
listener, err := unix_socket.NewListenerFromFile(socketFile)
if err != nil {
fail(fmt.Sprintf("initd: failed to create listener: %s\n", err), 5)
}
socketFile.Close()
if err := sync.SignalSuccess(); err != nil {
fail(fmt.Sprintf("signal host: %s", err), 6)
}
if err := daemon.Run(listener); err != nil {
fail(fmt.Sprintf("run daemon: %s", err), 7)
}
}
示例10: main
func main() {
logger := lager.NewLogger("checkin")
logger.RegisterSink(lager.NewWriterSink(os.Stdout, lager.INFO))
var opts Opts
_, err := flags.Parse(&opts)
if err != nil {
logger.Error("parsing-flags", err)
os.Exit(1)
}
// ts := oauth2.StaticTokenSource(
// &oauth2.Token{AccessToken: opts.GitHubAccessToken},
// )
// tc := oauth2.NewClient(oauth2.NoContext, ts)
// githubClient := github.NewClient(tc)
// checker := build.NewConcourseChecker()
// checker = build.NewStatusReporter(checker, githubClient.Repositories)
dbConn, err := migration.Open(opts.DBDriver, opts.DBURL, migrations.Migrations)
if err != nil {
logger.Error("failed-to-run-migrations", err)
os.Exit(1)
}
sqlDB := db.NewSQL(logger.Session("db"), dbConn)
enqueuer := build.NewEnqueuer(sqlDB)
apiServer := api.NewServer(opts.GitHubSecret, enqueuer)
members := []grouper.Member{
{
"api",
http_server.New(
opts.Addr,
apiServer,
),
},
}
group := grouper.NewParallel(os.Interrupt, members)
running := ifrit.Invoke(sigmon.New(group))
logger.Info("listening", lager.Data{
"api": opts.Addr,
})
err = <-running.Wait()
if err != nil {
fmt.Fprintln(os.Stderr, err)
os.Exit(1)
}
}
示例11: buildLogger
func buildLogger(logLevel string) lager.Logger {
laggerLogLevel, ok := logLevels[strings.ToUpper(logLevel)]
if !ok {
log.Fatal("Invalid log level: ", logLevel)
}
logger := lager.NewLogger("rds-broker")
logger.RegisterSink(lager.NewWriterSink(os.Stdout, laggerLogLevel))
return logger
}
示例12: logger
func logger() lager.Logger {
logger := lager.NewLogger("ltc")
var logLevel lager.LogLevel
if os.Getenv("LTC_LOG_LEVEL") == "DEBUG" {
logLevel = lager.DEBUG
} else {
logLevel = lager.INFO
}
logger.RegisterSink(lager.NewWriterSink(os.Stderr, logLevel))
return logger
}
示例13: main
func main() {
var port string
serviceBroker := &myServiceBroker{}
logger := lager.NewLogger("my-service-broker")
credentials := brokerapi.BrokerCredentials{
Username: "blah",
Password: "password",
}
port = os.Getenv("VCAP_APP_PORT")
brokerAPI := brokerapi.New(serviceBroker, logger, credentials)
http.Handle("/", brokerAPI)
http.ListenAndServe("0.0.0.0:"+port, nil)
}
示例14: main
func main() {
flag.Parse()
logger := lager.NewLogger("lattice-app")
if quiet {
logger.RegisterSink(lager.NewWriterSink(os.Stdout, lager.INFO))
} else {
logger.RegisterSink(lager.NewWriterSink(os.Stdout, lager.DEBUG))
}
ports := getServerPorts()
logger.Info("lattice-app.starting", lager.Data{"ports": ports})
handler, err := rata.NewRouter(routes.Routes, handlers.New(logger))
if err != nil {
logger.Fatal("router.creation.failed", err)
}
index, err := helpers.FetchIndex()
appName := fetchAppName()
go func() {
t := time.NewTicker(time.Second)
for {
<-t.C
if err != nil {
fmt.Fprintf(os.Stderr, "Failed to fetch index: %s\n", err.Error())
} else {
fmt.Println(fmt.Sprintf("%s. Says %s. on index: %d", appName, message, index))
}
}
}()
wg := sync.WaitGroup{}
for _, port := range ports {
wg.Add(1)
go func(wg *sync.WaitGroup, port string) {
defer wg.Done()
server := ifrit.Envoke(http_server.New(":"+port, handler))
logger.Info("lattice-app.up", lager.Data{"port": port})
err = <-server.Wait()
if err != nil {
logger.Error("shutting down server", err, lager.Data{"server port": port})
}
logger.Info("shutting down server", lager.Data{"server port": port})
}(&wg, port)
}
wg.Wait()
logger.Info("shutting latice app")
}
示例15: main
func main() {
logger := lager.NewLogger("garden-lame")
logger.RegisterSink(lager.NewWriterSink(os.Stdout, lager.DEBUG))
client := NewLameClient(logger)
backend := lameBackend{logger: logger, Client: client}
srv := server.New("tcp", ":3000", 5*time.Minute, &backend, logger)
srv.Start()
exit := make(chan os.Signal)
signal.Notify(exit, syscall.SIGINT, syscall.SIGTERM, syscall.SIGHUP)
<-exit
srv.Stop()
}