forked from cloudfoundry/docs-bosh
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathvsphere-cpi.html.md.erb
214 lines (163 loc) · 7.38 KB
/
vsphere-cpi.html.md.erb
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
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
---
title: vSphere CPI
---
This topic describes cloud properties for different resources created by the vSphere CPI.
## <a id='networks'></a> Networks
Schema for `cloud_properties` section used by manual network subnet:
* **name** [String, required]: Name of the vSphere network. Example: `VM Network`.
Example of manual network:
```yaml
networks:
- name: default
type: manual
subnets:
- range: 10.10.0.0/24
gateway: 10.10.0.1
cloud_properties:
name: VM Network
```
vSphere CPI does not support dynamic or vip networks.
---
## <a id='resource-pools'></a> Resource Pools
Schema for `cloud_properties` section:
* **cpu** [Integer, required]: Number of CPUs. Example: `1`.
* **ram** [Integer, required]: RAM in megabytes. Example: `1024`.
* **disk** [Integer, required]: Ephemeral disk size in megabytes. Example: `10240`.
* **nested\_hardware\_virtualization** [Boolean, optional]: Exposes hardware assisted virtualization to the VM. Default: `false`.
* **datacenters** [Array, optional]: Array of datacenters to use for VM placement. Must have only one and it must match datacenter configured in global CPI options.
* **name** [String, required]: Datacenter name.
* **clusters** [Array, required]: Array of clusters to use for VM placement.
* **\<cluster name\>** [String, required]: Cluster name.
* **drs_rulers** [Array, optional]: Array of DRS rules applied to [constrain VM placement](vm-anti-affinity.html#vsphere). Must have only one.
* **name** [String, required]: Name of a DRS rule that the Director will create.
* **type** [String, required]: Type of a DRS rule. Currently only `separate_vms` is supported.
Example of a VM with 1 CPU, 1GB RAM, and 10GB ephemeral disk asked to be placed into a specific cluster:
```yaml
resource_pools:
- name: default
network: default
stemcell:
name: bosh-vsphere-esxi-ubuntu-trusty-go_agent
version: latest
cloud_properties:
cpu: 2
ram: 1_024
disk: 10_240
datacenters:
- name: my-dc
clusters:
- my-vsphere-cluster: {}
```
And an example of a VM asked to be placed into a specific cluster in a specified vSphere resource pool:
```yaml
resource_pools:
- name: default
network: default
stemcell:
name: bosh-vsphere-esxi-ubuntu-trusty-go_agent
version: latest
cloud_properties:
cpu: 2
ram: 1_024
disk: 10_240
datacenters:
- name: my-dc
clusters:
- my-vsphere-cluster: {resource_pool: my-vsphere-res-pool}
```
---
## <a id='disk-pools'></a> Disk Pools
Schema for `cloud_properties` section:
* **type** [String, optional]: Type of the [disk](http://pubs.vmware.com/vi-sdk/visdk250/ReferenceGuide/vim.VirtualDiskManager.VirtualDiskType.html): `thick`, `thin`, `preallocated`, `eagerZeroedThick`. Defaults to `thick`. Available in v12.
Example of 10GB disk:
```yaml
disk_pools:
- name: default
disk_size: 10_240
```
Example of disk with type eagerZeroedThick:
```yaml
disk_pools:
- name: default
disk_size: 10_240
cloud_properties:
type: eagerZeroedThick
```
---
## <a id='global'></a> Global Configuration
The CPI can only talk to a single vCenter installation and manage VMs within a single vSphere datacenter.
Schema:
* **host** [String, required]: IP address of the vCenter. Example: `172.16.68.3`.
* **user** [String, required]: Username for the API access. Example: `root`.
* **password** [String, required]: Password for the API access. Example: `vmware`
* **datacenters** [Array, optional]: Array of datacenters to use for VM placement. Must have only one.
* **name** [String, required]: Datacenter name.
* **vm_folder** [String, required]: Path to a folder (relative to the datacenter) for storing created VMs. Folder will be automatically created if not found.
* **template_folder** [String, required]: Path to a folder (relative to the datacenter) for storing uploaded stemcells. Folder will be automatically created if not found.
* **disk_path** [String, required]: Path to a *disk* folder for storing persistent disks. Folder will be automatically created in the datastore if not found.
* **datastore_pattern** [String, required]: Pattern for selecting datastores for storing ephemeral disks and replicated stemcells.
* **persistent\_datastore\_pattern** [String, required]: Pattern for selecting datastores for storing persistent disks.
* **clusters** [Array, required]: Array of clusters to use for VM placement.
* **\<cluster name\>** [String, required]: Cluster name.
* **resource_pool** [String, optional]: Specific vSphere resource pool to use within the cluster.
Example of a CPI configuration that will place VMs into `BOSH_CL` cluster within `BOSH_DC`:
```yaml
properties:
vsphere:
host: 172.16.68.3
user: root
password: vmware
datacenters:
- name: BOSH_DC
vm_folder: prod-vms
template_folder: prod-templates
disk_path: prod-disks
datastore_pattern: '\Aprod-ds\z'
persistent_datastore_pattern: '\Aprod-ds\z'
clusters: [BOSH_CL]
```
Or example that places VMs by default into `BOSH_RP` vSphere resource pool:
```yaml
properties:
vsphere:
host: 172.16.68.3
user: root
password: vmware
datacenters:
- name: BOSH_DC
vm_folder: prod-vms
template_folder: prod-templates
disk_path: prod-disks
datastore_pattern: '\Aprod-ds\z'
persistent_datastore_pattern: '\Aprod-ds\z'
clusters:
- BOSH_CL: {resource_pool: BOSH_RP}
```
---
## <a id='notes'></a> Notes
* Assigned VM names (e.g. `vm-8dg349-s7cn74-...`) should not be manually changed since the CPI uses them to find created VMs. You can use [`bosh vms --details`](sysadmin-commands.html#health) to find which VM is assigned which job. VMs are also tagged with their assigned job, index and deployment.
* Storage DRS is not supported since it moves and renames persistent disks without maintaining same names.
* `allow_mixed_datastores` configuration has been deprecated in favor of setting same datastore pattern for `datastore_pattern` and `persistent_datastore_pattern` keys.
---
## <a id='errors'></a> Errors
```
Field object_set is not optional
```
This error may occur when global CPI configuration references:
- cluster (via `clusters` key) that cannot be found in the datacenter
- stemcell that cannot be found in the templates folder
```
...should have the following properties: ["info.progress", "info.state", "info.result", "info.error"] (VSphereCloud::CloudSearcher::MissingPropertiesException), but they were missing these: #<Set: {"info.state"}>
```
Add `System.View` on vCenter server level so that persistent disks can be moved between the datastores.
```
Field counter_id is not optional
...lib/cloud/vsphere/client.rb:270:in `fetch_perf_metric_names'
```
The CPI requires access to performance metrics from ESXi hosts. This error may be returned if one of the hosts in the cluster is not returning these metrics (e.g. `memory.usage.average`). Possible solution is to [restart management agents](http://www.running-system.com/no-cpu-and-memory-usage-data-from-host-available-in-vcenter/) on the hosts.
```
Failed to add disk scsi0:2.
```
This error typically occurs when persistent disk is being attached to a second VM while it is attached to another VM. That may happen when first VM was not properly deleted and BOSH is no longer aware of its existence.
---
Next: [Migrating from one datastore to another](vsphere-migrate-datastores.html)