ansible自動化playbook簡單實踐

方法一:部分使用ansible

基于現有的nginx配置文件,定制部署nginx軟件,將我們的知識進行整合 定制要求:
啟動用戶:nginx-test,uid是82,系統用戶,不能登錄
啟動端口82 web項目根目錄/data/webserver/html
默認首頁:index.html
首頁內容:"welcome to ansible"

1.1 準備工作?

  • 前提:三臺系統都是rocky
    檢查系統:確保三臺主機的 Rocky 系統已聯網,能正常安裝軟件包。
  • 關閉防火墻和 SELinux?(測試環境建議關閉,生產環境按需配置規則):
    關閉防火墻:systemctl stop firewalld;systemctl disable firewalld

永久關閉 SELinux(需重啟生效):編輯?/etc/selinux/config?文件,將?SELINUX=enforcing?改為?SELINUX=disabled?

1.2?創建啟動用戶

在每臺主機上執行以下命令創建?nginx-test?用戶,且設置為系統用戶、不能登錄:
useradd -u 82 -s /sbin/nologin nginx-test

1.3?安裝 Nginx

yum install nginx -y??

1.4 配置 Nginx

修改配置文件:打開 Nginx 的主配置文件(yum 安裝一般在?/etc/nginx/nginx.conf)

user nginx-test;  # 修改啟動用戶
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;include /etc/nginx/modules-enabled/*.conf;events {worker_connections 1024;
}http {server {listen 82;  # 修改監聽端口為82server_name _;root /data/webserver/html;  # 設置項目根目錄index index.html;  # 設置默認首頁location / {try_files $uri $uri/ =404;}}include /etc/nginx/mime.types;default_type application/octet-stream;sendfile on;tcp_nopush on;tcp_nodelay on;keepalive_timeout 65;gzip on;
}
  • 創建項目根目錄及首頁文件
    mkdir -p /data/webserver/html
    echo "welcome to ansible" > /data/webserver/html/index.html
    chown -R nginx-test:nginx-test /data/webserver/html  # 設置目錄所有者

1.5?啟動 Nginx?

systemctl start nginx;systemctl enable nginx # 設置開機自啟

1.6 測試訪問

創建nginx_deploy.yml文件并輸入下面的內容并使用?ansible-playbook nginx_deploy.yml?執行

- hosts: 10.0.0.12,10.0.0.15,10.0.0.18become: truetasks:- name: Create nginx-test useruser:name: nginx-testuid: 82shell: /sbin/nologin- name: Install nginxyum:name: nginxstate: present- name: Configure nginx.conflineinfile:path: /etc/nginx/nginx.confregexp: "{{ item.regexp }}"line: "{{ item.line }}"create: trueloop:- { regexp: "^user", line: "user nginx-test;" }- { regexp: "^listen", line: "listen 82;" }- { regexp: "^root", line: "root /data/webserver/html;" }- { regexp: "^index", line: "index index.html;" }- name: Create web project root directoryfile:path: /data/webserver/htmlstate: directoryowner: nginx-testgroup: nginx-test- name: Create index.htmlcopy:content: "welcome to ansible"dest: /data/webserver/html/index.htmlowner: nginx-testgroup: nginx-test- name: Start nginxservice:name: nginxstate: startedenabled: true

方法二:完全用ansible實現自動化

注意:按照方法一 前提環境已部署好,防護墻,selinux等 這里就不再操作

1.1 制作?個nginx.conf

yum install nginx -y;systemctl stop nginx
mkdir /data/ansible/nginx -p;cd /data/ansible/nginx/
grep -Ev '#|^$' /etc/nginx/nginx.conf > nginx.conf
并且進行定制修改,修改內容如下
sed -i 's#www-data#nginx-test#' nginx.conf
cat > nginx-define.conf <<- eof
server {listen 10086;root /data/webserver/html;location / {index index.html;  # 添加默認首頁try_files $uri $uri/ =404;  # 添加請求處理規則}
}

1.2 編寫playbook? ?

編寫 nginx playbook ?件 01-nginx.yml
- hosts: webremote_user: roottasks:- name: create new useruser:name: nginx-testsystem: yesuid: 82shell: /sbin/nologin- name: create web rootfile:name: /data/webserver/htmlowner: nginx-teststate: directory- name: touch web indexshell: echo '<h1>welcome to ansible</h1>' > /data/webserver/html/index.html- name: install packageyum:name: nginxstate: present- name: copy configcopy:src: nginx.confdest: /etc/nginx/nginx.conf- name: copy subconfigcopy:src: nginx-define.confdest: /etc/nginx/conf.d- name: start serviceservice:name: nginxstate: startedenabled: yes

1.3 檢測執行效果

ansible-playbook 01-nginx.yml --syntax-check? ? 檢測效果
ansible-playbook 01-nginx.yml -C? ? ? 模擬執行
注:該步驟執行即使存在一兩個異常,也不影響后續的正常安裝
ansible-playbook 01-nginx.yml? ?執行文件
ansible web -m shell -a "getent passwd | grep 82"
ansible web -m shell -a "ls -l /data/"
ansible web -m shell -a "netstat -tnulp | grep nginx"??

若出現都是80端口,則還需要執行??ansible web -m shell -a "systemctl reload nginx"

?

ansible web -m shell -a "curl -s localhost:10086"

1.4 清除環境

ansible web - m service - a "name=nginx state=stopped"
ansible web - m yum? - a "name=nginx,nginx-common state=absent"
ansible web - m file - a "path=/data/webserver state=absent"
ansible web - m user - a "name=nginx-test state=absent"

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/83196.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/83196.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/83196.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【Office】Excel兩列數據比較方法總結

在Excel中&#xff0c;比較兩列數據是否相等有多種方法&#xff0c;以下是常用的幾種方式&#xff1a; 方法1&#xff1a;使用公式&#xff08;返回TRUE/FALSE&#xff09; 在空白列&#xff08;如C列&#xff09;輸入公式&#xff0c;向下填充即可逐行比較兩列&#xff08;如…

day 42

知識點回顧 1.回調函數 2.lambda函數 3.hook函數的模塊鉤子和張量鉤子 4.Grad-CAM的示例 一。回調函數示例 Hook本質是回調函數&#xff0c;所以我們先介紹一下回調函數。回調函數是作為參數傳遞給其他函數的函數&#xff0c;其目的是在某個特定事件發生時被調用執行。這…

10.安卓逆向2-frida hook技術-frida基本使用-frida指令(用于hook)

免責聲明&#xff1a;內容僅供學習參考&#xff0c;請合法利用知識&#xff0c;禁止進行違法犯罪活動&#xff01; 內容參考于&#xff1a;圖靈Python學院 工具下載&#xff1a; 鏈接&#xff1a;https://pan.baidu.com/s/1bb8NhJc9eTuLzQr39lF55Q?pwdzy89 提取碼&#xff1…

LLM-MPC混合架構:車載大語言模型用來增強自動駕駛系統

1. 概述 2025年&#xff0c;蘇黎世研究團隊在RSS2025會議上正式提出「LLM-MPC混合架構」&#xff0c;標志著大語言模型&#xff08;LLM&#xff09;在自動駕駛系統中的實用化邁出關鍵一步。該方案旨在解決傳統深度學習模型在極端交通場景中泛化能力不足的問題。通過在車載終端…

解釋k8s種ConfigMap和Secret的作用,如何在Pod中掛載環境變

一、ConfigMap & Secret 核心定位 屬于Kubernetes的配置管理特性&#xff0c;用于解耦應用與配置 1. ConfigMap 作用&#xff1a;存儲非敏感配置數據 存儲內容&#xff1a; 環境變量命令行參數配置文件&#xff08;如JSON/XML/YAML&#xff09;系統參數&#xff08;如J…

Android --- ObjectAnimator 和 TranslateAnimation有什么區別

文章目錄 2. 作用范圍和功能2. 動畫表現3. 是否修改 View 的屬性4. 適用場景5. 性能總結&#xff1a; ObjectAnimator 和 TranslateAnimation 都是 Android 中常用的動畫類型&#xff0c;但它們有以下幾個關鍵的區別&#xff1a; 2. 作用范圍和功能 ObjectAnimator&#xff1a…

3d GIS數據來源與編輯工具

1、衛星遙感 2、航空攝影測量 3、地面實測技術 全站儀 3維掃描 3D GIS數據制作全流程詳解 一、數據采集&#xff1a;多源數據獲取 3D GIS數據的制作需從多維度采集地理空間信息&#xff0c;以下是主要采集方式及適用場景&#xff1a; &#xff08;一&#xff09;遙感與航測…

實驗設計與分析(第6版,Montgomery)第4章隨機化區組,拉丁方, 及有關設計4.5節思考題4.26~4.27 R語言解題

本文是實驗設計與分析&#xff08;第6版&#xff0c;Montgomery著&#xff0c;傅玨生譯) 第章隨機化區組&#xff0c;拉丁方&#xff0c; 及有關設計4.5節思考題4.26~4.27 R語言解題。主要涉及方差分析&#xff0c;正交拉丁方。 batch <- c(rep("batch1",5), rep(…

linux創建虛擬網卡和配置多ip

1.展示當前網卡信息列表&#xff1a; linux上&#xff1a; ip a ifconfigwindows上&#xff1a; ipconfig 2.創建虛擬網卡對&#xff1a; sudo ip link add name veth0 type veth peer name veth1 在 ip link add 命令中&#xff0c;type 參數可以指定多種虛擬網絡設備類型&…

分布式項目保證消息冪等性的常見策略

Hello&#xff0c;大家好&#xff0c;我是灰小猿&#xff01; 在分布式系統中&#xff0c;由于各個服務之間獨立部署&#xff0c;各個服務之間依靠遠程調用完成通信&#xff0c;再加上面對用戶重復點擊時的重復請求等情況&#xff0c;所以如何保證消息消費的冪等性是在分布式或…

微信小程序(uniapp)對接騰訊云IM

UniApp 對接騰訊云 IM&#xff08;即時通訊&#xff09;完整指南 一、項目背景與需求分析 隨著社交場景的普及&#xff0c;即時通訊功能已成為移動應用的標配。騰訊云 IM&#xff08;Tencent IM&#xff0c;即 TIM&#xff09;提供穩定可靠的即時通訊服務&#xff0c;支持單聊…

Portainer安裝指南:多節點監控的docker管理面板-家庭云計算專家

背景 Portainer 是一個輕量級且功能強大的容器管理面板&#xff0c;專為 Docker 和 Kubernetes 環境設計。它通過直觀的 Web 界面簡化了容器的部署、管理和監控&#xff0c;即使是非技術用戶也能輕松上手。Portainer 支持多節點管理&#xff0c;允許用戶從一個中央控制臺管理多…

[Redis] Redis命令在Pycharm中的使用

初次學習&#xff0c;如有錯誤還請指正 目錄 String命令 Hash命令 List命令 set命令 SortedSet命令 連接pycharm的過程見&#xff1a;[Redis] 在Linux中安裝Redis并連接桌面客戶端或Pycharm-CSDN博客 redis命令的使用見&#xff1a;[Redis] Redis命令&#xff08;1&#xf…

計算機網絡:物理層

目錄 一、物理層的基本概念 二、物理層下面的傳輸媒體 2.1 導引型傳輸媒體 2.1.1 同軸電纜 2.1.2 雙絞線 2.1.3 光纖 2.1.4 電力線 2.2 非導引型傳輸媒體 2.2.1 無線電波 2.2.2 微波 2.2.3 紅外線 2.2.4 可見光 三、傳輸方式 3.1 串行與并行 3.2 同步與異步 3.…

構建系統maven

1 前言 說真的&#xff0c;我是真的不想看構建了&#xff0c;因為真的太多了。又多又亂。Maven、Gradle、Make、CMake、Meson、Ninja&#xff0c;Android BP。。。感覺學不完&#xff0c;根本學不完。。。 但是沒辦法最近又要用一下Maven&#xff0c;所以咬著牙再簡單整理一下…

UE5藍圖暴露變量,在游戲運行時修改變量實時變化、看向目標跟隨目標Find Look at Rotation、修改玩家自身彈簧臂

UE5藍圖中暴露變量&#xff0c;類似Unity中public一個變量&#xff0c;在游戲運行時修改變量實時變化 1&#xff0c;添加變量 2&#xff0c;設置變量的值 3&#xff0c;點開小眼睛&#xff0c;此變量顯示在編輯器中&#xff0c;可以運行時修改 看向目標跟隨目標Find Look at R…

proteus美觀與偏好設置

本文主要講&#xff1a; 1 快捷鍵修改&#xff08;復制&#xff0c;粘貼&#xff0c;原件旋轉&#xff09; 2 背景顏色替換 3 模塊分區 一 快捷鍵的設置 設置復制粘貼和旋轉三個 這里只是強調一下要分配 二 背景顏色 原來的背景顏色&#xff1a; 之后的背景顏色&#xff1a;…

Arm處理器調試采用jlink硬件調試器的命令使用大全

arm處理器分為cortex-a&#xff0c;cortex-r&#xff0c;cortex-m等3個內核系列&#xff0c;其中m系列一般是單片機&#xff0c;例如stm32等&#xff0c;工控用得挺多。a系列一般是消費娛樂產品等使用較多&#xff0c;例如手機處理器。r系列是高端實時類型處理器&#xff0c;價…

如何將圖像插入 PDF:最佳工具比較

無論您是編輯營銷材料、寫報告還是改寫原來的PDF文件&#xff0c;將圖像插入 PDF 都至關重要。幸運的是&#xff0c;有多種在線和離線工具可以簡化此任務。在本文中&#xff0c;我們將比較一些常用的 PDF 添加圖像工具&#xff0c;并根據您的使用場景推薦最佳解決方案&#xff…

4、獲取樹莓派溫度

打開終端&#xff0c;使用指令查看CPU溫度&#xff0c;依次輸入以下指令&#xff1a; 1.進入操作目錄 cd /sys/class/thermal/thermal_zone0 2.查看溫度 cat temp 樹莓派的返回值 51540 返回值除以1000為當前CPU溫度值。即當前溫度為51攝氏度。