Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

*: support create global binding #9846

Merged
merged 54 commits into from
Apr 17, 2019
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
0cebb75
plan binding:add global binding
iamzhoug37 Mar 21, 2019
4f5df56
fix tidy fmt lint
iamzhoug37 Mar 21, 2019
68ee4d8
remove blan
iamzhoug37 Mar 21, 2019
9747bff
fix fmt
iamzhoug37 Mar 21, 2019
44d4619
fix error-check
iamzhoug37 Mar 21, 2019
0d85387
fix createBindPlan originSql and bindSql unnormolize
iamzhoug37 Mar 22, 2019
150b574
fix import
iamzhoug37 Mar 22, 2019
e2dc348
add index for origin_sql and defaultDB
iamzhoug37 Mar 25, 2019
367c7cc
merge master
iamzhoug37 Mar 25, 2019
5aa25ef
fix comment
iamzhoug37 Mar 26, 2019
6c1bd81
add version update
iamzhoug37 Mar 28, 2019
ae25b95
fix go.sum
iamzhoug37 Mar 28, 2019
ea3940a
replace user session ctx with domain's session ctx
iamzhoug37 Mar 29, 2019
e9e9cb0
fix lint
iamzhoug37 Mar 29, 2019
9cadfff
fix comment
iamzhoug37 Apr 1, 2019
787564e
xx
iamzhoug37 Apr 1, 2019
2d7d6d3
fx comment
iamzhoug37 Apr 1, 2019
3416b81
fix ci
iamzhoug37 Apr 1, 2019
ecd00b4
fix version
iamzhoug37 Apr 1, 2019
1df98f0
replace originalSQL with rowId
iamzhoug37 Apr 2, 2019
91b7494
fix ci
iamzhoug37 Apr 2, 2019
8849d3d
fix comment
iamzhoug37 Apr 2, 2019
7e9d879
add privilage check
iamzhoug37 Apr 3, 2019
45c24f3
fix make lint
iamzhoug37 Apr 3, 2019
e89f6c9
create bind plan
iamzhoug37 Apr 3, 2019
d77a038
fix comment
iamzhoug37 Apr 3, 2019
520ea9e
fix comment
iamzhoug37 Apr 4, 2019
23e3b97
remove unused code
iamzhoug37 Apr 4, 2019
924145e
timestamp bugfix
iamzhoug37 Apr 4, 2019
9e539a4
Merge branch 'master' into plan-management-add-global-binding
alivxxx Apr 4, 2019
fca0e5d
Merge branch 'master' into plan-management-add-global-binding
iamzhoug37 Apr 4, 2019
debf0c3
fix undefined error
iamzhoug37 Apr 4, 2019
bd1ae07
cjrioe
iamzhoug37 Apr 4, 2019
9380e05
merge master
iamzhoug37 Apr 12, 2019
8c6e4ec
add create update cache
iamzhoug37 Apr 15, 2019
682e5af
fix comment
iamzhoug37 Apr 16, 2019
d22f5dc
fix comment
iamzhoug37 Apr 16, 2019
3527cbc
lock
iamzhoug37 Apr 16, 2019
f45010a
aa
iamzhoug37 Apr 16, 2019
fda7535
tiny refine
zz-jason Apr 16, 2019
927346a
tiny refine planner and executor
zz-jason Apr 16, 2019
d5ffa60
release lock
iamzhoug37 Apr 16, 2019
918d8d6
Merge branch 'plan-management-add-global-binding' of github.com:iamzh…
iamzhoug37 Apr 16, 2019
efc4ad3
refine mutex in handle
zz-jason Apr 16, 2019
1b59531
Merge branch 'plan-management-add-global-binding' of github.com:iamzh…
iamzhoug37 Apr 16, 2019
33a2af4
code refactor
iamzhoug37 Apr 17, 2019
8a6b7b0
fix vet
iamzhoug37 Apr 17, 2019
85fa209
remove db
iamzhoug37 Apr 17, 2019
07ccf7b
Merge branch 'master' into plan-management-add-global-binding
zz-jason Apr 17, 2019
2bbb6d4
update cache
iamzhoug37 Apr 17, 2019
3e4539a
Merge branch 'plan-management-add-global-binding' of github.com:iamzh…
iamzhoug37 Apr 17, 2019
4fac6c3
make fmt
iamzhoug37 Apr 17, 2019
603074c
add licensed
iamzhoug37 Apr 17, 2019
2f10bb5
move import
iamzhoug37 Apr 17, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix comment
  • Loading branch information
iamzhoug37 committed Apr 4, 2019
commit 520ea9e69aa259824839d11166caef4ef49c20f5
11 changes: 4 additions & 7 deletions bindinfo/bind_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ import (
"flag"
"fmt"
"os"
"sync"
"testing"

. "github.com/pingcap/check"
Expand Down Expand Up @@ -116,9 +115,8 @@ func (s *testSuite) TestBindParse(c *C) {
sql := fmt.Sprintf(`INSERT INTO mysql.bind_info(original_sql,bind_sql,default_db,status,create_time,update_time,charset,collation) VALUES ('%s', '%s', '%s', '%s', NOW(), NOW(),'%s', '%s')`,
originSQL, bindSQL, defaultDb, status, charset, collation)
tk.MustExec(sql)
var lock sync.Mutex
bindHandle := bindinfo.NewHandle(tk.Se, &lock)
bindCacheUpdater := bindinfo.NewBindCacheUpdater(tk.Se, bindHandle, s.Parser, &lock)
bindHandle := bindinfo.NewHandle(tk.Se)
bindCacheUpdater := bindinfo.NewBindCacheUpdater(tk.Se, bindHandle, s.Parser)
err := bindCacheUpdater.Update(true)
c.Check(err, IsNil)
c.Check(len(bindHandle.Get()), Equals, 1)
Expand Down Expand Up @@ -152,9 +150,8 @@ func (s *testSuite) TestGlobalBinding(c *C) {
_, err = tk.Exec("create global binding for select * from t where i>99 using select * from t use index(index_t) where i>99")
c.Assert(err, NotNil)

var lock = &sync.Mutex{}
bindHandle := bindinfo.NewHandle(tk.Se, lock)
bindCacheUpdater := bindinfo.NewBindCacheUpdater(tk.Se, bindHandle, s.Parser, lock)
bindHandle := bindinfo.NewHandle(tk.Se)
bindCacheUpdater := bindinfo.NewBindCacheUpdater(tk.Se, bindHandle, s.Parser)
err = bindCacheUpdater.Update(true)
c.Check(err, IsNil)
c.Check(len(bindHandle.Get()), Equals, 1)
Expand Down
40 changes: 12 additions & 28 deletions bindinfo/cache.go
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,6 @@ type BindCacheUpdater struct {
parser *parser.Parser
lastUpdateTime types.Time
globalHandle *Handle
lock *sync.Mutex
}

type bindRecord struct {
Expand All @@ -82,20 +81,19 @@ type bindRecord struct {
}

// NewBindCacheUpdater creates a new BindCacheUpdater.
func NewBindCacheUpdater(ctx sessionctx.Context, handle *Handle, parser *parser.Parser, lock *sync.Mutex) *BindCacheUpdater {
func NewBindCacheUpdater(ctx sessionctx.Context, handle *Handle, parser *parser.Parser) *BindCacheUpdater {
return &BindCacheUpdater{
ctx: ctx,
parser: parser,
globalHandle: handle,
lock: lock,
}
}

// NewHandle creates a Handle with a cache.
func NewHandle(ctx sessionctx.Context, lock *sync.Mutex) *Handle {
func NewHandle(ctx sessionctx.Context) *Handle {
handle := &Handle{
ctx: ctx,
lock: lock,
lock: &sync.Mutex{},
}

return handle
Expand All @@ -112,35 +110,21 @@ func (h *Handle) Get() cache {

// LoadDiff is used to load new bind info to cache bc.
func (bindCacheUpdater *BindCacheUpdater) loadDiff(sql string, bc cache) error {
bindCacheUpdater.lock.Lock()
defer bindCacheUpdater.lock.Unlock()

recordSets, err := bindCacheUpdater.ctx.(sqlexec.SQLExecutor).Execute(context.Background(), sql)
rows, _, err := bindCacheUpdater.ctx.(sqlexec.RestrictedSQLExecutor).ExecRestrictedSQL(nil, sql)
if err != nil {
return err
}

rs := recordSets[0]
defer terror.Call(rs.Close)
chkBatch := rs.NewRecordBatch()
for {
err = rs.Next(context.TODO(), chkBatch)
if err != nil || chkBatch.NumRows() == 0 {
for _, row := range rows {
record := newBindMeta(row)
err = bc.appendNode(record, bindCacheUpdater.parser)
if err != nil {
return err
}

it := chunk.NewIterator4Chunk(chkBatch.Chunk)
for row := it.Begin(); row != it.End(); row = it.Next() {
record := newBindMeta(row)
err = bc.appendNode(record, bindCacheUpdater.parser)
if err != nil {
return err
}
if record.UpdateTime.Compare(bindCacheUpdater.lastUpdateTime) == 1 {
bindCacheUpdater.lastUpdateTime = record.UpdateTime
}
if record.UpdateTime.Compare(bindCacheUpdater.lastUpdateTime) == 1 {
bindCacheUpdater.lastUpdateTime = record.UpdateTime
}
}
return nil
}

// Update updates the BindCacheUpdater's cache.
Expand Down Expand Up @@ -234,7 +218,7 @@ func (h *Handle) AddGlobalBind(originSQL, bindSQL, defaultDB, charset, collation
if err != nil {
return err
}
if len(rs) > 1 {
if len(rs) >= 1 {
chkBatch := rs[0].NewRecordBatch()
for {
err = rs[0].Next(context.TODO(), chkBatch)
Expand Down
5 changes: 2 additions & 3 deletions domain/domain.go
Original file line number Diff line number Diff line change
Expand Up @@ -784,10 +784,9 @@ func (do *Domain) BindHandle() *bindinfo.Handle {
// be called only once in BootstrapSession.
func (do *Domain) LoadBindInfoLoop(ctx sessionctx.Context, parser *parser.Parser) error {
ctx.GetSessionVars().InRestrictedSQL = true
var lock = &sync.Mutex{}
do.bindHandle = bindinfo.NewHandle(ctx, lock)
do.bindHandle = bindinfo.NewHandle(ctx)

bindCacheUpdater := bindinfo.NewBindCacheUpdater(ctx, do.BindHandle(), parser, lock)
bindCacheUpdater := bindinfo.NewBindCacheUpdater(ctx, do.BindHandle(), parser)
err := bindCacheUpdater.Update(true)
if err != nil {
return errors.Trace(err)
Expand Down