Установите Rancher Server на RancherOS

обзор

RancherOS - это невероятно легкая операционная система (всего около 60 МБ), которая запускает «системный» демон Docker PID 0для запуска системных служб (сеть, консольный доступ и т. Д.), А также «пользовательский» демон Docker для запуска не системные контейнеры, (MySQL, Rancher и многое другое).

Rancher - это управляемая контейнером платформа для управления контейнерами, а также для более широких аспектов инфраструктуры, таких как хосты, среды и многое другое. Сервер Rancher контролирует оркестровку, и агент Rancher развертывается на каждом хосте, который управляется Rancher.

В этой статье мы рассмотрим следующие шаги для развертывания сервера Rancher:

  • Cloud-init script - Опубликовать файл cloud-init для установки и запуска сервера Rancher.
  • PXE script - Напишите PXE-скрипт для получения файла cloud-init и загрузки хоста в первый раз.
  • Firewall - Создайте группу межсетевого экрана, потому что безопасность имеет первостепенное значение.
  • Start it up - Предоставить хост и установить Rancher.

Требования

  • VPS с минимум 1 ГБ ОЗУ - мы установим сервер Rancher на этом хосте.
  • Блокировка хранилища - для постоянного хранения данных сервера Rancher, его настроек, пользователей и многого другого.
  • 1 Зарезервированный IP-адрес - чтобы дать агентам Rancher согласованный IP-адрес для использования в среде Rancher.

Cloud-init скрипт

Сохраните следующий скрипт в месте, доступном для вашего хоста, HTTP/HTTPSчтобы он мог ссылаться на него из своего скрипта PXE.

Замените ssh-...детали вашим открытым ключом SSH, чтобы вы могли подключить SSH к хосту.

#cloud-config
ssh_authorized_keys:
  - ssh-...

write_files:
  - path: /cloud-config.yml
    permissions: "0700"
    owner: root
    content: |
      #cloud-config
      ssh_authorized_keys:
        - ssh-...

      mounts:
       - ["/dev/vdb1", "/mnt", "ext4", ""] 

      rancher:
        services:
          rancher-server:
            image: rancher/server:stable
            ports:
              - 8080:8080
            restart: always
            volumes:
              - /mnt/rancher-server-mysql:/var/lib/mysql
  - path: /opt/rancher/bin/start.sh
    permissions: "0700"
    owner: root
    content: |
      #!/bin/bash
      echo y | ros install -f -c /cloud-config.yml -d /dev/vda

Обратите внимание, что это на самом деле посадка cloud-config.ymlвнутри другого cloud-config.yml. Внешний загружается, когда iPXE загружает хост в первый раз, и устанавливает Rancher на диск хоста /dev/vda. Внутренняя конфигурация предназначена для последующих загрузок и фактически запускает сервер Rancher.

Данные MySQL хранятся в блочном хранилище /dev/vdb, поэтому критические данные и конфигурации сервера Rancher могут выдержать замену хоста VPS.

Вы можете загрузить сценарий в любое количество бесплатных мест, доступных для публичного доступа в виде URL-адреса, или разместить его на другом VPS, чтобы его могли использовать только ваши хосты через частную сеть.

PXE скрипт

Скопируйте следующее в качестве сценария запуска PXE, называемого « Rancher Server», и замените CLOUD_CONFIG_URLего URL-адресом cloud-config.ymlфайла (что-то вроде https://example.com/cloud-config.yml).

#!ipxe

# Location of Kernel/Initrd images
set base-url https://releases.rancher.com/os/latest

kernel ${base-url}/vmlinuz rancher.state.dev=LABEL=RANCHER_STATE -- rancher.cloud_init.datasources=[url:CLOUD_CONFIG_URL]

initrd ${base-url}/initrd

boot

Это вытянет последнюю версию RancherOS ISO и загрузит ее в память, используя ваш скрипт cloud-init. Ваш скрипт cloud-init затем продолжит установку RancherOS на диск, и при второй загрузке будет запущен контейнер сервера Rancher.

Межсетевой экран

Когда Rancher впервые станет доступен, любой, кто попадет в конечную точку, сразу же получит права администратора.

Чтобы предотвратить захват вашего сервера Rancher посторонними лицами, создайте брандмауэр под названием «Rancher Server» со следующими правилами:

  • TCP 22 на ваш IP, так что вы можете SSH в хост.
  • TCP 8080 на ваш IP, так что вы можете загрузить веб-страницу сервера Rancher.
  • TCP 8080 для любых хостов агента Rancher, чтобы они могли зарегистрироваться на сервере Rancher.

Начни это

Предоставьте хосту 1+ ГБ в том же регионе, что и блочное хранилище, и установите его Server Typeдля пользовательского сценария запуска iPXE «Rancher Server».

После загрузки обязательно преобразуйте его IP-адрес в зарезервированный IP-адрес, чтобы у ваших агентов Rancher была конечная точка, с которой они могли бы последовательно регистрироваться.

IPXE потребуется ~ 4 минуты для загрузки ISO-образа RancherOS, первой загрузки для установки RancherOS /dev/vda, и второй загрузки для загрузки rancher/server:stableобраза Docker и запуска его контейнеров.

Как только это произойдет, вы сможете достичь его в http://YOUR_RESERVED_IP:8080.

Поздравляем, вы только что настроили сервер Rancher на RancherOS.

Вы можете перезапустить свой экземпляр или даже уничтожить / переустановить его, и блочное хранилище сохранит ваши данные и конфигурации, в то время как ваш зарезервированный IP позволит новым агентам Rancher знать, где найти ваш сервер.

Несколько следующих шагов:

  • Set up access control - как минимум, создать локального администратора с надежным паролем.
  • Add hosts- в Add Hosts -> Customразделе скопируйте URL-адрес, содержащий длинный токен, специфичный для вашего сервера Rancher. Это необходимо для регистрации агентов Rancher на вашем сервере.
  • Exploreпоследний Rancher сервер документации .


Leave a Comment

Развертывание Kubernetes с помощью Kubeadm на CentOS 7

Развертывание Kubernetes с помощью Kubeadm на CentOS 7

Обзор Эта статья призвана помочь вам в кратчайшие сроки запустить и запустить кластер Kubernetes с помощью kubeadm. Это руководство будет развертывать два сервера, на

Безопасное развертывание и управление контейнерами LXC в Ubuntu 14.04

Безопасное развертывание и управление контейнерами LXC в Ubuntu 14.04

Контейнеры LXC (контейнеры Linux) - это функция операционной системы Linux, которую можно использовать для запуска нескольких изолированных систем Linux на одном хосте. Thes

Создайте Docker Swarm в Alpine Linux 3.9.0

Создайте Docker Swarm в Alpine Linux 3.9.0

Введение Это руководство покажет вам, как создать и настроить рой Docker с использованием нескольких серверов Alpine Linux 3.9.0 и Portainer. Пожалуйста, знайте, что

Развертывание приложения PHP с помощью Docker-compose

Развертывание приложения PHP с помощью Docker-compose

Приложения PHP обычно состоят из веб-сервера, системы реляционных баз данных и самого интерпретатора языка. В этом уроке мы будем leveragin

Начало работы с Kubernetes в CentOS 7

Начало работы с Kubernetes в CentOS 7

Kubernetes - это платформа с открытым исходным кодом, разработанная Google для управления контейнерными приложениями на кластере серверов. Он основан на десятилетии и

Установите Docker CE на Ubuntu 18.04

Установите Docker CE на Ubuntu 18.04

Введение Docker - это приложение, которое позволяет нам развертывать программы, которые запускаются как контейнеры. Он был написан на популярном языке программирования Go

Установите Rancher на Ubuntu 16.04

Установите Rancher на Ubuntu 16.04

Используете другую систему? Введение Rancher - это платформа с открытым исходным кодом для запуска контейнеров и создания частного контейнерного сервиса. Rancher является базой

Установка docker-compose на CoreOS

Установка docker-compose на CoreOS

В этой статье объясняется, как установить docker-compose на CoreOS. В CoreOS папка / usr / является неизменяемой, поэтому стандартный путь / usr / local / bin недоступен для

На CoreOS настройте свой собственный реестр Docker

На CoreOS настройте свой собственный реестр Docker

Мы все знаем и любим Docker, платформу для создания, управления и распределения контейнеров приложений на нескольких компьютерах. Docker Inc. предоставляет услугу т

Установите Rancher на CentOS 7

Установите Rancher на CentOS 7

Используете другую систему? Введение Rancher - это платформа с открытым исходным кодом для запуска контейнеров и создания частного контейнерного сервиса. Rancher является базой

Настройка Sentry через Docker в Ubuntu 16.04

Настройка Sentry через Docker в Ubuntu 16.04

Используете другую систему? Введение Sentry - это решение с открытым исходным кодом для отслеживания ошибок. Sentry отслеживает исключения и другие полезные сообщения для

Как установить Harbour на CentOS 7

Как установить Harbour на CentOS 7

Harbour - это сервер реестра корпоративного класса с открытым исходным кодом, который хранит и распространяет образы Docker. Harbour расширяет с открытым исходным кодом Docker Distribution b

Липкая сессия с Docker Swarm (CE) на CentOS 7

Липкая сессия с Docker Swarm (CE) на CentOS 7

Используете другую систему? Введение Docker Swarm превращает ваши отдельные серверы в кластер компьютеров, облегчая масштабирование, высокую доступность и

Установка Docker на CentOS 7

Установка Docker на CentOS 7

Используете другую систему? Docker - это приложение, которое позволяет развертывать программное обеспечение в виртуальных контейнерах. Это было написано в программе Go

Липкая сессия с Docker Swarm (CE) в Debian 9

Липкая сессия с Docker Swarm (CE) в Debian 9

Используете другую систему? Введение Docker Swarm превращает ваши отдельные серверы в кластер компьютеров; облегчение масштабирования, высокая доступность и

Как использовать Docker: создание вашего первого Docker-контейнера

Как использовать Docker: создание вашего первого Docker-контейнера

Это руководство объясняет основы начала работы с Docker. Я предполагаю, что у вас уже установлен Docker. Шаги в этом уроке будут работать на

Балансировка нагрузки с помощью докера

Балансировка нагрузки с помощью докера

При запуске веб-приложения вы, как правило, хотите максимально эффективно использовать свои ресурсы без необходимости конвертировать программное обеспечение для использования многопоточности.

Начало работы с SQL Server 2017 (MS-SQL) в CentOS 7 с помощью Docker

Начало работы с SQL Server 2017 (MS-SQL) в CentOS 7 с помощью Docker

Предпосылки к движку Docker 1.8+. Минимум 4 ГБ дискового пространства. Минимум 4 ГБ ОЗУ. Шаг 1. Установите Docker Для установки SQL-сервера, Docker mus

Установка Docker CE на Debian 9

Установка Docker CE на Debian 9

Используете другую систему? Введение Docker - это приложение, которое позволяет развертывать программное обеспечение в виртуальных контейнерах. Это было написано в G

Изучение 26 методов анализа больших данных: часть 1

Изучение 26 методов анализа больших данных: часть 1

Изучение 26 методов анализа больших данных: часть 1

6 невероятных фактов о Nintendo Switch

6 невероятных фактов о Nintendo Switch

Многие из вас знают Switch, который выйдет в марте 2017 года, и его новые функции. Для тех, кто не знает, мы подготовили список функций, которые делают «Switch» обязательным гаджетом.

Технические обещания, которые все еще не выполнены

Технические обещания, которые все еще не выполнены

Вы ждете, когда технологические гиганты выполнят свои обещания? проверить, что осталось недоставленным.

Функциональные возможности уровней эталонной архитектуры больших данных

Функциональные возможности уровней эталонной архитектуры больших данных

Прочтите блог, чтобы узнать о различных уровнях архитектуры больших данных и их функциях самым простым способом.

Как ИИ может вывести автоматизацию процессов на новый уровень?

Как ИИ может вывести автоматизацию процессов на новый уровень?

Прочтите это, чтобы узнать, как искусственный интеллект становится популярным среди небольших компаний и как он увеличивает вероятность их роста и дает преимущество перед конкурентами.

CAPTCHA: как долго она может оставаться жизнеспособным методом различения между человеком и ИИ?

CAPTCHA: как долго она может оставаться жизнеспособным методом различения между человеком и ИИ?

CAPTCHA стало довольно сложно решать пользователям за последние несколько лет. Сможет ли он оставаться эффективным в обнаружении спама и ботов в ближайшем будущем?

Технологическая сингулярность: далекое будущее человеческой цивилизации?

Технологическая сингулярность: далекое будущее человеческой цивилизации?

По мере того, как наука развивается быстрыми темпами, принимая на себя большую часть наших усилий, также возрастает риск подвергнуться необъяснимой сингулярности. Прочтите, что может значить для нас необычность.

Телемедицина и удаленное здравоохранение: будущее уже здесь

Телемедицина и удаленное здравоохранение: будущее уже здесь

Что такое телемедицина, дистанционное здравоохранение и их влияние на будущее поколение? Это хорошее место или нет в ситуации пандемии? Прочтите блог, чтобы узнать мнение!

Вы когда-нибудь задумывались, как хакеры зарабатывают деньги?

Вы когда-нибудь задумывались, как хакеры зарабатывают деньги?

Возможно, вы слышали, что хакеры зарабатывают много денег, но задумывались ли вы когда-нибудь о том, как они зарабатывают такие деньги? Давайте обсудим.

Обновление дополнения к macOS Catalina 10.15.4 вызывает больше проблем, чем решает

Обновление дополнения к macOS Catalina 10.15.4 вызывает больше проблем, чем решает

Недавно Apple выпустила macOS Catalina 10.15.4, дополнительное обновление для исправления проблем, но похоже, что это обновление вызывает больше проблем, приводящих к поломке компьютеров Mac. Прочтите эту статью, чтобы узнать больше