# Clear Linux* OS `cgit` container image ## What is this image? `clearlinux/cgit` is a Docker image with `cgit` running on top of the [official clearlinux base image](https://hub.docker.com/_/clearlinux). > [Cgit](https://git.zx2c4.com/cgit/) is a hyperfast web frontend for git repositories written in C. For other Clear Linux* OS based container images, see: https://hub.docker.com/u/clearlinux ## Why use a clearlinux based image? > [Clear Linux* OS](https://clearlinux.org/) is an open source, rolling release > Linux distribution optimized for performance and security, from the Cloud to > the Edge, designed for customization, and manageability. Clear Linux* OS based container images use: * Optimized libraries that are compiled with latest compiler versions and flags. * Software packages that follow upstream source closely and update frequently. * An aggressive security model and best practices for CVE patching. * A multi-staged build approach to keep a reduced container image size. * The same container syntax as the official images to make getting started easy. To learn more about Clear Linux* OS, visit: https://clearlinux.org. ## Deployment: ### Deploy with Docker The easiest way to get started with this image is by simply pulling it from Docker Hub. 1. Pull the image from Docker Hub: ``` docker pull clearlinux/cgit ``` 2. Start a container using the examples below: ``` docker run -p 80:80 -v :/var/www/cgit clearlinux/cgit ``` ### Deploy with Kubernetes ## Build and modify: The Dockerfiles for all Clear Linux* OS based container images are available at https://github.com/clearlinux/dockerfiles. These can be used to build and modify the container images. 1. Clone the clearlinux/dockerfiles repository. ``` git clone https://github.com/clearlinux/dockerfiles.git ``` 2. Change to the directory of the application: ``` cd cgit/ ``` 3. Build the container image: ``` docker build -t clearlinux/cgit . ``` Refer to the Docker documentation for [default build arguments](https://docs.docker.com/engine/reference/builder/#arg). Additionally: - `swupd_args` - specifies arguments to pass to the Clear Linux* OS software manager. See the [swupd man pages](https://github.com/clearlinux/swupd-client/blob/master/docs/swupd.1.rst#options) for more information. ## Licenses All licenses for the Clear Linux* Project and distributed software can be found at https://clearlinux.org/terms-and-policies