vagrant-bosh 0.0.6 → 0.0.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (143) hide show
  1. checksums.yaml +4 -4
  2. data/.gitmodules +3 -6
  3. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-log +0 -0
  4. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-run +0 -0
  5. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.cert +0 -0
  6. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.json +0 -0
  7. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.key +0 -0
  8. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent +0 -0
  9. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent-rc +0 -0
  10. data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-blobstore-dav +0 -0
  11. data/bosh-provisioner/assets/bosh-provisioner +0 -0
  12. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit +0 -0
  13. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-log +0 -0
  14. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-run +0 -0
  15. data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monitrc +0 -0
  16. data/dev/Vagrantfile +1 -1
  17. data/dev/example-bosh-manifest.yml +12 -12
  18. data/lib/vagrant-bosh/bootstrapper.rb +6 -2
  19. data/lib/vagrant-bosh/config.rb +1 -1
  20. data/lib/vagrant-bosh/provisioner.rb +1 -1
  21. data/lib/vagrant-bosh/version.rb +1 -1
  22. data/vagrant-bosh.gemspec +3 -1
  23. metadata +20 -139
  24. data/go/.gitignore +0 -11
  25. data/go/bin/build +0 -10
  26. data/go/bin/build-linux-amd64 +0 -9
  27. data/go/bin/env +0 -13
  28. data/go/bin/go +0 -5
  29. data/go/bin/golint +0 -19
  30. data/go/bin/test +0 -37
  31. data/go/src/boshprovisioner/agent/client/client_interface.go +0 -73
  32. data/go/src/boshprovisioner/agent/client/fakes/fake_client.go +0 -81
  33. data/go/src/boshprovisioner/agent/client/http_client.go +0 -299
  34. data/go/src/boshprovisioner/agent/client/http_client_envelope.go +0 -107
  35. data/go/src/boshprovisioner/deployment/deployment.go +0 -221
  36. data/go/src/boshprovisioner/deployment/instance.go +0 -54
  37. data/go/src/boshprovisioner/deployment/manifest/deployment.go +0 -84
  38. data/go/src/boshprovisioner/deployment/manifest/ips.go +0 -23
  39. data/go/src/boshprovisioner/deployment/manifest/manifest.go +0 -143
  40. data/go/src/boshprovisioner/deployment/manifest/manifest_suite_test.go +0 -13
  41. data/go/src/boshprovisioner/deployment/manifest/manifest_test.go +0 -86
  42. data/go/src/boshprovisioner/deployment/manifest/syntax_validator.go +0 -186
  43. data/go/src/boshprovisioner/deployment/manifest/watch_time.go +0 -43
  44. data/go/src/boshprovisioner/deployment/manifest_reader.go +0 -46
  45. data/go/src/boshprovisioner/deployment/reader_factory.go +0 -25
  46. data/go/src/boshprovisioner/deployment/semantic_validator.go +0 -111
  47. data/go/src/boshprovisioner/downloader/blobstore_downloader.go +0 -55
  48. data/go/src/boshprovisioner/downloader/default_mux_downloader.go +0 -22
  49. data/go/src/boshprovisioner/downloader/downloader_interface.go +0 -6
  50. data/go/src/boshprovisioner/downloader/http_downloader.go +0 -53
  51. data/go/src/boshprovisioner/downloader/local_fs_downloader.go +0 -48
  52. data/go/src/boshprovisioner/downloader/mux_downloader.go +0 -69
  53. data/go/src/boshprovisioner/eventlog/log.go +0 -72
  54. data/go/src/boshprovisioner/eventlog/stage.go +0 -39
  55. data/go/src/boshprovisioner/eventlog/task.go +0 -58
  56. data/go/src/boshprovisioner/index/file_index.go +0 -289
  57. data/go/src/boshprovisioner/index/file_index_test.go +0 -296
  58. data/go/src/boshprovisioner/index/index_interface.go +0 -18
  59. data/go/src/boshprovisioner/index/index_suite_test.go +0 -13
  60. data/go/src/boshprovisioner/instance/instance.go +0 -43
  61. data/go/src/boshprovisioner/instance/instance_provisioner.go +0 -48
  62. data/go/src/boshprovisioner/instance/templatescompiler/concrete_templates_compiler.go +0 -284
  63. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erb_renderer.go +0 -117
  64. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erbrenderer_suite_test.go +0 -13
  65. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties.go +0 -77
  66. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties_test.go +0 -193
  67. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context.go +0 -85
  68. data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context_rb.go +0 -155
  69. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_jobs_repository.go +0 -86
  70. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_runtime_packages_repository.go +0 -113
  71. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_template_to_job_repository.go +0 -86
  72. data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/jobs_repository_interface.go +0 -49
  73. data/go/src/boshprovisioner/instance/templatescompiler/rendered_archives_compiler.go +0 -81
  74. data/go/src/boshprovisioner/instance/templatescompiler/templates_compiler_interface.go +0 -20
  75. data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/ct_repository.go +0 -54
  76. data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/templates_repository_interface.go +0 -16
  77. data/go/src/boshprovisioner/instance/updater/applier/applier.go +0 -93
  78. data/go/src/boshprovisioner/instance/updater/applier/empty_state.go +0 -66
  79. data/go/src/boshprovisioner/instance/updater/applier/job_state.go +0 -178
  80. data/go/src/boshprovisioner/instance/updater/drainer.go +0 -72
  81. data/go/src/boshprovisioner/instance/updater/starter.go +0 -36
  82. data/go/src/boshprovisioner/instance/updater/stopper.go +0 -36
  83. data/go/src/boshprovisioner/instance/updater/updater.go +0 -97
  84. data/go/src/boshprovisioner/instance/updater/updater_factory.go +0 -80
  85. data/go/src/boshprovisioner/instance/updater/updater_suite_test.go +0 -13
  86. data/go/src/boshprovisioner/instance/updater/waiter.go +0 -77
  87. data/go/src/boshprovisioner/instance/updater/waiter_test.go +0 -147
  88. data/go/src/boshprovisioner/main/config.go +0 -95
  89. data/go/src/boshprovisioner/main/config_test.go +0 -67
  90. data/go/src/boshprovisioner/main/main.go +0 -185
  91. data/go/src/boshprovisioner/main/main_suite_test.go +0 -13
  92. data/go/src/boshprovisioner/main/repos_factory.go +0 -86
  93. data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/compiled_packages_repository_interface.go +0 -17
  94. data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/concrete_compiled_packages_repository.go +0 -61
  95. data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler.go +0 -179
  96. data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler_factory.go +0 -48
  97. data/go/src/boshprovisioner/packagescompiler/packages_compiler_interface.go +0 -20
  98. data/go/src/boshprovisioner/packagescompiler/packagesrepo/concrete_packages_repository.go +0 -65
  99. data/go/src/boshprovisioner/packagescompiler/packagesrepo/packages_repository_interface.go +0 -16
  100. data/go/src/boshprovisioner/provisioner/blobstore_config.go +0 -65
  101. data/go/src/boshprovisioner/provisioner/blobstore_provisioner.go +0 -38
  102. data/go/src/boshprovisioner/provisioner/deployment_provisioner_interface.go +0 -10
  103. data/go/src/boshprovisioner/provisioner/release_compiler.go +0 -95
  104. data/go/src/boshprovisioner/provisioner/single_configured_vm_provisioner.go +0 -124
  105. data/go/src/boshprovisioner/provisioner/single_non_configured_vm_provisioner.go +0 -40
  106. data/go/src/boshprovisioner/provisioner/single_vm_provisioner_factory.go +0 -68
  107. data/go/src/boshprovisioner/release/dir_reader.go +0 -146
  108. data/go/src/boshprovisioner/release/job/job.go +0 -86
  109. data/go/src/boshprovisioner/release/job/manifest/manifest.go +0 -79
  110. data/go/src/boshprovisioner/release/job/manifest/manifest_suite_test.go +0 -13
  111. data/go/src/boshprovisioner/release/job/manifest/manifest_test.go +0 -59
  112. data/go/src/boshprovisioner/release/job/manifest/syntax_validator.go +0 -43
  113. data/go/src/boshprovisioner/release/job/reader_factory.go +0 -34
  114. data/go/src/boshprovisioner/release/job/tar_reader.go +0 -133
  115. data/go/src/boshprovisioner/release/manifest/manifest.go +0 -120
  116. data/go/src/boshprovisioner/release/manifest/manifest_suite_test.go +0 -13
  117. data/go/src/boshprovisioner/release/manifest/manifest_test.go +0 -126
  118. data/go/src/boshprovisioner/release/manifest/syntax_validator.go +0 -134
  119. data/go/src/boshprovisioner/release/reader_factory.go +0 -45
  120. data/go/src/boshprovisioner/release/reader_interface.go +0 -6
  121. data/go/src/boshprovisioner/release/release.go +0 -144
  122. data/go/src/boshprovisioner/release/release_suite_test.go +0 -13
  123. data/go/src/boshprovisioner/release/release_test.go +0 -129
  124. data/go/src/boshprovisioner/release/tar_reader.go +0 -141
  125. data/go/src/boshprovisioner/tar/cmd_compressor.go +0 -68
  126. data/go/src/boshprovisioner/tar/cmd_extractor.go +0 -47
  127. data/go/src/boshprovisioner/tar/compressor_interface.go +0 -6
  128. data/go/src/boshprovisioner/tar/extractor_interface.go +0 -6
  129. data/go/src/boshprovisioner/util/possible_base64.go +0 -21
  130. data/go/src/boshprovisioner/util/string_keyed.go +0 -70
  131. data/go/src/boshprovisioner/vm/vagrant/agent_provisioner.go +0 -296
  132. data/go/src/boshprovisioner/vm/vagrant/asset_manager.go +0 -61
  133. data/go/src/boshprovisioner/vm/vagrant/configured_vm.go +0 -29
  134. data/go/src/boshprovisioner/vm/vagrant/deps_provisioner.go +0 -214
  135. data/go/src/boshprovisioner/vm/vagrant/monit_provisioner.go +0 -85
  136. data/go/src/boshprovisioner/vm/vagrant/non_configured_vm.go +0 -26
  137. data/go/src/boshprovisioner/vm/vagrant/runit_provisioner.go +0 -229
  138. data/go/src/boshprovisioner/vm/vagrant/simple_cmds.go +0 -54
  139. data/go/src/boshprovisioner/vm/vagrant/vcap_user_provisioner.go +0 -167
  140. data/go/src/boshprovisioner/vm/vagrant/vm_provisioner.go +0 -119
  141. data/go/src/boshprovisioner/vm/vagrant/vm_provisioner_factory.go +0 -101
  142. data/go/src/boshprovisioner/vm/vm_interface.go +0 -45
  143. data/lib/vagrant-bosh/assets/provisioner +0 -0
@@ -1,61 +0,0 @@
1
- package vagrant
2
-
3
- import (
4
- "fmt"
5
- "path/filepath"
6
-
7
- bosherr "bosh/errors"
8
- boshlog "bosh/logger"
9
- boshsys "bosh/system"
10
- )
11
-
12
- type AssetManager struct {
13
- rootDir string
14
- fs boshsys.FileSystem
15
- runner boshsys.CmdRunner
16
- logger boshlog.Logger
17
- }
18
-
19
- func NewAssetManager(
20
- rootDir string,
21
- fs boshsys.FileSystem,
22
- runner boshsys.CmdRunner,
23
- logger boshlog.Logger,
24
- ) AssetManager {
25
- return AssetManager{
26
- rootDir: rootDir,
27
- fs: fs,
28
- runner: runner,
29
- logger: logger,
30
- }
31
- }
32
-
33
- func (m AssetManager) Place(name, dstPath string) error {
34
- srcPath := filepath.Join(m.rootDir, name)
35
-
36
- if !m.fs.FileExists(srcPath) {
37
- return bosherr.New("Missing asset %s at %s", name, srcPath)
38
- }
39
-
40
- tempDir, err := m.fs.TempDir("vm-AssetManager")
41
- if err != nil {
42
- return bosherr.WrapError(err, "Creating temp dir")
43
- }
44
-
45
- defer m.fs.RemoveAll(tempDir)
46
-
47
- srcCopyPath := fmt.Sprintf("%s/copy", tempDir)
48
-
49
- // todo fs.CopyFile leaks fds
50
- _, _, _, err = m.runner.RunCommand("cp", srcPath, srcCopyPath)
51
- if err != nil {
52
- return bosherr.WrapError(err, "Copying asset")
53
- }
54
-
55
- err = m.fs.Rename(srcCopyPath, dstPath)
56
- if err != nil {
57
- return bosherr.WrapError(err, "Renaming asset %s to %s", name, dstPath)
58
- }
59
-
60
- return nil
61
- }
@@ -1,29 +0,0 @@
1
- package vagrant
2
-
3
- import (
4
- bpagclient "boshprovisioner/agent/client"
5
- )
6
-
7
- // ConfiguredVM represents provisioned Vagrant machine
8
- // that can be communicated with via an AgentClient.
9
- type ConfiguredVM struct {
10
- vmProvisioner *VMProvisioner
11
- agentClient bpagclient.Client
12
- }
13
-
14
- func NewConfiguredVM(vmProvisioner *VMProvisioner, agentClient bpagclient.Client) ConfiguredVM {
15
- return ConfiguredVM{
16
- vmProvisioner: vmProvisioner,
17
- agentClient: agentClient,
18
- }
19
- }
20
-
21
- func (vm ConfiguredVM) AgentClient() bpagclient.Client {
22
- return vm.agentClient
23
- }
24
-
25
- func (vm ConfiguredVM) Deprovision() error {
26
- return vm.vmProvisioner.deprovision(vm)
27
- }
28
-
29
- func (vm ConfiguredVM) vagrantVM() {}
@@ -1,214 +0,0 @@
1
- package vagrant
2
-
3
- import (
4
- "fmt"
5
- "strings"
6
- "time"
7
-
8
- bosherr "bosh/errors"
9
- boshlog "bosh/logger"
10
- boshsys "bosh/system"
11
-
12
- bpeventlog "boshprovisioner/eventlog"
13
- )
14
-
15
- const (
16
- depsProvisionerLogTag = "DepsProvisioner"
17
- depsProvisionerAptGetUpdateMsg = "E: Unable to fetch some archives, maybe run apt-get update"
18
- )
19
-
20
- // DepsProvisioner installs basic dependencies for running
21
- // packaging scripts from BOSH packages. It also installs
22
- // non-captured dependencies by few common BOSH releases.
23
- // (e.g. cmake, quota)
24
- type DepsProvisioner struct {
25
- fullStemcellCompatibility bool
26
-
27
- runner boshsys.CmdRunner
28
- eventLog bpeventlog.Log
29
- logger boshlog.Logger
30
- }
31
-
32
- func NewDepsProvisioner(
33
- fullStemcellCompatibility bool,
34
- runner boshsys.CmdRunner,
35
- eventLog bpeventlog.Log,
36
- logger boshlog.Logger,
37
- ) DepsProvisioner {
38
- return DepsProvisioner{
39
- fullStemcellCompatibility: fullStemcellCompatibility,
40
-
41
- runner: runner,
42
- eventLog: eventLog,
43
- logger: logger,
44
- }
45
- }
46
-
47
- func (p DepsProvisioner) Provision() error {
48
- pkgNames := depsProvisionerPkgsForMinimumStemcellCompatibility
49
-
50
- if p.fullStemcellCompatibility {
51
- pkgNames = append(pkgNames, depsProvisionerPkgsForFullStemcellCompatibility...)
52
- }
53
-
54
- stage := p.eventLog.BeginStage("Installing dependencies", len(pkgNames))
55
-
56
- installedPkgNames, err := p.listInstalledPkgNames()
57
- if err != nil {
58
- return bosherr.WrapError(err, "Listing installed packages")
59
- }
60
-
61
- for _, pkgName := range pkgNames {
62
- task := stage.BeginTask(fmt.Sprintf("Package %s", pkgName))
63
-
64
- if p.isPkgInstalled(pkgName, installedPkgNames) {
65
- p.logger.Debug(depsProvisionerLogTag, "Package %s is already installed", pkgName)
66
- task.End(nil)
67
- continue
68
- }
69
-
70
- err := task.End(p.installPkg(pkgName))
71
- if err != nil {
72
- return bosherr.WrapError(err, "Installing %s", pkgName)
73
- }
74
- }
75
-
76
- return nil
77
- }
78
-
79
- func (p DepsProvisioner) installPkg(name string) error {
80
- p.logger.Debug(depsProvisionerLogTag, "Installing package %s", name)
81
-
82
- _, _, _, err := p.runner.RunCommand("apt-get", "-y", "install", name)
83
- if err == nil {
84
- return nil
85
- }
86
-
87
- // Avoid running 'apt-get update' since it usually takes 30sec
88
- if strings.Contains(err.Error(), depsProvisionerAptGetUpdateMsg) {
89
- _, _, _, err := p.runner.RunCommand("apt-get", "-y", "update")
90
- if err != nil {
91
- return bosherr.WrapError(err, "Updating sources")
92
- }
93
-
94
- var lastInstallErr error
95
-
96
- // For some reason libssl-dev was really hard to install on the first try
97
- for i := 0; i < 3; i++ {
98
- _, _, _, lastInstallErr = p.runner.RunCommand("apt-get", "-y", "install", name)
99
- if lastInstallErr == nil {
100
- return nil
101
- }
102
-
103
- time.Sleep(1 * time.Second)
104
- }
105
-
106
- return bosherr.WrapError(lastInstallErr, "Installing %s after updating", name)
107
- }
108
-
109
- return err
110
- }
111
-
112
- func (p DepsProvisioner) listInstalledPkgNames() ([]string, error) {
113
- var installedPkgNames []string
114
-
115
- installedPkgStdout, _, _, err := p.runner.RunCommand("dpkg", "--get-selections")
116
- if err != nil {
117
- return nil, bosherr.WrapError(err, "dkpg query")
118
- }
119
-
120
- // e.g. 'zlib1g:amd64 install'
121
- // 'util-linux install'
122
- for _, line := range strings.Split(installedPkgStdout, "\n") {
123
- pieces := strings.Fields(line)
124
-
125
- // Last line is empty
126
- if len(pieces) == 2 && pieces[1] == "install" {
127
- pkgName := strings.Split(pieces[0], ":")[0]
128
- installedPkgNames = append(installedPkgNames, pkgName)
129
- }
130
- }
131
-
132
- return installedPkgNames, nil
133
- }
134
-
135
- func (p DepsProvisioner) isPkgInstalled(pkgName string, installedPkgs []string) bool {
136
- for _, installedPkgName := range installedPkgs {
137
- if installedPkgName == pkgName {
138
- return true
139
- }
140
- }
141
-
142
- return false
143
- }
144
-
145
- var depsProvisionerPkgsForMinimumStemcellCompatibility = []string{
146
- // Most BOSH releases require it for packaging
147
- "build-essential", // 16sec
148
- "cmake", // 6sec
149
-
150
- "libcap2-bin",
151
- "libcap-dev",
152
-
153
- "libbz2-1.0", // noop on precise64 Vagrant box
154
- "libbz2-dev", // 2sec
155
- "libxslt1-dev", // 2sec
156
- "libxml2-dev", // 2sec
157
-
158
- // Used by BOSH Agent
159
- "iputils-arping",
160
-
161
- // For warden
162
- "quota", // 1sec
163
-
164
- // Started needing that in saucy for building BOSH
165
- "libssl-dev",
166
-
167
- "bison",
168
- "flex",
169
-
170
- "gettext",
171
- "libreadline6-dev",
172
- "libncurses5-dev",
173
- }
174
-
175
- // Taken from base_apt stemcell builder stage
176
- var depsProvisionerPkgsForFullStemcellCompatibility = []string{
177
- "libaio1",
178
- "uuid-dev",
179
- "nfs-common",
180
- "zlib1g-dev",
181
- "apparmor-utils",
182
- "openssh-server",
183
-
184
- "libgcrypt-dev",
185
- "ca-certificates",
186
-
187
- // CURL
188
- "libcurl3",
189
- "libcurl3-dev",
190
-
191
- // XML
192
- "libxml2",
193
- "libxml2-dev",
194
- "libxslt1.1",
195
- "libxslt1-dev",
196
-
197
- // Utils
198
- "bind9-host",
199
- "dnsutils",
200
- "zip",
201
- "unzip",
202
- "psmisc",
203
- "lsof",
204
- "strace",
205
- "curl",
206
- "wget",
207
- "gdb",
208
- "sysstat",
209
- "rsync",
210
-
211
- "iptables",
212
- "tcpdump",
213
- "traceroute",
214
- }
@@ -1,85 +0,0 @@
1
- package vagrant
2
-
3
- import (
4
- "time"
5
-
6
- bosherr "bosh/errors"
7
- boshlog "bosh/logger"
8
- )
9
-
10
- const monitProvisionerLogTag = "MonitProvisioner"
11
-
12
- // MonitProvisioner installs Monit binary.
13
- type MonitProvisioner struct {
14
- cmds SimpleCmds
15
- assetManager AssetManager
16
- runitProvisioner RunitProvisioner
17
- logger boshlog.Logger
18
- }
19
-
20
- func NewMonitProvisioner(
21
- cmds SimpleCmds,
22
- assetManager AssetManager,
23
- runitProvisioner RunitProvisioner,
24
- logger boshlog.Logger,
25
- ) MonitProvisioner {
26
- return MonitProvisioner{
27
- cmds: cmds,
28
- assetManager: assetManager,
29
- runitProvisioner: runitProvisioner,
30
- logger: logger,
31
- }
32
- }
33
-
34
- func (p MonitProvisioner) Provision() error {
35
- path := "/var/vcap/monit"
36
-
37
- err := p.cmds.MkdirP(path)
38
- if err != nil {
39
- return err
40
- }
41
-
42
- err = p.configureMonitrc()
43
- if err != nil {
44
- return bosherr.WrapError(err, "Configuring monitrc")
45
- }
46
-
47
- err = p.runitProvisioner.Provision("monit", 1*time.Minute)
48
- if err != nil {
49
- return bosherr.WrapError(err, "Provisioning monit with runit")
50
- }
51
-
52
- return nil
53
- }
54
-
55
- func (p MonitProvisioner) configureMonitrc() error {
56
- p.logger.Info(monitProvisionerLogTag, "Configuring monitc")
57
-
58
- err := p.cmds.MkdirP("/var/vcap/bosh/etc")
59
- if err != nil {
60
- return err
61
- }
62
-
63
- err = p.assetManager.Place("monit/monitrc", "/var/vcap/bosh/etc/monitrc")
64
- if err != nil {
65
- return bosherr.WrapError(err, "Placing monitrc")
66
- }
67
-
68
- err = p.cmds.Chmod("700", "/var/vcap/bosh/etc/monitrc")
69
- if err != nil {
70
- return err
71
- }
72
-
73
- // monit refuses to start without an include file present
74
- err = p.cmds.MkdirP("/var/vcap/monit")
75
- if err != nil {
76
- return err
77
- }
78
-
79
- err = p.cmds.Touch("/var/vcap/monit/empty.monitrc")
80
- if err != nil {
81
- return err
82
- }
83
-
84
- return nil
85
- }
@@ -1,26 +0,0 @@
1
- package vagrant
2
-
3
- import (
4
- bpagclient "boshprovisioner/agent/client"
5
- )
6
-
7
- // NonConfiguredVM represents provisioned Vagrant machine
8
- // that CANNOT be communicated with via an AgentClient.
9
- type NonConfiguredVM struct {
10
- vmProvisioner *VMProvisioner
11
- }
12
-
13
- func NewNonConfiguredVM(vmProvisioner *VMProvisioner) NonConfiguredVM {
14
- return NonConfiguredVM{vmProvisioner: vmProvisioner}
15
- }
16
-
17
- func (vm NonConfiguredVM) AgentClient() bpagclient.Client {
18
- // Programmer error
19
- panic("Must not ask for AgentClient from a non-configured VM")
20
- }
21
-
22
- func (vm NonConfiguredVM) Deprovision() error {
23
- return vm.vmProvisioner.deprovision(vm)
24
- }
25
-
26
- func (vm NonConfiguredVM) vagrantVM() {}
@@ -1,229 +0,0 @@
1
- package vagrant
2
-
3
- import (
4
- "fmt"
5
- "regexp"
6
- "strings"
7
- "time"
8
-
9
- bosherr "bosh/errors"
10
- boshlog "bosh/logger"
11
- boshsys "bosh/system"
12
- )
13
-
14
- const (
15
- runitProvisionerLogTag = "RunitProvisioner"
16
- runitStopStepDuration = 1 * time.Second
17
- )
18
-
19
- var (
20
- // Matches 'svlogd -tt /var/vcap/bosh/log'
21
- runitSvlogdRegex = regexp.MustCompile(`\s*svlogd\s+\-tt\s+(.+)\s*`)
22
-
23
- // Matches 'down: agent: 3s, normally up; run: log: (pid 15318) 7762s'
24
- runitStatusDownRegex = regexp.MustCompile(`\Adown: [a-z\/]+: \d+`)
25
- )
26
-
27
- // RunitProvisioner installs runit via apt-get and
28
- // adds specified service under runit's control.
29
- type RunitProvisioner struct {
30
- fs boshsys.FileSystem
31
- cmds SimpleCmds
32
- runner boshsys.CmdRunner
33
- assetManager AssetManager
34
- logger boshlog.Logger
35
- }
36
-
37
- func NewRunitProvisioner(
38
- fs boshsys.FileSystem,
39
- cmds SimpleCmds,
40
- runner boshsys.CmdRunner,
41
- assetManager AssetManager,
42
- logger boshlog.Logger,
43
- ) RunitProvisioner {
44
- return RunitProvisioner{
45
- fs: fs,
46
- cmds: cmds,
47
- runner: runner,
48
- assetManager: assetManager,
49
- logger: logger,
50
- }
51
- }
52
-
53
- func (p RunitProvisioner) Provision(name string, stopTimeout time.Duration) error {
54
- err := p.installRunit()
55
- if err != nil {
56
- return bosherr.WrapError(err, "Installing runit")
57
- }
58
-
59
- err = p.setUpService(name, stopTimeout)
60
- if err != nil {
61
- return bosherr.WrapError(err, "Setting up service")
62
- }
63
-
64
- return nil
65
- }
66
-
67
- func (p RunitProvisioner) installRunit() error {
68
- p.logger.Info(runitProvisionerLogTag, "Installing runit")
69
-
70
- // todo non-bash
71
- cmd := boshsys.Command{
72
- Name: "bash",
73
- Args: []string{
74
- "-c", "apt-get -q -y -o Dpkg::Options::='--force-confdef' -o Dpkg::Options::='--force-confold' install runit",
75
- },
76
- Env: map[string]string{
77
- "DEBIAN_FRONTEND": "noninteractive",
78
- },
79
- }
80
-
81
- _, _, _, err := p.runner.RunComplexCommand(cmd)
82
- if err != nil {
83
- return err
84
- }
85
-
86
- return nil
87
- }
88
-
89
- func (p RunitProvisioner) setUpService(name string, stopTimeout time.Duration) error {
90
- p.logger.Info(runitProvisionerLogTag, "Setting up %s service", name)
91
-
92
- servicePath := fmt.Sprintf("/etc/sv/%s", name)
93
- enableServicePath := fmt.Sprintf("/etc/service/%s", name)
94
-
95
- err := p.stopRunAndLog(servicePath, enableServicePath, name, stopTimeout)
96
- if err != nil {
97
- return bosherr.WrapError(err, "Stopping run and log")
98
- }
99
-
100
- err = p.setUpRun(servicePath, name)
101
- if err != nil {
102
- return bosherr.WrapError(err, "Setting up run")
103
- }
104
-
105
- err = p.setUpLog(servicePath, name)
106
- if err != nil {
107
- return bosherr.WrapError(err, "Setting up log")
108
- }
109
-
110
- err = p.startRunAndLog(servicePath, enableServicePath, name)
111
- if err != nil {
112
- return bosherr.WrapError(err, "Starting run and log")
113
- }
114
-
115
- return nil
116
- }
117
-
118
- // setUpRun sets up script that runit will execute for the primary process
119
- func (p RunitProvisioner) setUpRun(servicePath, name string) error {
120
- err := p.cmds.MkdirP(servicePath)
121
- if err != nil {
122
- return err
123
- }
124
-
125
- runPath := fmt.Sprintf("%s/run", servicePath)
126
-
127
- err = p.assetManager.Place(fmt.Sprintf("%s/%s-run", name, name), runPath)
128
- if err != nil {
129
- return err
130
- }
131
-
132
- return p.cmds.ChmodX(runPath)
133
- }
134
-
135
- // setUpLog sets up logging destination for the service
136
- func (p RunitProvisioner) setUpLog(servicePath, name string) error {
137
- logPath := fmt.Sprintf("%s/log", servicePath)
138
-
139
- err := p.cmds.MkdirP(logPath)
140
- if err != nil {
141
- return err
142
- }
143
-
144
- logRunPath := fmt.Sprintf("%s/run", logPath)
145
-
146
- err = p.assetManager.Place(fmt.Sprintf("%s/%s-log", name, name), logRunPath)
147
- if err != nil {
148
- return err
149
- }
150
-
151
- err = p.cmds.ChmodX(logRunPath)
152
- if err != nil {
153
- return err
154
- }
155
-
156
- contens, err := p.fs.ReadFileString(logRunPath)
157
- if err != nil {
158
- return err
159
- }
160
-
161
- // First match is the whole string
162
- svlogdPaths := runitSvlogdRegex.FindStringSubmatch(contens)
163
-
164
- // Create log file destination so that runit process can properly log
165
- if len(svlogdPaths) == 2 {
166
- err = p.cmds.MkdirP(svlogdPaths[1])
167
- if err != nil {
168
- return err
169
- }
170
- }
171
-
172
- return nil
173
- }
174
-
175
- func (p RunitProvisioner) stopRunAndLog(servicePath, enableServicePath, name string, stopTimeout time.Duration) error {
176
- err := p.stopRunsv(name, stopTimeout)
177
- if err != nil {
178
- return bosherr.WrapError(err, "Stopping service")
179
- }
180
-
181
- err = p.stopRunsv(fmt.Sprintf("%s/log", name), stopTimeout)
182
- if err != nil {
183
- return bosherr.WrapError(err, "Stopping log service")
184
- }
185
-
186
- err = p.fs.RemoveAll(enableServicePath)
187
- if err != nil {
188
- return err
189
- }
190
-
191
- // Clear out all service state kept in supervise/ and control/ dirs
192
- return p.fs.RemoveAll(servicePath)
193
- }
194
-
195
- func (p RunitProvisioner) startRunAndLog(servicePath, enableServicePath, name string) error {
196
- // Enabling service will kick in monitoring
197
- _, _, _, err := p.runner.RunCommand("ln", "-sf", servicePath, enableServicePath)
198
-
199
- return err
200
- }
201
-
202
- func (p RunitProvisioner) stopRunsv(name string, stopTimeout time.Duration) error {
203
- p.logger.Info(runitProvisionerLogTag, "Stopping runsv")
204
-
205
- downStdout, _, _, err := p.runner.RunCommand("sv", "down", name)
206
- if err != nil {
207
- p.logger.Error(runitProvisionerLogTag, "Ignoring down error %s", err.Error())
208
- }
209
-
210
- // If runsv configuration does not exist, service was never started
211
- if strings.Contains(downStdout, "file does not exist") {
212
- return nil
213
- }
214
-
215
- var lastStatusStdout string
216
- var passedDuration time.Duration
217
-
218
- for ; passedDuration < stopTimeout; passedDuration += runitStopStepDuration {
219
- lastStatusStdout, _, _, _ = p.runner.RunCommand("sv", "status", name)
220
-
221
- if runitStatusDownRegex.MatchString(lastStatusStdout) {
222
- return nil
223
- }
224
-
225
- time.Sleep(runitStopStepDuration)
226
- }
227
-
228
- return bosherr.New("Failed to stop runsv for %s. Output: %s", name, lastStatusStdout)
229
- }