server.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package server
  2. import (
  3. "github.com/getsentry/sentry-go"
  4. "github.com/langgenius/dify-plugin-daemon/internal/cluster"
  5. "github.com/langgenius/dify-plugin-daemon/internal/core/persistence"
  6. "github.com/langgenius/dify-plugin-daemon/internal/core/plugin_manager"
  7. "github.com/langgenius/dify-plugin-daemon/internal/db"
  8. "github.com/langgenius/dify-plugin-daemon/internal/oss"
  9. "github.com/langgenius/dify-plugin-daemon/internal/oss/local"
  10. "github.com/langgenius/dify-plugin-daemon/internal/oss/s3"
  11. "github.com/langgenius/dify-plugin-daemon/internal/oss/tencent_cos"
  12. "github.com/langgenius/dify-plugin-daemon/internal/types/app"
  13. "github.com/langgenius/dify-plugin-daemon/internal/utils/log"
  14. "github.com/langgenius/dify-plugin-daemon/internal/utils/routine"
  15. )
  16. func initOSS(config *app.Config) oss.OSS {
  17. // init oss
  18. var oss oss.OSS
  19. var err error
  20. if config.PluginStorageType == "aws_s3" {
  21. oss, err = s3.NewS3Storage(
  22. config.S3UseAwsManagedIam,
  23. config.S3Endpoint,
  24. config.AWSAccessKey,
  25. config.AWSSecretKey,
  26. config.PluginStorageOSSBucket,
  27. config.AWSRegion,
  28. )
  29. if err != nil {
  30. log.Panic("Failed to create s3 storage: %s", err)
  31. }
  32. } else if config.PluginStorageType == "local" {
  33. oss = local.NewLocalStorage(config.PluginStorageLocalRoot)
  34. } else if config.PluginStorageType == "tencent_cos" {
  35. oss, err = tencent_cos.NewTencentCOSStorage(
  36. config.TencentCOSSecretId,
  37. config.TencentCOSSecretKey,
  38. config.TencentCOSRegion,
  39. config.PluginStorageOSSBucket)
  40. if err != nil {
  41. log.Panic("Failed to create tencent cos storage: %s", err)
  42. }
  43. } else {
  44. log.Panic("Invalid plugin storage type: %s", config.PluginStorageType)
  45. }
  46. return oss
  47. }
  48. func (app *App) Run(config *app.Config) {
  49. // init routine pool
  50. if config.SentryEnabled {
  51. routine.InitPool(config.RoutinePoolSize, sentry.ClientOptions{
  52. Dsn: config.SentryDSN,
  53. AttachStacktrace: config.SentryAttachStacktrace,
  54. TracesSampleRate: config.SentryTracesSampleRate,
  55. SampleRate: config.SentrySampleRate,
  56. EnableTracing: config.SentryTracingEnabled,
  57. })
  58. } else {
  59. routine.InitPool(config.RoutinePoolSize)
  60. }
  61. // init db
  62. db.Init(config)
  63. // init oss
  64. oss := initOSS(config)
  65. // create manager
  66. manager := plugin_manager.InitGlobalManager(oss, config)
  67. // create cluster
  68. app.cluster = cluster.NewCluster(config, manager)
  69. // register plugin lifetime event
  70. manager.AddPluginRegisterHandler(app.cluster.RegisterPlugin)
  71. // init manager
  72. manager.Launch(config)
  73. // init persistence
  74. persistence.InitPersistence(oss, config)
  75. // launch cluster
  76. app.cluster.Launch()
  77. // start http server
  78. app.server(config)
  79. // block
  80. select {}
  81. }