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.
- checksums.yaml +4 -4
- data/.gitmodules +3 -6
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-log +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent-run +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.cert +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.json +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/agent.key +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-agent-rc +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/agent/bosh-blobstore-dav +0 -0
- data/bosh-provisioner/assets/bosh-provisioner +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-log +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monit-run +0 -0
- data/{lib/vagrant-bosh → bosh-provisioner}/assets/monit/monitrc +0 -0
- data/dev/Vagrantfile +1 -1
- data/dev/example-bosh-manifest.yml +12 -12
- data/lib/vagrant-bosh/bootstrapper.rb +6 -2
- data/lib/vagrant-bosh/config.rb +1 -1
- data/lib/vagrant-bosh/provisioner.rb +1 -1
- data/lib/vagrant-bosh/version.rb +1 -1
- data/vagrant-bosh.gemspec +3 -1
- metadata +20 -139
- data/go/.gitignore +0 -11
- data/go/bin/build +0 -10
- data/go/bin/build-linux-amd64 +0 -9
- data/go/bin/env +0 -13
- data/go/bin/go +0 -5
- data/go/bin/golint +0 -19
- data/go/bin/test +0 -37
- data/go/src/boshprovisioner/agent/client/client_interface.go +0 -73
- data/go/src/boshprovisioner/agent/client/fakes/fake_client.go +0 -81
- data/go/src/boshprovisioner/agent/client/http_client.go +0 -299
- data/go/src/boshprovisioner/agent/client/http_client_envelope.go +0 -107
- data/go/src/boshprovisioner/deployment/deployment.go +0 -221
- data/go/src/boshprovisioner/deployment/instance.go +0 -54
- data/go/src/boshprovisioner/deployment/manifest/deployment.go +0 -84
- data/go/src/boshprovisioner/deployment/manifest/ips.go +0 -23
- data/go/src/boshprovisioner/deployment/manifest/manifest.go +0 -143
- data/go/src/boshprovisioner/deployment/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/deployment/manifest/manifest_test.go +0 -86
- data/go/src/boshprovisioner/deployment/manifest/syntax_validator.go +0 -186
- data/go/src/boshprovisioner/deployment/manifest/watch_time.go +0 -43
- data/go/src/boshprovisioner/deployment/manifest_reader.go +0 -46
- data/go/src/boshprovisioner/deployment/reader_factory.go +0 -25
- data/go/src/boshprovisioner/deployment/semantic_validator.go +0 -111
- data/go/src/boshprovisioner/downloader/blobstore_downloader.go +0 -55
- data/go/src/boshprovisioner/downloader/default_mux_downloader.go +0 -22
- data/go/src/boshprovisioner/downloader/downloader_interface.go +0 -6
- data/go/src/boshprovisioner/downloader/http_downloader.go +0 -53
- data/go/src/boshprovisioner/downloader/local_fs_downloader.go +0 -48
- data/go/src/boshprovisioner/downloader/mux_downloader.go +0 -69
- data/go/src/boshprovisioner/eventlog/log.go +0 -72
- data/go/src/boshprovisioner/eventlog/stage.go +0 -39
- data/go/src/boshprovisioner/eventlog/task.go +0 -58
- data/go/src/boshprovisioner/index/file_index.go +0 -289
- data/go/src/boshprovisioner/index/file_index_test.go +0 -296
- data/go/src/boshprovisioner/index/index_interface.go +0 -18
- data/go/src/boshprovisioner/index/index_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/instance.go +0 -43
- data/go/src/boshprovisioner/instance/instance_provisioner.go +0 -48
- data/go/src/boshprovisioner/instance/templatescompiler/concrete_templates_compiler.go +0 -284
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erb_renderer.go +0 -117
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/erbrenderer_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties.go +0 -77
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/render_properties_test.go +0 -193
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context.go +0 -85
- data/go/src/boshprovisioner/instance/templatescompiler/erbrenderer/template_evaluation_context_rb.go +0 -155
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_jobs_repository.go +0 -86
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_runtime_packages_repository.go +0 -113
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/concrete_template_to_job_repository.go +0 -86
- data/go/src/boshprovisioner/instance/templatescompiler/jobsrepo/jobs_repository_interface.go +0 -49
- data/go/src/boshprovisioner/instance/templatescompiler/rendered_archives_compiler.go +0 -81
- data/go/src/boshprovisioner/instance/templatescompiler/templates_compiler_interface.go +0 -20
- data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/ct_repository.go +0 -54
- data/go/src/boshprovisioner/instance/templatescompiler/templatesrepo/templates_repository_interface.go +0 -16
- data/go/src/boshprovisioner/instance/updater/applier/applier.go +0 -93
- data/go/src/boshprovisioner/instance/updater/applier/empty_state.go +0 -66
- data/go/src/boshprovisioner/instance/updater/applier/job_state.go +0 -178
- data/go/src/boshprovisioner/instance/updater/drainer.go +0 -72
- data/go/src/boshprovisioner/instance/updater/starter.go +0 -36
- data/go/src/boshprovisioner/instance/updater/stopper.go +0 -36
- data/go/src/boshprovisioner/instance/updater/updater.go +0 -97
- data/go/src/boshprovisioner/instance/updater/updater_factory.go +0 -80
- data/go/src/boshprovisioner/instance/updater/updater_suite_test.go +0 -13
- data/go/src/boshprovisioner/instance/updater/waiter.go +0 -77
- data/go/src/boshprovisioner/instance/updater/waiter_test.go +0 -147
- data/go/src/boshprovisioner/main/config.go +0 -95
- data/go/src/boshprovisioner/main/config_test.go +0 -67
- data/go/src/boshprovisioner/main/main.go +0 -185
- data/go/src/boshprovisioner/main/main_suite_test.go +0 -13
- data/go/src/boshprovisioner/main/repos_factory.go +0 -86
- data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/compiled_packages_repository_interface.go +0 -17
- data/go/src/boshprovisioner/packagescompiler/compiledpackagesrepo/concrete_compiled_packages_repository.go +0 -61
- data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler.go +0 -179
- data/go/src/boshprovisioner/packagescompiler/concrete_packages_compiler_factory.go +0 -48
- data/go/src/boshprovisioner/packagescompiler/packages_compiler_interface.go +0 -20
- data/go/src/boshprovisioner/packagescompiler/packagesrepo/concrete_packages_repository.go +0 -65
- data/go/src/boshprovisioner/packagescompiler/packagesrepo/packages_repository_interface.go +0 -16
- data/go/src/boshprovisioner/provisioner/blobstore_config.go +0 -65
- data/go/src/boshprovisioner/provisioner/blobstore_provisioner.go +0 -38
- data/go/src/boshprovisioner/provisioner/deployment_provisioner_interface.go +0 -10
- data/go/src/boshprovisioner/provisioner/release_compiler.go +0 -95
- data/go/src/boshprovisioner/provisioner/single_configured_vm_provisioner.go +0 -124
- data/go/src/boshprovisioner/provisioner/single_non_configured_vm_provisioner.go +0 -40
- data/go/src/boshprovisioner/provisioner/single_vm_provisioner_factory.go +0 -68
- data/go/src/boshprovisioner/release/dir_reader.go +0 -146
- data/go/src/boshprovisioner/release/job/job.go +0 -86
- data/go/src/boshprovisioner/release/job/manifest/manifest.go +0 -79
- data/go/src/boshprovisioner/release/job/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/job/manifest/manifest_test.go +0 -59
- data/go/src/boshprovisioner/release/job/manifest/syntax_validator.go +0 -43
- data/go/src/boshprovisioner/release/job/reader_factory.go +0 -34
- data/go/src/boshprovisioner/release/job/tar_reader.go +0 -133
- data/go/src/boshprovisioner/release/manifest/manifest.go +0 -120
- data/go/src/boshprovisioner/release/manifest/manifest_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/manifest/manifest_test.go +0 -126
- data/go/src/boshprovisioner/release/manifest/syntax_validator.go +0 -134
- data/go/src/boshprovisioner/release/reader_factory.go +0 -45
- data/go/src/boshprovisioner/release/reader_interface.go +0 -6
- data/go/src/boshprovisioner/release/release.go +0 -144
- data/go/src/boshprovisioner/release/release_suite_test.go +0 -13
- data/go/src/boshprovisioner/release/release_test.go +0 -129
- data/go/src/boshprovisioner/release/tar_reader.go +0 -141
- data/go/src/boshprovisioner/tar/cmd_compressor.go +0 -68
- data/go/src/boshprovisioner/tar/cmd_extractor.go +0 -47
- data/go/src/boshprovisioner/tar/compressor_interface.go +0 -6
- data/go/src/boshprovisioner/tar/extractor_interface.go +0 -6
- data/go/src/boshprovisioner/util/possible_base64.go +0 -21
- data/go/src/boshprovisioner/util/string_keyed.go +0 -70
- data/go/src/boshprovisioner/vm/vagrant/agent_provisioner.go +0 -296
- data/go/src/boshprovisioner/vm/vagrant/asset_manager.go +0 -61
- data/go/src/boshprovisioner/vm/vagrant/configured_vm.go +0 -29
- data/go/src/boshprovisioner/vm/vagrant/deps_provisioner.go +0 -214
- data/go/src/boshprovisioner/vm/vagrant/monit_provisioner.go +0 -85
- data/go/src/boshprovisioner/vm/vagrant/non_configured_vm.go +0 -26
- data/go/src/boshprovisioner/vm/vagrant/runit_provisioner.go +0 -229
- data/go/src/boshprovisioner/vm/vagrant/simple_cmds.go +0 -54
- data/go/src/boshprovisioner/vm/vagrant/vcap_user_provisioner.go +0 -167
- data/go/src/boshprovisioner/vm/vagrant/vm_provisioner.go +0 -119
- data/go/src/boshprovisioner/vm/vagrant/vm_provisioner_factory.go +0 -101
- data/go/src/boshprovisioner/vm/vm_interface.go +0 -45
- 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
|
-
}
|