sistero 0.7.4 → 0.8.3

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
- SHA1:
3
- metadata.gz: c966aa5e013e4a912ed85572ea3df024ba5b3552
4
- data.tar.gz: e3a8f4a357ad77c63cb781c13b3a6700377ea798
2
+ SHA256:
3
+ metadata.gz: 0a01e88ca09bc7ef259fee75231306f215ef887081821cf7102f4dc8c2555889
4
+ data.tar.gz: 217d5c6d807fd34d74b07145d81b9a579ed7bd7fd955250ec2ddb2d20908fd58
5
5
  SHA512:
6
- metadata.gz: 85c52cd18afca7958e0a30991238cc737381f22eb6b5f6eb81c198483410ac77647788fcd06d8cae6b924c81d5fe4b4f9491b0b0a269e436c4af6b3ab539e5c3
7
- data.tar.gz: cc127f77567046ba6ad2ffdd2aa904741c87b89fa96efad279401ff934d6efdbca52399f07d4d5c7b136c4a81702ae4abd64adc898891767996e62ad0b27e311
6
+ metadata.gz: 57deb592ced358a0f05364c0bc7b902f3b217059b1605e982fb1af3ded786590cd5d7f041e836db37eafc80759c19db2c7c44afbf741b394bc710f54e95ee0ca
7
+ data.tar.gz: d855e5f5af2950f48f03b74399c6af1f110f0c5232997a907752963fe7b871c313e4a2fdbd3b6b6ca8effdcf89863fda8140506dd575687371b123dab7bc43b7
data/bin/sistero CHANGED
@@ -28,7 +28,7 @@ module Sistero::Command
28
28
  subop.on '-o val', 'add ssh options', 'ssh_options'
29
29
  end
30
30
 
31
- op.subcommand 'rsync vm *cmd', 'rsync files to vm'
31
+ op.subcommand 'rsync vm *cmd', 'rsync files to/from vm'
32
32
 
33
33
  op.subcommand 'create [*vms]', 'create vm'
34
34
  op.subcommand 'create-all', 'create all vms in config'
@@ -64,7 +64,7 @@ module Sistero::Command
64
64
  when 'create'
65
65
  vms = command_cfg.vms
66
66
  vms.push nil if vms.empty?
67
- vms.each &sistero.method(:create_vm)
67
+ vms.each &sistero.method(:create_droplet_from_vm)
68
68
  when 'create-all'
69
69
  sistero.create_all()
70
70
  when 'destroy'
@@ -1,3 +1,3 @@
1
1
  module Sistero
2
- VERSION = '0.7.4'
2
+ VERSION = '0.8.3'
3
3
  end
data/lib/sistero.rb CHANGED
@@ -10,12 +10,12 @@ module Sistero
10
10
  end
11
11
 
12
12
  def find_droplet(name)
13
- @client.droplets.all.find { |vm| vm.name == name }
13
+ @client.droplets.all.find { |droplet| droplet.name == name }
14
14
  end
15
15
 
16
16
  def list_vms()
17
- @client.droplets.all.each do |vm|
18
- puts "#{vm.name} - #{vm.networks[0][0].ip_address}"
17
+ @client.droplets.all.each do |droplet|
18
+ puts "#{droplet.name} - #{get_public_ip droplet}"
19
19
  end
20
20
  end
21
21
 
@@ -70,10 +70,10 @@ module Sistero
70
70
  ssh_options ||= vm.ssh_options
71
71
 
72
72
  droplet = find_droplet(name) || create_droplet_from_vm(name)
73
- public_network = get_public_network name, droplet
74
- ip = wait_for_ssh_port public_network
73
+ public_ip = get_public_ip droplet
74
+ wait_for_ssh_port public_ip
75
75
 
76
- cmd = "ssh -o 'StrictHostKeyChecking no' #{ssh_options} #{vm.ssh_user || 'root'}@#{ip}"
76
+ cmd = "ssh -o 'StrictHostKeyChecking no' #{ssh_options} #{vm.ssh_user || 'root'}@#{public_ip}"
77
77
  unless run.empty?
78
78
  cmd += ' ' + run.join(' ')
79
79
  end
@@ -85,10 +85,10 @@ module Sistero
85
85
  def rsync(name, cmd: nil)
86
86
  vm, name = get_vm name
87
87
  droplet = find_droplet(name) || create_droplet_from_vm(name)
88
- public_network = get_public_network name, droplet
89
- ip = wait_for_ssh_port public_network
88
+ public_ip = get_public_ip droplet
89
+ wait_for_ssh_port public_ip
90
90
 
91
- cmd_str = 'rsync ' + cmd.join(' ').gsub('vm:', "#{vm.ssh_user || 'root'}@#{ip}:")
91
+ cmd_str = 'rsync ' + cmd.join(' ').gsub('vm:', "#{vm.ssh_user || 'root'}@#{public_ip}:")
92
92
  exec cmd_str
93
93
  end
94
94
 
@@ -145,27 +145,30 @@ module Sistero
145
145
  end
146
146
 
147
147
  private
148
- def get_public_network name, droplet
149
- public_network = droplet.networks.v4.find { |network| network.type == 'public' }
148
+ def find_public_network droplet
149
+ droplet&.networks&.v4.find { |network| network.type == 'public' }
150
+ end
151
+
152
+ private
153
+ def get_public_ip droplet
154
+ public_network = find_public_network droplet
150
155
  until public_network
151
156
  puts "no public interfaces, trying again in a second"
152
157
  sleep 1
153
- droplet = find_droplet(name)
154
- public_network = droplet.networks.v4.find { |network| network.type == 'public' }
158
+ droplet = find_droplet(droplet.name)
159
+ public_network = find_public_network droplet
155
160
  end
156
- public_network
161
+ public_network.ip_address
157
162
  end
158
163
 
159
- def wait_for_ssh_port public_network
160
- ip = public_network.ip_address
161
- unless is_port_open? ip, 22
164
+ def wait_for_ssh_port public_ip
165
+ unless is_port_open? public_ip, 22
162
166
  puts "waiting for ssh port to open"
163
167
  sleep 1
164
- until is_port_open? ip, 22 do
168
+ until is_port_open? public_ip, 22 do
165
169
  sleep 1
166
170
  end
167
171
  end
168
- ip
169
172
  end
170
173
  end
171
174
  end
data/readme.md CHANGED
@@ -8,33 +8,35 @@ sistero is a profile based tool to manage a digital ocean cluster.
8
8
 
9
9
  ## Configuration
10
10
 
11
- The configuration file lives at `.config/sistero`, an example looks like this:
11
+ First sistero looks for a file called `sistero.yaml` in the current directory or a parent of the current directory. If it is not found the default configuration is loaded from `.config/sistero`. Here is an example:
12
12
 
13
13
  ```
14
14
  defaults:
15
- vm_name: default-vm
15
+ name: default-vm
16
16
  ssh_keys:
17
17
  - 1234567
18
18
  ssh_options: -D1080 -A
19
19
  access_token: f788fffffffffffff8ffffffffffffffffffffff8fffffffffffffffffffffff
20
- vm_size: 512mb
21
- vm_region: nyc3
22
- vm_image: ubuntu-14-04-x64
23
- profiles:
20
+ size: 512mb
21
+ region: nyc3
22
+ image: ubuntu-14-04-x64
23
+ vms:
24
24
  -
25
- vm_name: london-vm
26
- vm_region: lon1
25
+ name: default-vm
27
26
  -
28
- vm_name: london-bigger-vm
29
- vm_region: lon1
30
- vm_size: 1gb
27
+ name: london-vm
28
+ region: lon1
29
+ -
30
+ name: london-bigger-vm
31
+ region: lon1
32
+ size: 1gb
31
33
  ```
32
34
 
33
- Any values not specified in a profile are taken from `defaults`. If the `defaults` entry specifies a `vm_name` then it becomes the default VM for the `create`, `ssh` and `destroy` commands.
35
+ Any values not specified in a profile are taken from `defaults`. If the `defaults` entry specifies a `name` then it becomes the default VM for the `create`, `ssh` and `destroy` commands but is not inherited by vm configuration items.
34
36
 
35
37
  The `ssh_keys` is a list of ID numbers (rather than names) of ssh keys, these can be found by running `sistero ssh-keys`.
36
38
 
37
- The valid options for `region`, `vm_size` and `vm_image` can be found by running `sistero regions`, `sistero sizes` and `sistero images` respectively.
39
+ The valid options for `region`, `size` and `image` can be found by running `sistero regions`, `sistero sizes` and `sistero images` respectively.
38
40
 
39
41
  ## Running
40
42
 
@@ -47,3 +49,58 @@ Or to create a VM called `london-vm` in london:
47
49
  ```
48
50
  sistero create london-vm
49
51
  ```
52
+
53
+ The command `sistero create-all` can be used to create all VMs listed in the configuration file.
54
+
55
+ ## More advanced configurations
56
+
57
+ This config that shows how to create a CoreOS cluster:
58
+
59
+ ```
60
+ defaults:
61
+ ssh_user: core
62
+ ssh_keys:
63
+ - 1234567
64
+ - 1234568
65
+ ssh_options: -D1080 -A
66
+ access_token:
67
+ file: ./secrets/digital-ocean.access-token
68
+ region: lon1
69
+ image: coreos-stable
70
+ name: vm1
71
+ private_networking: true
72
+ user_data: |
73
+ #cloud-config
74
+ coreos:
75
+ etcd2:
76
+ # y$@" :r !curl -s -w "\n" "https://discovery.etcd.io/new?size=2"
77
+ discovery: https://discovery.etcd.io/af66d811fc9b5b9b0989009f849cc37a
78
+ # use $public_ipv4 for multi-cloud/region:
79
+ advertise-client-urls: http://$private_ipv4:2379
80
+ initial-advertise-peer-urls: http://$private_ipv4:2380
81
+ listen-client-urls: http://0.0.0.0:2379
82
+ listen-peer-urls: http://$private_ipv4:2380
83
+ fleet:
84
+ public-ip: $private_ipv4 # used for fleetctl ssh command
85
+ metadata: "size=#{size},name=#{name}"
86
+ units:
87
+ - name: etcd2.service
88
+ command: start
89
+ - name: fleet.service
90
+ command: start
91
+ vms:
92
+ -
93
+ name: vm1
94
+ size: 1gb
95
+ -
96
+ name: vm2
97
+ size: 512mb
98
+ -
99
+ name: vm3
100
+ size: 512mb
101
+ ```
102
+
103
+ This demonstrates a few more things:
104
+
105
+ 1. The config can be split over multiple files using `file:`, in this config file the digital ocean access token is specified in a different file.
106
+ 2. In `user_data` vm configuration variables can be substituted, see `#{size}` and `#{name}` in the metadata.
data/sistero.gemspec CHANGED
@@ -26,10 +26,10 @@ Gem::Specification.new do |spec|
26
26
  spec.executables = spec.name
27
27
  spec.require_paths = ["lib"]
28
28
 
29
- spec.add_development_dependency "bundler", "~> 1.10"
29
+ spec.add_development_dependency "bundler", "~> 2.0"
30
30
  spec.add_development_dependency "rake", "~> 10.0"
31
31
  spec.add_development_dependency "rspec"
32
32
 
33
- spec.add_dependency "droplet_kit", "~> 1.3"
33
+ spec.add_dependency "droplet_kit", "~> 3.14"
34
34
  spec.add_dependency "moister", "~> 0.3"
35
35
  end
metadata CHANGED
@@ -1,14 +1,14 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: sistero
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.7.4
4
+ version: 0.8.3
5
5
  platform: ruby
6
6
  authors:
7
7
  - James Pike
8
- autorequire:
8
+ autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2016-06-18 00:00:00.000000000 Z
11
+ date: 2021-09-02 00:00:00.000000000 Z
12
12
  dependencies:
13
13
  - !ruby/object:Gem::Dependency
14
14
  name: bundler
@@ -16,14 +16,14 @@ dependencies:
16
16
  requirements:
17
17
  - - "~>"
18
18
  - !ruby/object:Gem::Version
19
- version: '1.10'
19
+ version: '2.0'
20
20
  type: :development
21
21
  prerelease: false
22
22
  version_requirements: !ruby/object:Gem::Requirement
23
23
  requirements:
24
24
  - - "~>"
25
25
  - !ruby/object:Gem::Version
26
- version: '1.10'
26
+ version: '2.0'
27
27
  - !ruby/object:Gem::Dependency
28
28
  name: rake
29
29
  requirement: !ruby/object:Gem::Requirement
@@ -58,14 +58,14 @@ dependencies:
58
58
  requirements:
59
59
  - - "~>"
60
60
  - !ruby/object:Gem::Version
61
- version: '1.3'
61
+ version: '3.14'
62
62
  type: :runtime
63
63
  prerelease: false
64
64
  version_requirements: !ruby/object:Gem::Requirement
65
65
  requirements:
66
66
  - - "~>"
67
67
  - !ruby/object:Gem::Version
68
- version: '1.3'
68
+ version: '3.14'
69
69
  - !ruby/object:Gem::Dependency
70
70
  name: moister
71
71
  requirement: !ruby/object:Gem::Requirement
@@ -105,7 +105,7 @@ homepage: http://github.com/ohjames/sistero
105
105
  licenses: []
106
106
  metadata:
107
107
  allowed_push_host: https://rubygems.org
108
- post_install_message:
108
+ post_install_message:
109
109
  rdoc_options: []
110
110
  require_paths:
111
111
  - lib
@@ -120,9 +120,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
120
120
  - !ruby/object:Gem::Version
121
121
  version: '0'
122
122
  requirements: []
123
- rubyforge_project:
124
- rubygems_version: 2.5.1
125
- signing_key:
123
+ rubygems_version: 3.2.21
124
+ signing_key:
126
125
  specification_version: 4
127
126
  summary: Profile based digital ocean cluster management command line tool.
128
127
  test_files: []