我有以下项目结构:
myGithubProject/ |---- cmd |----- command |----- hello.go |---- internal |----- template |----- template.go |----- log |----- logger.go main.go
和log
处于template
同一级别(在内部包下) 在logger.go
我使用logrus
一些配置作为记录器时,我想使用包logger.go
内的对象template
。我应该如何以干净的方式做到这一点?
import logger
目前我在我的文件中使用它template.go
,
在包下,internal
我有6
更多packages
需要这个的东西logger
。他们每个人都依赖于它。(在log
包装上),有没有很好的去处理它?
更新:
如果我有更多需要传递的东西(比如记录器),这里的方法/模式是什么?也许使用dependency injection
?interface
?其他清洁方法...
我需要一些最佳实践的完整示例,我如何在文件logger
内部hello.go
以及template.go
.
这是我的项目
cliProject/main.go
package main
import (
"cliProject/cmd"
"cliProject/internal/logs"
)
func main() {
cmd.Execute()
logs.Logger.Error("starting")
}
**cliProject/cmd/root.go**
package cmd
import (
"fmt"
"github.com/spf13/cobra"
)
var rootCmd = &cobra.Command{
Use: "cliProject",
Short: "A brief description of your application",
}
func Execute() {
if err := rootCmd.Execute(); err != nil {
fmt.Println(err)
}
}
**cliProject/cmd/serve.go**
package cmd
import (
"cliProject/internal/logs"
"fmt"
"github.com/spf13/cobra"
)
// serveCmd represents the serve command
var serveCmd = &cobra.Command{
Use: "serve",
Short: "A brief description of your command",
Run: func(cmd *cobra.Command, args []string) {
fmt.Println("serve called")
startServe()
stoppingServe()
},
}
func init() {
rootCmd.AddCommand(serveCmd)
serveCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
}
func startServe() {
logs.Logger.Error("starting from function serve")
}
func stoppingServe() {
logs.Logger.Error("stoping from function serve")
}
**cliProject/cmd/start.go**
package cmd
import (
"cliProject/internal/logs"
"github.com/spf13/cobra"
)
这是它的样子
料青山看我应如是
慕尼黑8549860
哈士奇WWW
相关分类