Merge remote-tracking branch 'origin/master'

This commit is contained in:
钱纯净
2025-03-25 20:39:28 +08:00
6 changed files with 39 additions and 32 deletions

View File

@@ -8,6 +8,7 @@ import (
"github.com/injoyai/conv" "github.com/injoyai/conv"
"github.com/injoyai/ios" "github.com/injoyai/ios"
"github.com/injoyai/ios/client" "github.com/injoyai/ios/client"
"github.com/injoyai/ios/module/common"
"github.com/injoyai/logs" "github.com/injoyai/logs"
"github.com/injoyai/tdx/protocol" "github.com/injoyai/tdx/protocol"
"runtime/debug" "runtime/debug"
@@ -15,6 +16,16 @@ import (
"time" "time"
) )
const (
LevelNone = common.LevelNone
LevelDebug = common.LevelDebug
LevelWrite = common.LevelWrite
LevelRead = common.LevelRead
LevelInfo = common.LevelInfo
LevelError = common.LevelError
LevelAll = common.LevelAll
)
// WithDebug 是否打印通讯数据 // WithDebug 是否打印通讯数据
func WithDebug(b ...bool) client.Option { func WithDebug(b ...bool) client.Option {
return func(c *client.Client) { return func(c *client.Client) {
@@ -22,6 +33,12 @@ func WithDebug(b ...bool) client.Option {
} }
} }
func WithLevel(level int) client.Option {
return func(c *client.Client) {
c.Logger.SetLevel(level)
}
}
// WithRedial 断线重连 // WithRedial 断线重连
func WithRedial(b ...bool) client.Option { func WithRedial(b ...bool) client.Option {
return func(c *client.Client) { return func(c *client.Client) {
@@ -31,6 +48,7 @@ func WithRedial(b ...bool) client.Option {
// DialDefault 默认连接方式 // DialDefault 默认连接方式
func DialDefault(op ...client.Option) (cli *Client, err error) { func DialDefault(op ...client.Option) (cli *Client, err error) {
op = append([]client.Option{WithRedial()}, op...)
return DialHostsRange(Hosts, op...) return DialHostsRange(Hosts, op...)
} }
@@ -63,7 +81,8 @@ func DialWith(dial ios.DialFunc, op ...client.Option) (cli *Client, err error) {
} }
cli.Client, err = client.Dial(dial, func(c *client.Client) { cli.Client, err = client.Dial(dial, func(c *client.Client) {
c.Logger.Debug(false) //关闭日志打印 c.Logger.Debug(true) //关闭日志打印
c.Logger.SetLevel(LevelInfo) //设置日志级别
c.Logger.WithHEX() //以HEX显示 c.Logger.WithHEX() //以HEX显示
c.SetOption(op...) //自定义选项 c.SetOption(op...) //自定义选项
c.Event.OnReadFrom = protocol.ReadFrom //分包 c.Event.OnReadFrom = protocol.ReadFrom //分包
@@ -86,16 +105,6 @@ func DialWith(dial ios.DialFunc, op ...client.Option) (cli *Client, err error) {
go cli.Client.Run() go cli.Client.Run()
/*
部分接口需要通过代码信息计算得出
*/
codesOnce.Do(func() {
//初始化代码管理
if DefaultCodes == nil {
DefaultCodes, err = NewCodes(cli, "./codes.db")
}
})
return cli, err return cli, err
} }

View File

@@ -8,17 +8,13 @@ import (
"math" "math"
"os" "os"
"path/filepath" "path/filepath"
"sync"
"time" "time"
"xorm.io/core" "xorm.io/core"
"xorm.io/xorm" "xorm.io/xorm"
) )
// 增加单例,部分数据需要通过Codes里面的信息计算 // DefaultCodes 增加单例,部分数据需要通过Codes里面的信息计算
var ( var DefaultCodes *Codes
DefaultCodes *Codes
codesOnce sync.Once
)
func NewCodes(c *Client, filename string) (*Codes, error) { func NewCodes(c *Client, filename string) (*Codes, error) {

View File

@@ -73,7 +73,8 @@ func NewRangeDial(hosts []string) ios.DialFunc {
} }
if i < len(hosts)-1 { if i < len(hosts)-1 {
//最后一个错误返回出去 //最后一个错误返回出去
logs.Err(err) logs.Err(err, "等待2秒后尝试下一个服务地址...")
<-time.After(time.Second * 2)
} }
} }
return return

View File

@@ -16,19 +16,18 @@ func NewManage(cfg *ManageConfig, op ...client.Option) (*Manage, error) {
if cfg == nil { if cfg == nil {
cfg = &ManageConfig{} cfg = &ManageConfig{}
} }
if len(cfg.Hosts) == 0 {
cfg.Hosts = Hosts
}
if cfg.CodesDir == "" { if cfg.CodesDir == "" {
cfg.CodesDir = DefaultDatabaseDir cfg.CodesDir = DefaultDatabaseDir
} }
if cfg.WorkdayDir == "" { if cfg.WorkdayDir == "" {
cfg.WorkdayDir = DefaultDatabaseDir cfg.WorkdayDir = DefaultDatabaseDir
} }
if cfg.Dial == nil {
cfg.Dial = DialDefault
}
//代码 //代码
DefaultCodes = &Codes{} codesClient, err := cfg.Dial(op...)
codesClient, err := DialHostsRange(cfg.Hosts, op...)
if err != nil { if err != nil {
return nil, err return nil, err
} }
@@ -37,18 +36,17 @@ func NewManage(cfg *ManageConfig, op ...client.Option) (*Manage, error) {
if err != nil { if err != nil {
return nil, err return nil, err
} }
DefaultCodes = codes
//连接池 //连接池
p, err := NewPool(func() (*Client, error) { p, err := NewPool(func() (*Client, error) {
return DialHostsRange(cfg.Hosts, op...) return cfg.Dial(op...)
}, cfg.Number) }, cfg.Number)
if err != nil { if err != nil {
return nil, err return nil, err
} }
//工作日 //工作日
workdayClient, err := DialHostsRange(cfg.Hosts, op...) workdayClient, err := cfg.Dial(op...)
if err != nil { if err != nil {
return nil, err return nil, err
} }
@@ -85,8 +83,8 @@ func (this *Manage) AddWorkdayTask(spec string, f func(m *Manage)) {
} }
type ManageConfig struct { type ManageConfig struct {
Hosts []string //服务端IP Number int //客户端数量
Number int //客户端数量 CodesDir string //代码数据库位置
CodesDir string //代码数据库位置 WorkdayDir string //工作日数据库位置
WorkdayDir string //工作日数据库位置 Dial func(op ...client.Option) (cli *Client, err error) //默认连接方式
} }

View File

@@ -77,7 +77,10 @@ func (this *Kline) RisePrice() Price {
// RiseRate 涨跌比例/涨跌幅,第一个数据不准,仅做参考 // RiseRate 涨跌比例/涨跌幅,第一个数据不准,仅做参考
func (this *Kline) RiseRate() float64 { func (this *Kline) RiseRate() float64 {
return float64(this.RisePrice()) / float64(this.Open) * 100 if this.Last == 0 {
return float64(this.Close-this.Open) / float64(this.Open) * 100
}
return float64(this.Close-this.Last) / float64(this.Last) * 100
} }
type kline struct{} type kline struct{}

View File

@@ -77,7 +77,7 @@ func (this *Workday) Update() error {
now := time.Now() now := time.Now()
if lastWorkday == nil || lastWorkday.Unix < IntegerDay(now).Unix() { if lastWorkday == nil || lastWorkday.Unix < IntegerDay(now).Unix() {
resp, err := this.Client.GetKlineDayAll("sh000001") resp, err := this.Client.GetIndexDayAll("sh000001")
if err != nil { if err != nil {
logs.Err(err) logs.Err(err)
return err return err