File: chaos-server.go

package info (click to toggle)
golang-github-minio-dsync 0.0~git20170209.0.b9f7da7-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, forky, sid, trixie
  • size: 232 kB
  • sloc: makefile: 5
file content (68 lines) | stat: -rw-r--r-- 2,075 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
/*
 * Minio Cloud Storage, (C) 2016 Minio, 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 main

import (
	"fmt"
	"log"
	"math/rand"
	"net"
	"net/http"
	"net/rpc"
	"strconv"
	"sync"
	"time"
)

// For this test framework we have short lock timings
// Production should use eg following values
//
// const LockMaintenanceLoop       = 1 * time.Minute
// const LockCheckValidityInterval = 2 * time.Minute
//
const LockMaintenanceLoop = 1 * time.Second
const LockCheckValidityInterval = 5 * time.Second

func startRPCServer(port int) {
	log.SetPrefix(fmt.Sprintf("[%d] ", port))
	log.SetFlags(log.Lmicroseconds)

	server := rpc.NewServer()
	locker := &lockServer{
		mutex:   sync.Mutex{},
		lockMap: make(map[string][]lockRequesterInfo),
		// timestamp: leave uninitialized for testing (set to real timestamp for actual usage)
	}
	go func() {
		// Start with random sleep time, so as to avoid "synchronous checks" between servers
		time.Sleep(time.Duration(rand.Float64() * float64(LockMaintenanceLoop)))
		for {
			time.Sleep(LockMaintenanceLoop)
			locker.lockMaintenance(LockCheckValidityInterval)
		}
	}()
	server.RegisterName("Dsync", locker)
	// For some reason the registration paths need to be different (even for different server objs)
	rpcPath := rpcPathPrefix + "-" + strconv.Itoa(port)
	server.HandleHTTP(rpcPath, fmt.Sprintf("%s-debug", rpcPath))
	l, e := net.Listen("tcp", ":"+strconv.Itoa(port))
	if e != nil {
		log.Fatal("listen error:", e)
	}
	log.Println("RPC server listening at port", port, "under", rpcPath)
	http.Serve(l, nil)
}