No Description
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

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