Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/aahad91/git-jenk-dock
Docker-based solution for GitLab and Jenkins
https://github.com/aahad91/git-jenk-dock
docker docker-compose gitlab gitlab-ci gitlab-runner integration jenkins jenkins-ci owasp-dependencycheck postgresql sonarqube
Last synced: 28 days ago
JSON representation
Docker-based solution for GitLab and Jenkins
- Host: GitHub
- URL: https://github.com/aahad91/git-jenk-dock
- Owner: aahad91
- License: apache-2.0
- Created: 2020-05-20T12:29:39.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2020-11-24T21:06:17.000Z (about 4 years ago)
- Last Synced: 2024-11-22T21:13:48.331Z (3 months ago)
- Topics: docker, docker-compose, gitlab, gitlab-ci, gitlab-runner, integration, jenkins, jenkins-ci, owasp-dependencycheck, postgresql, sonarqube
- Language: Python
- Homepage:
- Size: 19.6 MB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/e14c6/e14c68f9d0f93e4547b673e18a5cd59cfebc6b71" alt="Docker-compose CI"
# git-jenk-dock
## Docker-based solution for GitLab, GitLab Runner, Jenkins and SonarQube### Documentation for Installation, Integration, Plugins Installation and Pipeline Testing
#### Requirement
- Docker (Installed)
- Docker-compose (Installed)### Installation
```bash
#For Ubuntu to resolve virtual memory issue of Sonarqube
sudo sysctl -w vm.max_map_count=262144sudo docker-compose -f docker-compose.yaml up
#New terminal
sudo docker exec -it -u root jenkins chmod 777 /var/run/docker.sock
```#### URLs
Browse to following Urls to verify successful installation of Gitlab, Jenkins and SonarQube.
- **Gitlab:** http://localhost:8081
- **Login:**
- **Password:**
- **Jenkins:** http://localhost:8095
- **Login:**
- **Password:**
- **SonarQube:** http://localhost:9000
- **Login:** admin
- **Password:** admin#### Gitlab Configuration
- After browsing to above mentioned url of gitlab, initial registration page will show up. Set the new password for root user of Gitlab.
data:image/s3,"s3://crabby-images/f151c/f151c356f7561df78b8ece64a31d322843f14507" alt="root-password-set"
- Login with the newly created password
data:image/s3,"s3://crabby-images/c3d09/c3d0930bc761b3eaf2c153829daba5ed09fd9069" alt="root-login"
- Gitlab Homepage
data:image/s3,"s3://crabby-images/59b76/59b76564862cc463fc5f55c3d799af44e6fd656a" alt="git-home"
### Gitlab Runner Integration
#### Gitlab
- Navigate to ***Admin Area*** > ***Runners*** and copy the ***Registration Token***.
data:image/s3,"s3://crabby-images/5f205/5f2057c13dbdbdf406b59e36306d576f084d5322" alt="gitlab-runner1"
#### Gitlab Runner
```bash
# Command to register runner with gitlab
gitlab-runner register -n --url http://:80/ --registration-token {token from gitlab} --clone-url http://:80/ --executor docker --docker-image "docker:latest" --docker-privileged# Execute
sudo docker exec -it gitlab-runner gitlab-runner register -n --url http://192.168.0.105:8081/ --registration-token m4zgS3wQuiPLusTHbzD1 --clone-url http://192.168.0.105:8081/ --executor docker --docker-image "docker:latest" --docker-privileged
```- Verify the added runner.
data:image/s3,"s3://crabby-images/a883c/a883cbc19eadd19636094e089a59f8305e9afa5d" alt="gitlab-runner2"
#### Jenkins Configuration
- Browse to above mentioned url of jenkins and get the Administrator password from the mentioned path:
```bash
sudo docker exec -it jenkins cat /var/jenkins_home/secrets/initialAdminPassword
```data:image/s3,"s3://crabby-images/1d2cc/1d2cccf09a8e4c6f1b48842b0d58e4b4e7ff103f" alt="jenkins-conf"
- Select the "Select plugins to Install", search and enable gitlab, afterwards click on the Install.
data:image/s3,"s3://crabby-images/5d790/5d790d3516af317cac027c9c86484382eb0f12c3" alt="jenkins-plugins"
- Wait till all the plugins are installed.
data:image/s3,"s3://crabby-images/ab17d/ab17d39cc8df385197e64e1aee3fa007b334610a" alt="plugins-install"
- Set Admin user and password.
data:image/s3,"s3://crabby-images/3292a/3292abcbc7ffffa39de87be83429a6c101884317" alt="user-create"
- Set the default url for jenkins for 3rd party access. For-example integration with gitlab and email configuration.
data:image/s3,"s3://crabby-images/0a29e/0a29e976066b7fdc7981e70d4559d45f07df54e3" alt="instance-conf"
- All set!
data:image/s3,"s3://crabby-images/4ba09/4ba09f76d5c1e1f0cd6b70433c767074de221831" alt="jenkins-installed"
- Jenkins Homepage
data:image/s3,"s3://crabby-images/b441f/b441f030182d31ea41997477c4a78b46f35eb5a1" alt="jenkins-homepage"
#### Installing required plugins for Jenkins
- OWASP Dependency-Check
- Docker
- Docker pipeline
- Navigate to **_Manage Jenkins_** > **_Manage Plugins_**. Click on ***Available*** tab and search for OWASP Dependency-Check and Docker afterwards click on Download now and install after restart.data:image/s3,"s3://crabby-images/8fdd6/8fdd6af327044295bfbf93458522880b776c2387" alt=""
data:image/s3,"s3://crabby-images/c1bba/c1bba357171fde8c1178560ee5df4b1e4f304057" alt=""
- Verify the successfull installation of OWASP Dependency-Check plugin by navigating to **_Manage Jenkins_** > **_Manage Plugins_** and click on ***installed*** tab.
data:image/s3,"s3://crabby-images/26917/26917aab97779999a8b911429970a9c83cc172e0" alt=""
### Integration of Gitlab and Jenkins
#### Gitlab
- Generate authentication token. *Navigate to **Settings** > **Access Token***. Do as follow:
data:image/s3,"s3://crabby-images/0f990/0f990c711eea095abe71e7dbe5025412a3a75ffc" alt="git-token"
#### Jenkins
- Add connection to Gitlab from jenkins. *Navigate to **Manage Jenkins** > **Configure System***. Search for Gitlab tab. Add Name, Url of gitlab, token and test the connection as follow.
data:image/s3,"s3://crabby-images/26673/266739ce569f0c873433e3c887c204ffe17d2aae" alt="add-conn"
data:image/s3,"s3://crabby-images/6e6ff/6e6ffe318e43490ffea6ffc77b27b7b78badb0d5" alt="add-token"
### SonarQube
- Browse ot Url http://localhost:9000
data:image/s3,"s3://crabby-images/af0db/af0db3f2af1dd0c303629beac610901d73cd3080" alt=""
- Click on login and enter the credentials for the first login and later can be changed to desired password:
- Username: admin
- Password: admindata:image/s3,"s3://crabby-images/567c1/567c10ad30bfc5482cb154b95cabe72d2c4b067f" alt=""
data:image/s3,"s3://crabby-images/72814/72814728692744e98a1e9cd9aa087365dd54c560" alt=""
#### Installing OWASP Dependency Checker for SonarQube
- Click on ***Administration*** -> ***Marketplace***. Type dependency-check in search bar and click install.
data:image/s3,"s3://crabby-images/f7a50/f7a5038502427a48616ad183543020089a304d38" alt=""
- Click on ***Restart Server*** on the top to proceed the installation.
data:image/s3,"s3://crabby-images/70a32/70a3275b717d78ff33d13fa13aa9ee4413f2909e" alt=""
- Verify the successfull installation of OWASP Dependency Checker plugin. Navigate to ***Administration*** > ***Marketplace***, and click on Plugins installed.
data:image/s3,"s3://crabby-images/9736d/9736d2fbb6997ba100e69c9c452cc5e1e1d8367f" alt=""
### Test Pipeline
#### Gitlab
- Click on **Create a project** and select **Import Project**, after that copy and paste the repo: **https://github.com/aahad91/maven.git**. Set project to public and finally click on Create project.
data:image/s3,"s3://crabby-images/50864/50864e98e9391c5b96f2e5a4bd555fd633493c66" alt=""
data:image/s3,"s3://crabby-images/882f8/882f8cbc307b5de17ef9914994e2b3e87876b01e" alt="repo-2"
#### Jenkins
##### Pipeline
- From Home page click on "New Item". Add the name for pipeline and select pipeline.
data:image/s3,"s3://crabby-images/3b480/3b480e329698490ad9cd26a7e4829d76d7ffbb02" alt="create-pipeline"
- Under Build Triggers section, select "Build when a change is pushed to GitLab. GitLab webhook URL: http://192.168.0.105:8095/project/maven-dependency-check".
data:image/s3,"s3://crabby-images/026ff/026ffc35a3429e4fac665e33a7e53fa5ada0c3e1" alt=""
- In pipeline section, select "Pipeline script from SCM" and set SCM to "Git". Afterwards add URL of the git repo.
data:image/s3,"s3://crabby-images/ec276/ec2769c9e55d11a7461c2512c460cc80aee81878" alt="pipeline-config"
- Click on Build now to test the pipeline.
data:image/s3,"s3://crabby-images/e3a31/e3a316c235fba6ce0ec572e1cf93c3f96a1eafbd" alt="run-pipeline"
- Verfiy the pipeline is executed successfully.
data:image/s3,"s3://crabby-images/3ac04/3ac04c6f469cb292083b6f5f7ed96110f8fd3e4b" alt=""
data:image/s3,"s3://crabby-images/10f47/10f47540ee8572b79a417e0b0f32467dcde19b59" alt=""
##### Dependency check
- Configure the OWASP dependency check. Navigate to ***Manage Jenkins > Global Tool Configuration***. In Dependency-Check section, click on **Add Dependency-Check**. Set the name and click save.
data:image/s3,"s3://crabby-images/7df8c/7df8cab41443d8b5149419f2a7dd53e511a9d3d3" alt=""
- From Home page click on "New Item". Add the name and select freestyle project.
data:image/s3,"s3://crabby-images/1bdac/1bdacaa87085474ad07bbeb18a4ad9dab0226bf8" alt=""
- In settings, under Source Code Management section. Add the repository Url.
data:image/s3,"s3://crabby-images/14a74/14a74fa94c906b9ff9b2c74274c9f91a07938ee1" alt=""
- Under Build Triggers section, select "Build when a change is pushed to GitLab. GitLab webhook URL: http://192.168.0.105:8095/project/maven-dependency-check"
data:image/s3,"s3://crabby-images/6580b/6580bb9a00c811d705bd9b4b06d237426513456c" alt=""
- Under Build section select **Invoke Dependency-Check** and under Post-build Actions select **Publish Dependency-Check results**. For build section, in Arguments add the following and click on save:
- --format XML
- --format HTMLdata:image/s3,"s3://crabby-images/5ee3d/5ee3d2e70efc06ff211843e344e2c8d83cd98a1b" alt=""
- Click on **Build Now** to see the results.
data:image/s3,"s3://crabby-images/8ac23/8ac2350a6c3bea0b3a36a4e3158c7b4ac575c1e1" alt=""
data:image/s3,"s3://crabby-images/1a1d7/1a1d7f427cd8082c5c08ea7d37e1b3d4e99cba0f" alt=""
##### Gitlab webhook for automatically triggering Jenkins pipeline and OWASP Dependency-Check
data:image/s3,"s3://crabby-images/1ffc3/1ffc3b804c6648d3df859964aa3329322ec93b12" alt=""
#### Gitlab Runner and SonarQube
##### SonarQube
- From the main page click on **Create new project**. Add the **Project-key** and click on Set Up.
data:image/s3,"s3://crabby-images/57600/5760051ac7e3537c75719730bf1e5ee011a908f5" alt=""
- Provide the name for the Key and click on Generate. Copy the token.
data:image/s3,"s3://crabby-images/b7d93/b7d93446e407d62e470056495d04e748d962beb7" alt=""
##### Gitlab
- Edit the **.gitlab-ci.yml**. Add the token and SonarQube Url then Commit.
data:image/s3,"s3://crabby-images/42bae/42baedfb76379a0b298174f51de5b0fe7915cb48" alt=""
- Navigate to ***CI/CD > Pipelines***. To verify the Gitlab Runner pipeline.
data:image/s3,"s3://crabby-images/f77ba/f77ba9db91457c7b4d2af36d809b27c9913e461a" alt=""
data:image/s3,"s3://crabby-images/acea5/acea55153d2a88e716952b7b6278410e60c518f6" alt=""
##### SonarQube
- Verify the analysis on SonarQube.
data:image/s3,"s3://crabby-images/3ff2b/3ff2b9fc2ccfe68f091e838382693144a033ff43" alt=""
------