|
@@ -61,19 +61,23 @@ var topicAmount int
|
|
var archiveTopicAmount int
|
|
var archiveTopicAmount int
|
|
|
|
|
|
// every roundsBeforeUpdate the client updates his pirQuery
|
|
// every roundsBeforeUpdate the client updates his pirQuery
|
|
-const roundsBeforeUpdate = 1
|
|
|
|
|
|
+const roundsBeforeUpdate = 5
|
|
const neededSubscriptions = 1
|
|
const neededSubscriptions = 1
|
|
const numThreads = 12
|
|
const numThreads = 12
|
|
-const dataLength = 128
|
|
|
|
|
|
+const dataLength = 64
|
|
|
|
+const minDBWriteSize = 1000
|
|
|
|
|
|
-var dbWriteSize int = 100
|
|
|
|
|
|
+var dbWriteSize float64 = 20000
|
|
|
|
+var collisionCounter []float64
|
|
|
|
|
|
-const minDBWriteSize int = 10
|
|
|
|
|
|
+var maxTimePerRound time.Duration = 100 * time.Second
|
|
|
|
|
|
-var maxTimePerRound time.Duration = 5 * time.Second
|
|
|
|
|
|
+var clientsServedPhase1 []int
|
|
|
|
+var clientsServedPhase3 []int
|
|
|
|
|
|
-var clientsServedPhase1 int = 0
|
|
|
|
-var clientsServedPhase3 int = 0
|
|
|
|
|
|
+var startPhase1 time.Time
|
|
|
|
+var startPhase2 time.Time
|
|
|
|
+var startPhase3 time.Time
|
|
|
|
|
|
//counts the number of rounds
|
|
//counts the number of rounds
|
|
var round int = 0
|
|
var round int = 0
|
|
@@ -85,7 +89,7 @@ var phase1Channel = make(chan net.Conn, maxNumberOfClients)
|
|
var phase3Channel = make(chan net.Conn, maxNumberOfClients)
|
|
var phase3Channel = make(chan net.Conn, maxNumberOfClients)
|
|
|
|
|
|
//variables for calculating the dbWrite size
|
|
//variables for calculating the dbWrite size
|
|
-const publisherRounds int = 3
|
|
|
|
|
|
+const publisherRounds int = 10
|
|
|
|
|
|
var publisherAmount float64
|
|
var publisherAmount float64
|
|
var publisherHistory [publisherRounds]int
|
|
var publisherHistory [publisherRounds]int
|
|
@@ -96,6 +100,9 @@ func main() {
|
|
//prevents race conditions for wrtiting
|
|
//prevents race conditions for wrtiting
|
|
m := &sync.RWMutex{}
|
|
m := &sync.RWMutex{}
|
|
|
|
|
|
|
|
+ clientsServedPhase1 := make([]int, 1000)
|
|
|
|
+ clientsServedPhase3 := make([]int, 1000)
|
|
|
|
+
|
|
generatedPublicKey, generatedPrivateKey, err := box.GenerateKey(rand.Reader)
|
|
generatedPublicKey, generatedPrivateKey, err := box.GenerateKey(rand.Reader)
|
|
if err != nil {
|
|
if err != nil {
|
|
panic(err)
|
|
panic(err)
|
|
@@ -224,6 +231,13 @@ func main() {
|
|
break
|
|
break
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ _, err = clientConnection.Write(intToByte(startTime.Second()))
|
|
|
|
+ if err != nil {
|
|
|
|
+ fmt.Println("error", err)
|
|
|
|
+ clientConnection.Close()
|
|
|
|
+ break
|
|
|
|
+ }
|
|
|
|
+
|
|
clientPublicKey = &tmpClientPublicKey
|
|
clientPublicKey = &tmpClientPublicKey
|
|
|
|
|
|
//this is the key for map(client data)
|
|
//this is the key for map(client data)
|
|
@@ -248,30 +262,28 @@ func main() {
|
|
phase := make([]byte, 1)
|
|
phase := make([]byte, 1)
|
|
|
|
|
|
for {
|
|
for {
|
|
-
|
|
|
|
startTime = time.Now()
|
|
startTime = time.Now()
|
|
|
|
+ startPhase1 = time.Now()
|
|
|
|
+
|
|
phase[0] = 1
|
|
phase[0] = 1
|
|
|
|
|
|
round++
|
|
round++
|
|
|
|
|
|
- fmt.Println("clientsServedPhase1", clientsServedPhase1)
|
|
|
|
- fmt.Println("clientsServedPhase3", clientsServedPhase3)
|
|
|
|
|
|
+ fmt.Println("clientsServedPhase1", clientsServedPhase1[round-1])
|
|
|
|
+ fmt.Println("clientsServedPhase3", clientsServedPhase3[round-1])
|
|
fmt.Println("dbWriteSize", dbWriteSize)
|
|
fmt.Println("dbWriteSize", dbWriteSize)
|
|
|
|
|
|
- clientsServedPhase1 = 0
|
|
|
|
- clientsServedPhase3 = 0
|
|
|
|
-
|
|
|
|
fmt.Println("Phase 1 Round", round)
|
|
fmt.Println("Phase 1 Round", round)
|
|
|
|
|
|
//creates a new write Db for this round
|
|
//creates a new write Db for this round
|
|
- for i := 0; i < dbWriteSize; i++ {
|
|
|
|
|
|
+ for i := 0; i < int(dbWriteSize); i++ {
|
|
C.createDb(C.int(1), C.int(dataLength))
|
|
C.createDb(C.int(1), C.int(dataLength))
|
|
}
|
|
}
|
|
|
|
|
|
//creates a new db containing virtual addresses for auditing
|
|
//creates a new db containing virtual addresses for auditing
|
|
virtualAddresses := createVirtualAddresses()
|
|
virtualAddresses := createVirtualAddresses()
|
|
//send all virtualAddresses to follower
|
|
//send all virtualAddresses to follower
|
|
- for i := 0; i <= dbWriteSize; i++ {
|
|
|
|
|
|
+ for i := 0; i <= int(dbWriteSize); i++ {
|
|
writeTo(followerConnection, intToByte(virtualAddresses[i]))
|
|
writeTo(followerConnection, intToByte(virtualAddresses[i]))
|
|
}
|
|
}
|
|
|
|
|
|
@@ -289,8 +301,12 @@ func main() {
|
|
|
|
|
|
wg.Wait()
|
|
wg.Wait()
|
|
|
|
|
|
|
|
+ fmt.Println("fullDurationPhase1", time.Since(startPhase1).Seconds())
|
|
|
|
+
|
|
//Phase 2
|
|
//Phase 2
|
|
|
|
|
|
|
|
+ startPhase2 = time.Now()
|
|
|
|
+
|
|
followerConnection, err := tls.Dial("tcp", follower, conf)
|
|
followerConnection, err := tls.Dial("tcp", follower, conf)
|
|
if err != nil {
|
|
if err != nil {
|
|
panic(err)
|
|
panic(err)
|
|
@@ -299,8 +315,12 @@ func main() {
|
|
|
|
|
|
phase2(followerConnection)
|
|
phase2(followerConnection)
|
|
|
|
|
|
|
|
+ fmt.Println("fullDurationPhase2", time.Since(startPhase2).Seconds())
|
|
|
|
+
|
|
//Phase 3
|
|
//Phase 3
|
|
|
|
|
|
|
|
+ startPhase3 = time.Now()
|
|
|
|
+
|
|
//no tweets -> continue to phase 1 and mb get tweets
|
|
//no tweets -> continue to phase 1 and mb get tweets
|
|
topicList, topicAmount = lib.GetTopicList(0)
|
|
topicList, topicAmount = lib.GetTopicList(0)
|
|
if len(topicList) == 0 {
|
|
if len(topicList) == 0 {
|
|
@@ -323,6 +343,8 @@ func main() {
|
|
|
|
|
|
wg.Wait()
|
|
wg.Wait()
|
|
|
|
|
|
|
|
+ fmt.Println("fullDurationPhase3", time.Since(startPhase3).Seconds())
|
|
|
|
+
|
|
lib.CleanUpdbR(round)
|
|
lib.CleanUpdbR(round)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -345,7 +367,12 @@ func phase1(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
}
|
|
}
|
|
|
|
|
|
for clientConnection := range phase1Channel {
|
|
for clientConnection := range phase1Channel {
|
|
- clientsServedPhase1++
|
|
|
|
|
|
+ clientsServedPhase1[round] = clientsServedPhase1[round] + 1
|
|
|
|
+
|
|
|
|
+ if clientsServedPhase1[round]%1000 == 0 {
|
|
|
|
+ fmt.Println("clientsServedPhase1", clientsServedPhase1[round])
|
|
|
|
+ fmt.Println("timeTaken", time.Since(startPhase1))
|
|
|
|
+ }
|
|
|
|
|
|
gotClient[0] = 1
|
|
gotClient[0] = 1
|
|
//tells follower that this worker got a clientConnection
|
|
//tells follower that this worker got a clientConnection
|
|
@@ -376,7 +403,7 @@ func phase1(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
}
|
|
}
|
|
|
|
|
|
//tells client current dbWriteSize
|
|
//tells client current dbWriteSize
|
|
- errorBool = writeToWError(clientConnection, intToByte(dbWriteSize), followerConnection, 5)
|
|
|
|
|
|
+ errorBool = writeToWError(clientConnection, intToByte(int(dbWriteSize)), followerConnection, 5)
|
|
if errorBool {
|
|
if errorBool {
|
|
contBool := handleClientDC(wg, followerConnection, phase1Channel)
|
|
contBool := handleClientDC(wg, followerConnection, phase1Channel)
|
|
if contBool {
|
|
if contBool {
|
|
@@ -397,6 +424,8 @@ func phase1(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ //begin auditing
|
|
|
|
+ auditingStart := time.Now()
|
|
m.RLock()
|
|
m.RLock()
|
|
var clientKeys = clientData[clientConnection.RemoteAddr()]
|
|
var clientKeys = clientData[clientConnection.RemoteAddr()]
|
|
m.RUnlock()
|
|
m.RUnlock()
|
|
@@ -419,6 +448,10 @@ func phase1(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ if id == 0 {
|
|
|
|
+ fmt.Println("Auditing duration", time.Since(auditingStart))
|
|
|
|
+ }
|
|
|
|
+
|
|
m.Lock()
|
|
m.Lock()
|
|
clientData[clientConnection.RemoteAddr()] = clientKeys
|
|
clientData[clientConnection.RemoteAddr()] = clientKeys
|
|
m.Unlock()
|
|
m.Unlock()
|
|
@@ -470,7 +503,7 @@ func phase1(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
|
|
|
|
ds := int(C.db[0].dataSize)
|
|
ds := int(C.db[0].dataSize)
|
|
dataShareLeader := make([]byte, ds)
|
|
dataShareLeader := make([]byte, ds)
|
|
- pos := C.getUint128_t(C.int(virtualAddresses[dbWriteSize]))
|
|
|
|
|
|
+ pos := C.getUint128_t(C.int(virtualAddresses[int(dbWriteSize)]))
|
|
C.evalDPF(C.ctx[id], (*C.uchar)(&dpfQueryA[0]), pos, C.int(ds), (*C.uchar)(&dataShareLeader[0]))
|
|
C.evalDPF(C.ctx[id], (*C.uchar)(&dpfQueryA[0]), pos, C.int(ds), (*C.uchar)(&dataShareLeader[0]))
|
|
|
|
|
|
dataShareFollower, _ := readFrom(followerConnection, ds, nil, 0)
|
|
dataShareFollower, _ := readFrom(followerConnection, ds, nil, 0)
|
|
@@ -612,11 +645,16 @@ func phase2(followerConnection net.Conn) {
|
|
|
|
|
|
var tweets []lib.Tweet
|
|
var tweets []lib.Tweet
|
|
var currentPublisherAmount int = 0
|
|
var currentPublisherAmount int = 0
|
|
|
|
+ var collisions float64
|
|
for i := 0; i < dbSize; i++ {
|
|
for i := 0; i < dbSize; i++ {
|
|
//discard cover message
|
|
//discard cover message
|
|
if tmpdb[i][1] == 0 {
|
|
if tmpdb[i][1] == 0 {
|
|
continue
|
|
continue
|
|
|
|
+ //collision
|
|
} else if -1 == strings.Index(string(tmpdb[i]), ";;") {
|
|
} else if -1 == strings.Index(string(tmpdb[i]), ";;") {
|
|
|
|
+ currentPublisherAmount++
|
|
|
|
+ currentPublisherAmount++
|
|
|
|
+ collisions++
|
|
continue
|
|
continue
|
|
} else {
|
|
} else {
|
|
currentPublisherAmount++
|
|
currentPublisherAmount++
|
|
@@ -649,13 +687,25 @@ func phase2(followerConnection net.Conn) {
|
|
|
|
|
|
tweet := lib.Tweet{"", -1, topics, text, round}
|
|
tweet := lib.Tweet{"", -1, topics, text, round}
|
|
|
|
|
|
- tweets = append(tweets, tweet)
|
|
|
|
|
|
+ if text != "" {
|
|
|
|
+ tweets = append(tweets, tweet)
|
|
|
|
+ } else {
|
|
|
|
+ //this is a odd(number) way collisions
|
|
|
|
+ collisions++
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+ collisionCounter = append(collisionCounter, collisions)
|
|
|
|
+
|
|
|
|
+ if collisions/dbWriteSize > 0.05 {
|
|
|
|
+ fmt.Println("Collisions this round", collisions, "dbWriteSize", dbWriteSize)
|
|
|
|
+ }
|
|
|
|
+
|
|
//fmt.Println("tweets recovered: ", tweets)
|
|
//fmt.Println("tweets recovered: ", tweets)
|
|
|
|
|
|
//sort into read db
|
|
//sort into read db
|
|
|
|
+ //fmt.Println("newTweets", tweets)
|
|
lib.NewEntries(tweets, 0)
|
|
lib.NewEntries(tweets, 0)
|
|
|
|
|
|
C.resetDb()
|
|
C.resetDb()
|
|
@@ -677,14 +727,14 @@ func phase2(followerConnection net.Conn) {
|
|
}
|
|
}
|
|
|
|
|
|
//calculates the dbWriteSize for this round
|
|
//calculates the dbWriteSize for this round
|
|
- dbWriteSize = int(math.Ceil(19.5 * float64(publisherAverage)))
|
|
|
|
|
|
+ dbWriteSize = math.Ceil(19.5 * float64(publisherAverage))
|
|
|
|
|
|
if dbWriteSize < minDBWriteSize {
|
|
if dbWriteSize < minDBWriteSize {
|
|
dbWriteSize = minDBWriteSize
|
|
dbWriteSize = minDBWriteSize
|
|
}
|
|
}
|
|
|
|
|
|
//writes dbWriteSize of current round to follower
|
|
//writes dbWriteSize of current round to follower
|
|
- writeTo(followerConnection, intToByte(dbWriteSize))
|
|
|
|
|
|
+ writeTo(followerConnection, intToByte(int(dbWriteSize)))
|
|
}
|
|
}
|
|
|
|
|
|
func addTestTweets() {
|
|
func addTestTweets() {
|
|
@@ -713,7 +763,7 @@ func phase3(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
|
|
|
|
//wait until time is up
|
|
//wait until time is up
|
|
for len(phase3Channel) == 0 {
|
|
for len(phase3Channel) == 0 {
|
|
- if time.Since(startTime) > maxTimePerRound {
|
|
|
|
|
|
+ if time.Since(startTime) > maxTimePerRound*2 {
|
|
//tells follower that this worker is done
|
|
//tells follower that this worker is done
|
|
writeToWError(followerConnection, gotClient, nil, 0)
|
|
writeToWError(followerConnection, gotClient, nil, 0)
|
|
wg.Done()
|
|
wg.Done()
|
|
@@ -723,7 +773,12 @@ func phase3(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
}
|
|
}
|
|
|
|
|
|
for clientConnection := range phase3Channel {
|
|
for clientConnection := range phase3Channel {
|
|
- clientsServedPhase3++
|
|
|
|
|
|
+ clientsServedPhase3[round] = clientsServedPhase3[round] + 1
|
|
|
|
+
|
|
|
|
+ if clientsServedPhase3[round]%1000 == 0 {
|
|
|
|
+ fmt.Println("clientsServedPhase3", clientsServedPhase3[round])
|
|
|
|
+ fmt.Println("timeTaken", time.Since(startPhase3).Seconds())
|
|
|
|
+ }
|
|
|
|
|
|
gotClient[0] = 1
|
|
gotClient[0] = 1
|
|
//tells follower that this worker got a clientConnection
|
|
//tells follower that this worker got a clientConnection
|
|
@@ -886,7 +941,7 @@ func phase3(id int, phase []byte, followerConnection net.Conn, wg *sync.WaitGrou
|
|
phase1Channel <- clientConnection
|
|
phase1Channel <- clientConnection
|
|
|
|
|
|
for {
|
|
for {
|
|
- if time.Since(startTime) < maxTimePerRound {
|
|
|
|
|
|
+ if time.Since(startTime) < 2*maxTimePerRound {
|
|
//this worker handles the next client
|
|
//this worker handles the next client
|
|
if len(phase3Channel) > 0 {
|
|
if len(phase3Channel) > 0 {
|
|
break
|
|
break
|
|
@@ -936,7 +991,7 @@ func createVirtualAddresses() []int {
|
|
//array will be filled with unique random ascending values
|
|
//array will be filled with unique random ascending values
|
|
//adapted from: https://stackoverflow.com/questions/20039025/java-array-of-unique-randomly-generated-integers
|
|
//adapted from: https://stackoverflow.com/questions/20039025/java-array-of-unique-randomly-generated-integers
|
|
//+1 to have a position to evaluate each received message
|
|
//+1 to have a position to evaluate each received message
|
|
- arraySize := dbWriteSize + 1
|
|
|
|
|
|
+ arraySize := int(dbWriteSize) + 1
|
|
var maxInt int = int(math.Pow(2, 31))
|
|
var maxInt int = int(math.Pow(2, 31))
|
|
virtualAddresses := make([]int, arraySize)
|
|
virtualAddresses := make([]int, arraySize)
|
|
for i := 0; i < arraySize; i++ {
|
|
for i := 0; i < arraySize; i++ {
|
|
@@ -1083,7 +1138,7 @@ func handlePirQuery(clientKeys clientKeys, clientConnection net.Conn, followerCo
|
|
|
|
|
|
if doAuditing {
|
|
if doAuditing {
|
|
tmpNeededSubscriptions = 1
|
|
tmpNeededSubscriptions = 1
|
|
- tmpTopicAmount = dbWriteSize
|
|
|
|
|
|
+ tmpTopicAmount = int(dbWriteSize)
|
|
}
|
|
}
|
|
|
|
|
|
//send length to follower
|
|
//send length to follower
|