Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://mxschmitt.github.io/ui-driver-hetzner/
Rancher UI driver for the Hetzner Cloud docker driver.
https://mxschmitt.github.io/ui-driver-hetzner/
docker hcloud hetzner hetzner-cloud rancher
Last synced: 3 months ago
JSON representation
Rancher UI driver for the Hetzner Cloud docker driver.
- Host: GitHub
- URL: https://mxschmitt.github.io/ui-driver-hetzner/
- Owner: mxschmitt
- License: apache-2.0
- Fork: true (rancher/ui-driver-skel)
- Created: 2018-01-28T13:53:57.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-04-07T06:09:18.000Z (10 months ago)
- Last Synced: 2024-08-03T21:03:03.760Z (6 months ago)
- Topics: docker, hcloud, hetzner, hetzner-cloud, rancher
- Language: JavaScript
- Homepage: https://mxschmitt.github.io/ui-driver-hetzner
- Size: 1.24 MB
- Stars: 253
- Watchers: 16
- Forks: 50
- Open Issues: 20
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-rancher - Hetzner Cloud UI Driver
README
# Rancher 2 Hetzner Cloud UI Driver
[![Build Status](https://travis-ci.org/mxschmitt/ui-driver-hetzner.svg?branch=master)](https://travis-ci.org/mxschmitt/ui-driver-hetzner)
Rancher 2.X UI driver for the [Hetzner Cloud](https://www.hetzner.de/cloud). For the Rancher 1 version check out the readme from the `v1.6` branch which you can find [here](https://github.com/mxschmitt/ui-driver-hetzner/blob/v1.6/README.md).
## Usage
* Add a Machine Driver in Rancher 2 (`Cluster Management` -> `Drivers` -> `Node Drivers`)
| Key | Value |
| --- | ----- |
| Download URL | `https://github.com/JonasProgrammer/docker-machine-driver-hetzner/releases/download/3.3.0/docker-machine-driver-hetzner_3.3.0_linux_amd64.tar.gz` |
| Custom UI URL | `https://storage.googleapis.com/hcloud-rancher-v2-ui-driver/component.js` |
| Whitelist Domains | `storage.googleapis.com` |* Wait for the driver to become "Active"
* Go to Clusters -> Add Cluster, your driver and custom UI should show up.![Authentication screen](docs/authentication-screen.png)
![Configuration screen](docs/configuration-screen.png)## Compatibility
The following `component.js` is always compatible with the latest Rancher 2.X version:
`https://storage.googleapis.com/hcloud-rancher-v2-ui-driver/component.js`
### Rancher 2.0
Use this `component.js` to support Rancher 2.0 version:
`https://storage.googleapis.com/hcloud-rancher-v2-ui-driver/component-v20.js`
## Tested linux distributions
To use `Debian` e.g. with a non default Storage Driver, you have to set it manually in the Engine Options of the Node Template in Rancher.
### Recommend
| Image | Docker Version | Docker Storage Driver |
|--------------|------------------------------------|------------------------|
| Ubuntu 18.04 | 18.06 | overlay2 (default) |
| Ubuntu 16.04 | 18.06 | aufs (default) |
| Debian 9 | 18.06 | overlay2, overlay |
| CentOS 7 | 18.06 | devicemapper (default) |
| Fedora 27 | not supported (due docker-install) | |
| Fedora 28 | not supported (due docker-install) | |## Development
This package contains a small web-server that will serve up the custom driver UI at `http://localhost:3000/component.js`. You can run this while developing and point the Rancher settings there.
* `npm start`
* The driver name can be optionally overridden: `npm start -- --name=DRIVERNAME`
* The compiled files are viewable at http://localhost:3000.
* **Note:** The development server does not currently automatically restart when files are changed.## Building
For other users to see your driver, you need to build it and host the output on a server accessible from their browsers.
* `npm run build`
* Copy the contents of the `dist` directory onto a webserver.
* If your Rancher is configured to use HA or SSL, the server must also be available via HTTPS.## Useful resources
### `Error creating machine: Error running provisioning: ssh command error:`
Try to use `overlay2` and if it does not work `overlay` as `Storage Driver` in the `Engine Options` in the bottom.
### How secure is the `Private Network` feature?
> Traffic between Cloud Servers inside a Network is private and isolated, but not automatically encrypted. We recommend you use TLS or similar protocols to encrypt sensitive traffic.
Reference: [Hetzner Cloud documentation](https://wiki.hetzner.de/index.php/CloudServer/en#Is_traffic_inside_Hetzner_Cloud_Networks_encrypted.3F)
The Rancher traffic between the agents and the Rancher related traffic to the nodes is fully encrypted over HTTPS/TLS.
The custom application specific traffic is *not* encrypted. You can use e.g. the Weave CNI-Provider for that: https://rancher.com/docs/rancher/v2.x/en/faq/networking/cni-providers/#weave
### Requirements for Private Networks
- Rancher host needs to be in the *same Private Network* as the selected one in the Node template
- Under the global settings of Rancher the `server-url` needs to be the internal IP of the Private Network (you can find it in the Hetzner Cloud Console). Otherwise the traffic won't go through the Internal network.### How to close the open ports on the public interface?
You could use it e.g. in combination with that tool: https://github.com/vitobotta/hetzner-cloud-init