generated from CC/VMServiceTemplate
Compare commits
24 Commits
317bf4be62
...
main
| Author | SHA1 | Date | |
|---|---|---|---|
| e785930578 | |||
|
|
92f9bd459d | ||
|
|
8518bd6064 | ||
|
|
3c7a22032a | ||
|
|
a363aafd97 | ||
|
|
e40fb6742a | ||
|
|
da2362d0a9 | ||
|
|
684a86385b | ||
|
|
eded1b9777 | ||
|
|
80c611ecda | ||
|
|
2d27326cbc | ||
|
|
325d61bef0 | ||
|
|
4bff0f9703 | ||
| 2f505e5062 | |||
|
|
d73dd0919d | ||
|
|
ba593526bd | ||
|
|
adc4188918 | ||
|
|
5e4d5c82d8 | ||
|
|
31cc759d4d | ||
|
|
afbd95d765 | ||
|
|
ae70feaaf3 | ||
|
|
d68ab4b309 | ||
|
|
1cb81833d7 | ||
|
|
bf11724516 |
@@ -1,6 +1,8 @@
|
|||||||
name: Deploy VM and App
|
name: Deploy VM and App
|
||||||
|
|
||||||
on:
|
on:
|
||||||
|
push:
|
||||||
|
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
inputs:
|
inputs:
|
||||||
tfvars_file:
|
tfvars_file:
|
||||||
@@ -21,11 +23,11 @@ jobs:
|
|||||||
- name: Check files & Select tfvars
|
- name: Check files & Select tfvars
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
pwd
|
#rm ansible/inventory/inventory.yml
|
||||||
mkdir -p ansible/inventory
|
mkdir -p ansible/inventory
|
||||||
cd terraform
|
cd terraform
|
||||||
cp ${{ inputs.tfvars_file }} terraform.tfvars
|
#rm vm_data.yml
|
||||||
ls
|
cp "${{ inputs.tfvars_file || 'single.tfvars.example' }}" terraform.tfvars
|
||||||
|
|
||||||
- uses: hashicorp/setup-terraform@v4
|
- uses: hashicorp/setup-terraform@v4
|
||||||
|
|
||||||
@@ -40,6 +42,27 @@ jobs:
|
|||||||
run: terraform apply -auto-approve
|
run: terraform apply -auto-approve
|
||||||
working-directory: "terraform"
|
working-directory: "terraform"
|
||||||
|
|
||||||
|
- name: Install Ansible
|
||||||
|
shell: bash
|
||||||
|
run: |
|
||||||
|
sudo apt-get update
|
||||||
|
sudo apt-get install -y ansible rsync
|
||||||
|
|
||||||
|
- name: Set up SSH
|
||||||
|
run: |
|
||||||
|
mkdir -p ~/.ssh
|
||||||
|
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/vlans_rsa
|
||||||
|
chmod 600 ~/.ssh/vlans_rsa
|
||||||
|
cat > ~/.ssh/config <<'EOF'
|
||||||
|
Host *
|
||||||
|
StrictHostKeyChecking no
|
||||||
|
UserKnownHostsFile=/dev/null
|
||||||
|
EOF
|
||||||
|
|
||||||
|
- name: Run playbook
|
||||||
|
run: |
|
||||||
|
ansible-playbook ansible/playbooks/docker_copy.yml -i ansible/inventory/inventory.yml -u cloud --private-key ~/.ssh/vlans_rsa
|
||||||
|
|
||||||
- name: Configure Git
|
- name: Configure Git
|
||||||
run: |
|
run: |
|
||||||
git config user.name "git-bot"
|
git config user.name "git-bot"
|
||||||
@@ -53,26 +76,3 @@ jobs:
|
|||||||
git push origin HEAD:main
|
git push origin HEAD:main
|
||||||
env:
|
env:
|
||||||
GITEA_USERNAME: git-bot # or your bot account
|
GITEA_USERNAME: git-bot # or your bot account
|
||||||
|
|
||||||
- name: Install Ansible
|
|
||||||
shell: bash
|
|
||||||
run: |
|
|
||||||
sudo apt-get update
|
|
||||||
sudo apt-get install -y ansible
|
|
||||||
|
|
||||||
- name: Set up SSH
|
|
||||||
run: |
|
|
||||||
mkdir -p ~/.ssh
|
|
||||||
echo "${{ secrets.SSH_PRIVATE_KEY }}" > ~/.ssh/id_rsa
|
|
||||||
chmod 600 ~/.ssh/id_rsa
|
|
||||||
echo -e "Host *\n\tStrictHostKeyChecking no\n\tUserKnownHostsFile=/dev/null\n" > ~/.ssh/config
|
|
||||||
|
|
||||||
- name: Setup Ansible Directories
|
|
||||||
run: |
|
|
||||||
pwd
|
|
||||||
cat ansible/inventory/inventory.yml
|
|
||||||
ls -r
|
|
||||||
|
|
||||||
- name: Run playbook
|
|
||||||
run: |
|
|
||||||
ansible-playbook ansible/playbooks/docker_copy.yml -i ansible/inventory/inventory.yml -u cloud --private-key ~/.ssh/id_rsa
|
|
||||||
|
|||||||
@@ -3,6 +3,6 @@
|
|||||||
"n8n":
|
"n8n":
|
||||||
"hosts":
|
"hosts":
|
||||||
"n8n-01":
|
"n8n-01":
|
||||||
"ansible_host": "192.168.10.117"
|
"ansible_host": "192.168.10.107"
|
||||||
"vars":
|
"vars":
|
||||||
"ansible_user": "cloud"
|
"ansible_user": "cloud"
|
||||||
|
|||||||
@@ -40,12 +40,12 @@ module "vm-n8n" {
|
|||||||
|
|
||||||
module "inventory" {
|
module "inventory" {
|
||||||
source = "./modules/proxmox_ansible_inventory"
|
source = "./modules/proxmox_ansible_inventory"
|
||||||
filename = "${path.root}/ansible/inventory/inventory.yml"
|
filename = "${abspath("${path.root}/..")}/ansible/inventory/inventory.yml"
|
||||||
instances = local.vm_created
|
instances = local.vm_created
|
||||||
}
|
}
|
||||||
|
|
||||||
module "vm_data" {
|
module "vm_data" {
|
||||||
source = "./modules/proxmox_vm_data"
|
source = "./modules/proxmox_vm_data"
|
||||||
filename = "${path.root}/terraform/vm_data.yml"
|
filename = "${abspath("${path.root}/..")}/terraform/vm_data.yml"
|
||||||
instances = local.vm_created
|
instances = local.vm_created
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -57,7 +57,7 @@ resource "proxmox_virtual_environment_file" "cloud_config" {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
resource "proxmox_virtual_environment_vm" "ubuntu_22_minimal_template" {
|
resource "proxmox_virtual_environment_vm" "ubuntu_22_minimal_clone" {
|
||||||
name = var.vm_name # VM name
|
name = var.vm_name # VM name
|
||||||
node_name = var.node_name # Proxmox node to deploy the VM
|
node_name = var.node_name # Proxmox node to deploy the VM
|
||||||
tags = var.vm_tags # Optional VM tags for categorization
|
tags = var.vm_tags # Optional VM tags for categorization
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
output "vm_ipv4_address" {
|
output "vm_ipv4_address" {
|
||||||
value = proxmox_virtual_environment_vm.ubuntu_vm.ipv4_addresses[1][0]
|
value = proxmox_virtual_environment_vm.ubuntu_22_minimal_clone.ipv4_addresses[1][0]
|
||||||
}
|
}
|
||||||
@@ -0,0 +1,13 @@
|
|||||||
|
terraform {
|
||||||
|
required_providers {
|
||||||
|
proxmox = {
|
||||||
|
source = "bpg/proxmox"
|
||||||
|
version = "0.106.0"
|
||||||
|
#url = https://registry.terraform.io/providers/bpg/proxmox/latest/docs/guides/clone-vm
|
||||||
|
}
|
||||||
|
aws = {
|
||||||
|
source = "hashicorp/aws"
|
||||||
|
version = "6.38.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -16,7 +16,7 @@ variable "instance_configs" {
|
|||||||
default = [
|
default = [
|
||||||
{ crispy_name = "snap", vmid = "9002" },
|
{ crispy_name = "snap", vmid = "9002" },
|
||||||
{ crispy_name = "crackle", vmid = "9000" },
|
{ crispy_name = "crackle", vmid = "9000" },
|
||||||
{ crispy_name = "pop", vmid = "9001" }
|
{ crispy_name = "pop", vmid = "900" }
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -6,5 +6,5 @@
|
|||||||
- "terraform"
|
- "terraform"
|
||||||
- "docker"
|
- "docker"
|
||||||
- "n8n"
|
- "n8n"
|
||||||
- "ip-192-168-10-117"
|
- "ip-192-168-10-107"
|
||||||
"vm_name": "n8n-01"
|
"vm_name": "n8n-01"
|
||||||
|
|||||||
Reference in New Issue
Block a user