-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathenv.go
101 lines (84 loc) · 2.5 KB
/
env.go
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
package gopark
import (
"flag"
"fmt"
"log"
"os"
"path"
"time"
)
type _Environment struct {
master string
parallel int
goparkWorkDir string
jobWorkDir string
started bool
verbose bool
}
func (e *_Environment) getLocalShufflePath(shuffleId int64, inputId, outputId int) string {
e.start()
pathName := path.Join(e.jobWorkDir, fmt.Sprintf("shuffle-%d", shuffleId))
if _, err := os.Stat(pathName); os.IsNotExist(err) {
os.Mkdir(pathName, os.ModePerm)
}
return path.Join(pathName, fmt.Sprintf("%05d_%05d", inputId, outputId))
}
func (e *_Environment) getLocalRDDPath(rddId int64, splitId int) string {
e.start()
pathName := path.Join(e.jobWorkDir, fmt.Sprintf("rdd-%d", rddId))
if _, err := os.Stat(pathName); os.IsNotExist(err) {
os.Mkdir(pathName, os.ModePerm)
}
return path.Join(pathName, fmt.Sprintf("%05d", splitId))
}
func (e *_Environment) start() {
if e.started {
return
}
if _, err := os.Stat(e.goparkWorkDir); os.IsNotExist(err) {
os.Mkdir(e.goparkWorkDir, os.ModePerm)
}
// create sub job working dir
pathName := fmt.Sprintf("gopark-%s-%s-%d", e.master, time.Now().Format("20060102150405"), os.Getpid())
e.jobWorkDir = path.Join(e.goparkWorkDir, pathName)
if _, err := os.Stat(e.jobWorkDir); os.IsNotExist(err) {
os.Mkdir(e.jobWorkDir, os.ModePerm)
}
// need to setup the basic tracker servers and etc.
e.started = true
}
func (e *_Environment) stop() {
if !e.started {
return
}
// clear the working dir
if !e.verbose {
err := os.RemoveAll(e.jobWorkDir)
if err != nil {
parklog("Error when removing job work directory[%s]: %s", e.jobWorkDir, err)
} else {
parklog("Clear the gopark job work direcotry: %s", e.jobWorkDir)
}
}
e.started = false
}
var env *_Environment
func init() {
env = &_Environment{}
}
func parklog(fmt string, v ...interface{}) {
if env.verbose {
log.Printf(fmt, v...)
}
}
func ParseOptions() {
flag.StringVar(&env.master, "master", "local", "Master of Gpark: local")
flag.IntVar(&env.parallel, "p", 2, "Number of parallelism level, must >= 0")
flag.StringVar(&env.goparkWorkDir, "workdir", "/opt/tmp", "Working Directory of Gpark")
flag.BoolVar(&env.verbose, "v", false, "Output verbose log information.")
flag.Parse()
if env.parallel < 0 {
flag.Usage()
os.Exit(1)
}
}