Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alilotfi23/aptlyserved
Ansible-powered solution designed to streamline the deployment and management of a local APT repository served through Nginx
https://github.com/alilotfi23/aptlyserved
ansible ansible-playbook ansible-role apt debian jinja2 nginx ubuntu
Last synced: about 2 months ago
JSON representation
Ansible-powered solution designed to streamline the deployment and management of a local APT repository served through Nginx
- Host: GitHub
- URL: https://github.com/alilotfi23/aptlyserved
- Owner: alilotfi23
- License: mit
- Created: 2024-07-19T08:16:26.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-08-20T12:09:40.000Z (5 months ago)
- Last Synced: 2024-10-20T12:29:48.503Z (3 months ago)
- Topics: ansible, ansible-playbook, ansible-role, apt, debian, jinja2, nginx, ubuntu
- Language: Jinja
- Homepage:
- Size: 9.77 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# AptlyServed
AptlyServed is an Ansible-powered solution designed to streamline the deployment and management of a local APT repository that is served through Nginx. This project encapsulates best practices and modular design, making deploying and managing Debian package repositories on your network easy.
## Features
- **Automatic Installation:** Sets up and configures Nginx to serve your APT repository.
- **Easy Package Management:** Easily add or update Debian packages within your repository.
- **Modular Design:** Utilizes Ansible roles to separate concerns.
- **Scalable:** Suitable for everything from small labs to large enterprise environments.## Requirements
- An Ubuntu Server (18.04 or newer)
- Ansible 2.9 or higher
- SSH access to the target server
- Sudo privileges on the server## Getting Started
### Installation
1. **Clone the Repository:**
```bash
git clone https://github.com/alilotfi23/AptlyServed.git
cd AptlyServed
```2. **Set Up Inventory:**
Edit the `inventory` file to include the IP addresses of the servers where you want to deploy the repository.3. **Configure Variables:**
Open the `vars/main.yml` to set up necessary configurations like repository directory, server name, etc.4. **Run the Playbook:**
```bash
ansible-playbook -i inventory setup_repo.yml
```### Directory Structure
```
.
AptlyServed/
├── ansible.cfg # Ansible configuration file
├── inventory # Inventory file defining hosts and groups
├── setup_repo.yml # Main Ansible playbook
├── roles/
│ ├── base_setup/
│ │ └── tasks/
│ │ └── main.yml # Tasks for basic server setup
│ ├── nginx/
│ │ ├── tasks/
│ │ │ └── main.yml # Tasks for installing and configuring Nginx
│ │ ├── handlers/
│ │ │ └── main.yml # Handlers for reloading Nginx
│ │ └── templates/
│ │ └── repo.conf.j2 # Jinja2 template for Nginx configuration
│ └── repository/
│ ├── tasks/
│ │ └── main.yml # Tasks for setting up the repository
│ └── handlers/
│ └── main.yml # Handlers for repository actions
└── vars/
└── main.yml # Variables used across the roles```
### Usage
After deployment, your APT repository will be accessible via the configured domain or IP address. You can add `.deb` files to your repository and run the playbook to update the metadata automatically.
## Contributing
Contributions are what make the open-source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**.
1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request