Skip to content
Snippets Groups Projects
Commit 86b38bc9 authored by Ashwin Ramesh's avatar Ashwin Ramesh
Browse files

Merge pull request #66 from dgraph-io/shardDiscovery

Change key formation, code to get list of predicates in a given store
parents 0a5d6a6c 0446dc70
No related branches found
No related tags found
No related merge requests found
/*
* Copyright 201666666 DGraph Labs, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
This package includes getting the list of predicates that a node serves
and sharing it with other nodes in the cluster.
A RAFT backed key-value store will maintain a globally consistent
mapping from a given predicate to the information of the node
that serves that predicate.
*/
package cluster
/*
* Copyright 2016 DGraph Labs, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package cluster
import (
"bytes"
"github.com/dgraph-io/dgraph/store"
"github.com/dgraph-io/dgraph/x"
)
var glog = x.Log("cluster")
func getPredicate(b []byte) string {
buf := bytes.NewBuffer(b)
a, err := buf.ReadString('|')
if err != nil {
glog.WithField("byte", b).Fatal("error retreiving predicate")
}
str := string(a[:len(a)-1]) // omit the trailing '|'
return str
}
func GetPredicateList(ps *store.Store) []string {
var predicateList []string
var lastPredicate, predicate string
it := ps.GetIterator()
for it.SeekToFirst(); it.Valid(); it.Next() {
predicate = getPredicate(it.Key())
if predicate != lastPredicate {
predicateList = append(predicateList, predicate)
lastPredicate = predicate
}
}
return predicateList
}
/*
* Copyright 2016 DGraph Labs, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
package cluster
import (
"bytes"
"encoding/binary"
"io/ioutil"
"os"
"testing"
"github.com/Sirupsen/logrus"
"github.com/dgraph-io/dgraph/posting"
"github.com/dgraph-io/dgraph/store"
)
func TestgetPredicate(t *testing.T) {
attr := "friends"
var uid uint64 = 12345
buf := bytes.NewBufferString(attr)
if err := binary.Write(buf, binary.LittleEndian, uid); err != nil {
t.Fatalf("Error while creating key with attr: %v uid: %v\n", attr, uid)
}
str := getPredicate(buf.Bytes())
if str != "friends" {
t.Error("Wrong predicate obtained")
}
}
func TestGetPredicateList(t *testing.T) {
logrus.SetLevel(logrus.DebugLevel)
dir1, err := ioutil.TempDir("", "dir_")
if err != nil {
t.Error(err)
return
}
defer os.RemoveAll(dir1)
ps1 := new(store.Store)
ps1.Init(dir1)
defer ps1.Close()
k1 := posting.Key(1000, "friend")
k2 := posting.Key(1010, "friend")
k3 := posting.Key(1020, "friend")
k4 := posting.Key(1030, "follow")
k5 := posting.Key(1040, "follow")
ps1.SetOne(k1, []byte("alice"))
ps1.SetOne(k2, []byte("bob"))
ps1.SetOne(k3, []byte("ram"))
ps1.SetOne(k4, []byte("ash"))
ps1.SetOne(k5, []byte("mallory"))
list := GetPredicateList(ps1)
if len(list) != 2 {
t.Errorf("Predicate List incorrect %v", len(list))
}
}
package cluster
type shardinfo struct {
ip string
}
......@@ -106,6 +106,7 @@ func samePosting(a *types.Posting, b *types.Posting) bool {
// key = (entity uid, attribute)
func Key(uid uint64, attr string) []byte {
buf := bytes.NewBufferString(attr)
buf.WriteRune('|')
if err := binary.Write(buf, binary.LittleEndian, uid); err != nil {
glog.Fatalf("Error while creating key with attr: %v uid: %v\n", attr, uid)
}
......
......@@ -67,6 +67,10 @@ func (s *Store) Delete(k []byte) error {
return s.db.Delete(s.wopt, k)
}
func (s *Store) GetIterator() *rocksdb.Iterator {
return s.db.NewIterator(s.ropt)
}
func (s *Store) Close() {
s.db.Close()
}
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment