Ingen beskrivning
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

main.go 3.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. package main
  2. import (
  3. "log"
  4. "net/http"
  5. "git.x2erp.com/qdy/go-svc-mcp/internal/handler"
  6. "git.x2erp.com/qdy/go-svc-mcp/internal/mcp"
  7. _ "git.x2erp.com/qdy/go-svc-mcp/internal/tools" // 触发工具自动注册
  8. "git.x2erp.com/qdy/go-base/authbase"
  9. "git.x2erp.com/qdy/go-base/config"
  10. "git.x2erp.com/qdy/go-base/container"
  11. "git.x2erp.com/qdy/go-base/graceful"
  12. "git.x2erp.com/qdy/go-base/logger"
  13. "git.x2erp.com/qdy/go-base/webx"
  14. "git.x2erp.com/qdy/go-base/webx/router"
  15. "git.x2erp.com/qdy/go-db/factory/database"
  16. "git.x2erp.com/qdy/go-db/sqldef"
  17. mcpsdk "github.com/modelcontextprotocol/go-sdk/mcp"
  18. _ "git.x2erp.com/qdy/go-svc-mcp/internal/tables" // 导入表定义包,触发 init() 函数
  19. )
  20. var (
  21. appName = "svc-mcp"
  22. appVersion = "1"
  23. )
  24. func main() {
  25. // 0. 初始化日志
  26. logBootFactory := logger.InitBootLog()
  27. // 1. 获取配置文件
  28. cfg := config.GetConfig()
  29. cfg.SetAppName(appName)
  30. cfg.SetAppVersion(appVersion)
  31. // 2. 创建关闭容器
  32. ctr := container.NewContainer(cfg)
  33. // 注册日志,实现自动关闭
  34. container.Reg(ctr, logBootFactory)
  35. // 3. 创建数据库工厂
  36. dbFactory := container.Create(ctr, database.CreateDBFactory)
  37. dbFactory.TestConnection()
  38. // 创建表
  39. creteTabel(dbFactory)
  40. // 创建mongodb
  41. //mongoDBFactory := container.Create(ctr, mongodb.CreateFactory)
  42. //mongoDBFactory.TestConnection()
  43. // 创建mcpservice
  44. mcpServer := createMcpService(cfg, dbFactory)
  45. //启用运行日志
  46. container.Create(ctr, logger.InitRuntimeLogger)
  47. //建立httpservice
  48. webxService := createMHttpService(cfg, dbFactory)
  49. //等待关闭
  50. graceful.WaitForShutdown(cfg.GetServiceConfig().ServiceName, ctr, mcpServer.GetHTTPServer(), webxService.GetServer())
  51. }
  52. // 创建httpService
  53. func createMHttpService(cfg config.IConfig, dbFactory *database.DBFactory) *webx.WebService {
  54. //得到webservice服务工厂
  55. webxFactory := webx.GetWebServiceFactory()
  56. //建立hhtpService服务
  57. webServcie, _ := webxFactory.CreateService(cfg.GetServiceConfig())
  58. //建立路由-api
  59. routerService := router.NewWebService(webServcie.GetRouter())
  60. //注册路由--api
  61. handler.RegisterRouter(routerService, dbFactory)
  62. //启动服务
  63. webServcie.Run()
  64. return webServcie
  65. }
  66. // createMcpService 创建mcpService
  67. func createMcpService(cfg config.IConfig, dbFactory *database.DBFactory) *mcp.Server {
  68. // 4. 创建基础请求上下文(可从配置或认证中提取)
  69. //baseCtx := &ctx.RequestContext{
  70. // TenantID: "default-tenant", // 实际应从认证中间件获取
  71. //}
  72. // 5. 创建 MCP 服务器
  73. mcpServer, err := mcp.NewServer(mcp.Config{
  74. Name: appName,
  75. Version: appVersion,
  76. Description: "MCP 工具服务,提供自动注册发现和依赖注入",
  77. DBFactory: dbFactory,
  78. Port: cfg.GetMcpServiceConfig().Port,
  79. ServiceName: cfg.GetMcpServiceConfig().ServiceName,
  80. })
  81. if err != nil {
  82. log.Fatalf("Failed to create MCP server: %v", err)
  83. }
  84. log.Printf("MCP server created with tools registered")
  85. // 6. 获取 SDK 服务器实例
  86. sdkServer := mcpServer.GetSDKServer()
  87. mcpHandler := mcpsdk.NewStreamableHTTPHandler(func(req *http.Request) *mcpsdk.Server {
  88. return sdkServer
  89. }, nil)
  90. // 包装验证中间件
  91. //handler := auth.AuthMiddlewareMcp(mcpHandler, dbFactory)
  92. handler := authbase.TokenAuth(mcpHandler)
  93. mcpServer.Run(handler)
  94. return mcpServer
  95. }
  96. func creteTabel(factory *database.DBFactory) {
  97. // 获取数据库连接和类型
  98. db := factory.GetDB()
  99. dbType := factory.GetDBType()
  100. // 创建表同步器
  101. syncer, err := sqldef.NewTableSyncer(db, dbType)
  102. if err != nil {
  103. log.Printf("创建 - 建立器失败: %v", err)
  104. return
  105. }
  106. // 创建表
  107. if err := syncer.CreateTables(); err != nil {
  108. log.Printf("建表失败: %v", err)
  109. return
  110. }
  111. log.Println("数据库表建立完成!")
  112. }