DevOps 360° – Telegram
DevOps 360°
399 subscribers
50 photos
61 videos
4 files
156 links
Привет! 🌟

Добро пожаловать! Здесь ты узнаешь о новых фичах в мире DevOps, получишь помощь в рабочих задачах и освоишь профессию без токсичного комьюнити. Подключайся и общайся со мной @kubernetesman! ❤️
Download Telegram
This media is not supported in your browser
VIEW IN TELEGRAM
Начнемс ?)
Залетаем на менторство и практику, о чем говорилось выше https://news.1rj.ru/str/Devops_Revolution/54
🏃‍♂️🏃‍♂️🏃‍♂️🏃‍♂️🏃‍♂️
https://news.1rj.ru/str/+hC65UC7ojGRiMTgysdfds
Please open Telegram to view this post
VIEW IN TELEGRAM
Please open Telegram to view this post
VIEW IN TELEGRAM
👍4
### Установка Ansible

1. Установка Homebrew: Это пакетный менеджер для macOS, который упрощает установку программного обеспечения. Если у вас еще не установлен Homebrew, откройте терминал и выполните команду:


   /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"


2. Установка Ansible: После успешной установки Homebrew можно установить Ansible, выполнив следующую команду в терминале:


   brew install ansible


3. Проверка установки: Чтобы убедиться, что установка прошла успешно, выполните:


   ansible --version


Это покажет установленную версию Ansible.

### Установка Ansible на Linux

Ansible можно установить на большинстве дистрибутивов Linux. Рассмотрим Ubuntu и CentOS в качестве примеров.

#### На Ubuntu

1. Обновление пакетов: Сначала обновите список доступных пакетов:


   sudo apt update


2. Установка Ansible: Выполните следующую команду для установки:


   sudo apt install ansible


3. Проверка установки: Проверьте, что Ansible установлен:


   ansible --version


#### На CentOS/RHEL

1. Включение EPEL репозитория: Ansible доступен через EPEL (Extra Packages for Enterprise Linux). Включите его с помощью команды:


   sudo yum install epel-release


2. Установка Ansible: Теперь установите Ansible:


   sudo yum install ansible


3. Проверка установки: Проверяем версию Ansible:


   ansible --version


### Начало работы с Ansible

После установки Ansible вы можете начать работать с ним. Прежде всего, нужно подготовить свой инвентарь и плейбуки.

1. Создание инвентарного файла: Инвентарный файл (обычно hosts или inventory) содержит список серверов, с которыми будет работать Ansible. Создайте новый файл, например inventory.ini:


   [myservers]
192.168.1.10
192.168.1.11


Здесь замените IP-адреса на адреса ваших серверов. Группа myservers содержит сервера, на которых вы будете проводить операции.

2. Создание плейбука: Плейбук описывает действия, которые Ansible выполнит на серверах. Например, создайте файл myplaybook.yml:


   - hosts: myservers
tasks:
- name: Установить Apache
yum:
name: httpd
state: present


В этом плейбуке мы указываем, что нужно установить пакет httpd (Apache) на все серверы из группы myservers.

3. Запуск плейбука: Для запуска плейбука выполните команду:


   ansible-playbook -i inventory.ini myplaybook.yml


Эта команда запускает плейбук, и Ansible выполняет указанные задачи на всех серверах, которые вы перечислили в инвентаре.

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

Таким образом, у вас есть основные шаги для установки и использования Ansible. С его помощью вы можете автоматизировать множество задач, что значительно упростит вашу работу с серверами и приложениями.
🔝 Наш чат для обсуждений |🚀 Буст для канала
Please open Telegram to view this post
VIEW IN TELEGRAM
3
Please open Telegram to view this post
VIEW IN TELEGRAM
😁6🐳2🔥1
Плейбук в Ansible — это файл, написанный на YAML, который описывает настроенные задачи или инструкции, которые Ansible должен выполнить на удаленных хостах. Плейбуки позволяют упрощать управление конфигурацией, автоматизировать задачи и развертывать приложения. Они могут содержать наборы задач, которые запускаются на одном или нескольких хостах, а также могут включать роли, которые помогают структурировать код и повторно использовать настройки.

### Основы плейбуков

Плейбук имеет простую структуру. Вот основные компоненты плейбука:

1. Определение хостов: Этот раздел указывает, к каким хостам применяются задачи. Можно использовать конкретные имена хостов, группы или даже переменные.

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

3. Задачи (tasks): Основные инструкции, которые Ansible будет выполнять. Каждая задача выполняет какой-то модуль, например, установку пакетов, копирование файлов и т. д.

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

### Пример простого плейбука

Вот пример простого плейбука, который устанавливает Nginx на группе хостов под названием webservers и запускает службу:

---
- name: Установить и запустить Nginx
hosts: webservers
become: yes # Поднимает привилегии до суперпользователя
tasks:
- name: Обновить пакеты
apt:
update_cache: yes

- name: Установить Nginx
apt:
name: nginx
state: present

- name: Запустить и включить Nginx
service:
name: nginx
state: started
enabled: yes


### Использование ролей в плейбуках

Роли — это удобный способ организации и повторного использования вашего кода. Они позволяют структурировать вашу конфигурацию так, чтобы каждый компонент имел свое собственное место.

#### Структура роли

Роли имеют определенную структуру каталогов, которая может включать:

- tasks/: Задачи, которые будет выполнять роль.
- handlers/: Обработчики, которые выполняются при изменении состояния (например, перезапуск службы).
- templates/: Шаблоны файлов, которые могут быть использованы.
- files/: Файлы, которые могут быть скопированы на удаленные хосты.
- vars/: Переменные, специфичные для роли.
- defaults/: Значения по умолчанию для переменных роли.
- meta/: Метаданные роли.

#### Пример использования роли в плейбуке

Давайте создадим роль для установки Nginx и использовать ее в плейбуке.

1. Создание роли:

Для создания роли Нginx можно использовать команду:

ansible-galaxy init nginx


Эта команда создаст структуру каталогов для роли.

2. Определение задач в `tasks/main.yml`:

---
- name: Обновить пакеты
apt:
update_cache: yes

- name: Установить Nginx
apt:
name: nginx
state: present

- name: Запустить и включить Nginx
service:
name: nginx
state: started
enabled: yes


3. Использование роли в плейбуке:

Теперь вы можете использовать эту роль в вашем плейбуке:

---
- name: Установить Нginx с помощью роли
hosts: webservers
become: yes
roles:
- nginx


### Запуск плейбука

Для запуска плейбука используйте команду ansible-playbook, как показано ниже:

ansible-playbook имя_вашего_плейбука.yml


Не забудьте указать инвентарь, если он не является файлом по умолчанию:

ansible-playbook -i your_inventory_file имя_вашего_плейбука.yml


### Заключение

Плейбуки в Ansible — это мощный инструмент для автоматизации, с возможностью управления сложными конфигурациями с использованием ролей. Роли обеспечивают модульность, что делает их отличным способом организации ваших автоматизаций. Вы можете гибко адаптировать свои плейбуки и роли под свои нужды, что значительно упрощает процесс управления.
🔝 Наш чат для обсуждений |🚀 Буст для канала
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥3
Ох - включаем наши головушки и погнали вникать !

Давайте создадим пример Ansible роли, которая будет устанавливать и настраивать веб-сервер Nginx. Мы организуем это в соответствии с перечисленными вами компонентами роли. В рамках этой роли будут использоваться следующие директории: tasks, handlers, templates, files, vars, defaults и meta.

### Структура роли

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

roles/
└── nginx_server/
├── tasks/
│ └── main.yml
├── handlers/
│ └── main.yml
├── templates/
│ └── nginx.conf.j2
├── files/
│ └── index.html
├── vars/
│ └── main.yml
├── defaults/
│ └── main.yml
└── meta/
└── main.yml


### Содержимое файлов роли

#### 1. tasks/main.yml
---
- name: Обновить пакеты
apt:
update_cache: yes

- name: Установить Nginx
apt:
name: nginx
state: present
notify: Перезапустить Nginx

- name: Копировать файл индекса
copy:
src: index.html
dest: /var/www/html/index.html
notify: Перезапустить Nginx

- name: Настроить Nginx
template:
src: nginx.conf.j2
dest: /etc/nginx/nginx.conf
notify: Перезапустить Nginx


#### 2. handlers/main.yml
---
- name: Перезапустить Nginx
service:
name: nginx
state: restarted


#### 3. templates/nginx.conf.j2
worker_processes auto;

events {
worker_connections 1024;
}

http {
include /etc/nginx/mime.types;
default_type application/octet-stream;

server {
listen 80;
server_name {{ ansible_hostname }};

location / {
root /var/www/html;
index index.html index.htm;
}
}
}


#### 4. files/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<noscript>Привет, Nginx!</noscript>
</head>
<body>
<h1>Сервер Nginx работает!</h1>
</body>
</html>


#### 5. vars/main.yml
---
nginx_port: 80


#### 6. defaults/main.yml
---
nginx_listen_port: 80


#### 7. meta/main.yml
---
dependencies:
- role: some_other_role


### Плейбук для вызова роли

Теперь мы можем создать плейбук, который использует эту роль:

---
- name: Установить и настроить Nginx
hosts: webservers
become: yes
roles:
- nginx_server


### Объяснение

В этом примере:

- В tasks/main.yml мы определяем задачи, которые будут выполнены. Они обновляют систему, устанавливают Nginx, копируют файл index.html на веб-сервер и настраивают конфигурацию Nginx на основе шаблона.
- В handlers/main.yml мы определяем обработчик для перезапуска службы Nginx, который будет вызван, если произошли изменения.
- В templates/nginx.conf.j2 находится шаблон конфигурационного файла Nginx, который использует переменные.
- В files/index.html хранится HTML-файл, который будет отображаться клиентам.
- В vars/main.yml указаны переменные, специфичные для роли, например, порт, который Nginx будет слушать.
- В defaults/main.yml задаются значения по умолчанию для переменных роли.
- В meta/main.yml можно указать зависимости от других ролей.

Такой подход делает вашу роль модульной и легко управляемой, что особенно полезно в больших проектах. Вы можете переиспользовать эту роль в других плейбуках или добавлять новые функции по мере необходимости.
🔝 Наш чат для обсуждений |🚀 Буст для канала
Please open Telegram to view this post
VIEW IN TELEGRAM
Следующая тема недели
Final Results
67%
CI/CD
9%
Terraform
23%
docker-compose
DevOps 360° pinned «Следующая тема недели»
Всех с окончание рабочей недели , но давайте хорошенька пройдемся по Ansible и сделаем , что-то прикольное!
Давайте создадим более сложный плейбук Ansible, который будет устанавливать Docker на несколько серверов, а затем развернет простое приложение, например, Nginx, в контейнере Docker.

### Пример структуры проекта

Представим, что у нас есть следующая структура:

playbooks/
└── docker_nginx.yml
roles/
└── docker/
├── tasks/
│ ├── main.yml
├── handlers/
│ └── main.yml
├── defaults/
│ └── main.yml
├── meta/
│ └── main.yml


### Содержимое файлов роли

#### 1. roles/docker/tasks/main.yml
---
- name: Обновить пакеты на хосте 🛠
apt:
update_cache: yes

- name: Установить зависимости для Docker 📦
apt:
name: "{{ item }}"
state: present
loop:
- apt-transport-https
- ca-certificates
- curl
- software-properties-common

- name: Добавить GPG ключ Docker 🔑
apt_key:
url: https://download.docker.com/linux/ubuntu/gpg
state: present

- name: Добавить репозиторий Docker 📥
apt_repository:
repo: "deb [arch=amd64] https://download.docker.com/linux/ubuntu {{ ansible_lsb.codename }} stable"
state: present

- name: Установить Docker 🐳
apt:
name: docker-ce
state: latest

- name: Убедиться, что Docker запущен 🎉
service:
name: docker
state: started
enabled: yes

- name: Запустить Nginx в контейнере Docker 🚀
docker_container:
name: nginx_container
image: nginx:latest
state: started
ports:
- "80:80"


#### 2. roles/docker/handlers/main.yml
---
- name: Перезапустить Docker 🛑➡️🆕
service:
name: docker
state: restarted


#### 3. roles/docker/defaults/main.yml
---
docker_version: "latest"


#### 4. roles/docker/meta/main.yml
---
dependencies: []


### Содержимое плейбука

#### playbooks/docker_nginx.yml
---
- name: Установка Docker и развертывание Nginx на серверах 🐳➡️🍕
hosts: all
become: yes
roles:
- docker


### Использование плейбука

Этот плейбук устанавливает Docker и запускает контейнер с Nginx на всех серверах, указанных в инвентаре. Для его запуска вам нужно выполнить команду:

ansible-playbook -i inventory_file playbooks/docker_nginx.yml


Где inventory_file - это файл с перечислением ваших серверов. Например, он может выглядеть так:

[web_servers]
server1 ansible_host=192.168.1.10
server2 ansible_host=192.168.1.11


### Заключение

Теперь у вас есть плейбук, который устанавливает Docker на нескольких серверах и запускает Nginx в контейнере. Эмодзи добавляют немного веселья в процесс! 😊
🔝 Наш чат для обсуждений |🚀 Буст для канала
Please open Telegram to view this post
VIEW IN TELEGRAM
👍3
Channel photo updated
С новой рабочей неделей! Рубрика недели CI/CD

CI/CD — это практики, используемые в разработке программного обеспечения, которые помогают делать процесс создания и развертывания приложений более быстрым и эффективным. Давайте разберем, что это значит, простыми словами и с эмодзи.

CI (Continuous Integration, непрерывная интеграция) — это процесс, когда программисты регулярно (даже несколько раз в день) объединяют свои изменения в общий код проекта. Это похоже на то, как команда готовит блюдо — каждый добавляет свои ингредиенты по мере готовности, а затем все смешивают, чтобы получить вкусное угощение. 🍲 Это позволяет быстро находить и исправлять ошибки, когда они еще маленькие и несложные.

CD (Continuous Delivery/Continuous Deployment, непрерывная доставка/развертывание) — это следующий шаг, который происходит после интеграции. Непрерывная доставка означает, что код автоматически подготавливается к развертыванию на рабочем сервере, но окончательное развертывание может происходить вручную. Это как если бы вы готовили блюдо и держали его в готовности, а подаете только тогда, когда уверены, что оно идеально! 🍽

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

Использование CI/CD помогает командам работать более слаженно, повышает качество кода и сокращает время от идеи до реализации. 📈 Значит, меньше времени на исправление ошибок и больше времени на новые фичи!

Таким образом, CI/CD — это как суперкоманда шеф-поваров, которые совместно работают над созданием идеального блюда и тут же подают его как можно быстрее. 🍽

Если у вас есть вопросы о CI/CD или вы хотите узнать больше — пишите в комментарии! 💬

🔝 Наш чат для обсуждений |🚀 Буст для канала

🤗Поддержи канал и автора миской супа и на развитие мерча!
Please open Telegram to view this post
VIEW IN TELEGRAM
👍6🔥2
🚀 Давайте поговорим о CI/CD и GitLab!

Всё начинается с Git — мощного инструмента для контроля версий кода. Когда разработчики работают над проектом, они используют Git для отслеживания изменений в своих файлах. Это позволяет команде видеть, кто и когда вносил правки, а также легко возвращаться к предыдущим версиям, если что-то пошло не так. 📂🔍

Теперь представьте, что у нас есть GitLab — это не только система управления репозиториями, но и мощная платформа для CI/CD. 📈🔥 GitLab объединяет процесс разработки, тестирования и развертывания в одном месте, делая его максимально удобным для команд.

На начальном уровне GitLab предлагает возможность создания репозиториев, где вся команда может хранить свой код. Когда вы делаете изменения и хотите их сохранить, вы создаете коммит — это как записка, в которой вы описываете, что нового вы добавили или изменили. 📝

Далее, GitLab позволяет вам настраивать проектные пайплайны. Они состоят из различных этапов, таких как сборка, тестирование и развертывание. Каждый из этих этапов —это автоматизированное действие, которое выполняется при каждом новом коммите. Это похоже на конвейер, где ваш код проходит через несколько проверок, прежде чем быть представленным пользователям. ⚙️🔧

Одной из ключевых особенностей GitLab является возможность использования гитовских воркфлоу, которые позволяют автоматизировать процесс с помощью .gitlab-ci.yml файла. Это специальный файл, в котором вы описываете, что именно должно происходить на каждом этапе. Например, вы можете указать, чтобы тесты запускались автоматически каждый раз, когда кто-то делает коммит. Это поможет вам убедиться, что новый код не поломал ничего в приложении. 👨‍💻

Внедряя GitLab CI/CD, вы делаете свою работу более предсказуемой и эффективной, так как автоматизация процессов позволяет сосредоточиться на написании качественного кода, а не на его развертывании. Это как если бы вы могли сами автоматически заказывать продукты в магазине без необходимости стоять в очереди! 🛒🥳

Подводя итоги, GitLab — это отличный инструмент для начала вашего пути в CI/CD. Он объединяет всю команду, упрощает процесс развертывания и позволяет вам быстрее получать обратную связь. Если вы ещё не начали использовать GitLab, самое время! 🌟

Пишите в комментариях, если у вас есть вопросы или хотите узнать больше! 📢💬

🔝 Наш чат для обсуждений |🚀 Буст для канала

🤗Поддержи канал и автора миской супа и на развитие мерча!
Please open Telegram to view this post
VIEW IN TELEGRAM
👍2
🌟 CI/CD начинается с установки GitLab Runner!

Если вы хотите автоматизировать процесс тестирования и развертывания вашего приложения, вам нужно настроить GitLab Runner. 🏃‍♂️🔥 Это агент, который запускает ваши задания CI/CD. Установка раннера — это первый шаг на пути к безошибочному процессу интеграции и доставки.

Вот краткий гайд о том, как установить GitLab Runner на сервер или в Kubernetes:

1. Установите GitLab Runner: Если вы хотите установить его на своём сервере, начните с того, чтобы открыть терминал и выполнить следующие команды:


   # Добавляем официальный репозиторий GitLab
curl -L https://packages.gitlab.com/install/repo.sh | sudo bash

# Устанавливаем GitLab Runner
sudo apt-get install gitlab-runner


Для установки в Kubernetes можно использовать следующую команду:


   kubectl apply -f https://gitlab.com/gitlab-org/gitlab-runner/-/raw/master/deploy/kubernetes/helm/gitlab-runner/templates/gitlab-runner.yaml


2. Регистрация раннера: После установки, вам нужно зарегистрировать ваш раннер с помощью команды:


   gitlab-runner register


При регистрации вам будет предложено ввести URL вашего GitLab и токен, который можно найти в настройках вашего проекта в разделе CI/CD. 🗝🌐

3. Настройка конфигурации: В процессе регистрации вас спросят, какой тип раннера вы хотите установить (например, Shell, Docker, Kubernetes). Выберите тот, который подходит для вашего проекта. 📦🔍

4. Запуск раннера: После успешной регистрации, запустите ваш раннер командой:


   gitlab-runner start


Теперь ваш GitLab Runner готов к работе! 🎉 Вы можете настроить свои проекты для использования CI/CD, и каждое изменение ваш код будет автоматически проходить сборку, тесты и развертывание. 🔄🚀

💡 *Не забывайте следить за статусом ваших пайплайнов в GitLab! Это поможет вам своевременно обнаруживать и устранять проблемы в коде.*

Делитесь опытом установки и используйте CI/CD в своей команде для повышения качества кода! 🛠💪 #DevOps #GitLab #CICD #Automatization

🔝 Наш чат для обсуждений |🚀 Буст для канала

🤗Поддержи канал и автора миской супа и на развитие мерча!
Please open Telegram to view this post
VIEW IN TELEGRAM
🤓1
🌟 Создание простого CI/CD пайплайна в GitLab 🌟

Привет, друзья! 👋 Сегодня я расскажу вам, как создать простой CI/CD пайплайн с использованием GitLab. Это отличный способ автоматизировать процесс развертывания вашего приложения и ускорить разработку! 🚀

### Что такое CI/CD? 🤔

CI/CD расшифровывается как "непрерывная интеграция и непрерывная доставка". Это процесс, который позволяет разработчикам часто обновлять код, автоматически проверять его и развертывать изменения без ручного вмешательства. Это удобно и повышает качество вашего кода.

### Создаем файл .gitlab-ci.yml 📝

Для начала создадим файл конфигурации, который называется .gitlab-ci.yml. Этот файл будет содержать все инструкции для вашего пайплайна. Вот простой пример:

stages:
- build
- test
- deploy

build_job:
stage: build
noscript:
- echo "Сборка приложения..."
- mkdir build
- cp -r src/* build/

test_job:
stage: test
noscript:
- echo "Запуск тестов..."
- cd build
- echo "Тесты прошли успешно!"

deploy_job:
stage: deploy
noscript:
- echo "Развертывание приложения..."
- echo "Приложение успешно развернуто!"


### Как это работает? 🛠

1. Этапы (stages): В начале мы определяем этапы пайплайна: build, test и deploy. Это логические блоки, которые упорядочивают выполнение задач. Каждый этап выполняется последовательно.

2. Работы (jobs): Далее мы создаем три работы (jobs) для каждого этапа. В каждой работе мы указываем, что нужно сделать. В этом примере:
- build_job отвечает за сборку приложения. Он создает папку build и копирует туда исходный код из папки src.
- test_job запускает тесты. В реальном проекте, здесь можно добавить команды для запуска тестов.
- deploy_job отвечает за развертывание приложения. В нашем простом примере он просто выводит сообщение, но здесь вы можете добавить команды для развертывания на сервер.

### Как запустить пайплайн? 🚦

Теперь, когда мы создали .gitlab-ci.yml, достаточно сделать коммит и запушить изменения в ваш репозиторий в GitLab. Каждый раз, когда вы будете отправлять новое изменение, GitLab автоматически будет запускать ваш пайплайн, проходя через созданные этапы.

### Резюме 💡

Создание CI/CD пайплайна в GitLab позволяет вам автоматизировать процесс сборки, тестирования и развертывания вашего приложения. Это не только упрощает вашу работу, но и улучшает качество кода, позволяя вам быть уверенными в каждом развертывании. 🌈

Не бойтесь экспериментировать и добавлять новые задания в ваш пайплайн! Успехов в разработке! 💪🎉

Если у вас есть вопросы, пишите в комментариях! 📩👨‍💻

🔝 Наш чат для обсуждений |🚀 Буст для канала

🤗Поддержи канал и автора миской супа и на развитие мерча!
Please open Telegram to view this post
VIEW IN TELEGRAM
🔥2