【微服务部署】使用Docker-compose部署Jenkins、SonarQube

一、安装

1、编写docker-compose部署Postgres、SonarQube、Jenkins的yml文件jenkins-compose.ymlPostgres:作为SonarQube的数据库存储SonarQube:代码质量检查Jenkins:jenkins/jenkins:lts镜像,jenkinsci/blueocean镜像缺少node运行时环境,导致node无法运行。关键配置说明( 宿主机 : Docker容器):/data/docker/ci/postgresql/data:/var/lib/postgresql/data # Postgres数据存储映射到宿主机目录/etc/localtime:/etc/localtime:ro # docker容器取宿主机的日期,:ro(read-only)表示只读,即docker容器只能读取宿主机的/etc/localtime文件,不能修改。/usr/lib64/libltdl.so.7:/usr/lib/x86_64-linux-gnu/libltdl.so.7 # 在docker容器中运行宿主机docker命令,如果宿主机没有这个文件,可以使用以下命令进行安装。这里将Docker容器的内存设置为10G,因为我们NodeJS打包需要设置的内存为8G。
复制
yum install libtool-ltdl-2.4.2-22.el7_3.x86_641.

jenkins-compose.yml完整内容如下:

复制
version: 3 networks: prodnetwork: driver: bridge services: sonardb: image: postgres:12.2 restart: always ports: - "5433:5432" networks: - prodnetwork volumes: - /data/docker/ci/postgresql:/var/lib/postgresql - /data/docker/ci/postgresql/data:/var/lib/postgresql/data - /etc/localtime:/etc/localtime:ro environment: - POSTGRES_USER=sonar - POSTGRES_PASSWORD=sonar - POSTGRES_DB=sonar - TZ=Asia/Shanghai sonar: image: sonarqube:10.1.0-community restart: always ports: - "19000:9000" - "19092:9092" networks: - prodnetwork depends_on: - sonardb volumes: - /data/docker/ci/sonarqube/conf:/opt/sonarqube/conf - /data/docker/ci/sonarqube/data:/opt/sonarqube/data - /data/docker/ci/sonarqube/logs:/opt/sonarqube/logs - /data/docker/ci/sonarqube/extensions:/opt/sonarqube/extensions - /data/docker/ci/sonarqube/bundled-plugins:/opt/sonarqube/lib/bundled-plugins environment: - TZ=Asia/Shanghai - SONARQUBE_JDBC_URL=jdbc:postgresql://sonardb:5432/sonar - SONARQUBE_JDBC_USERNAME=sonar - SONARQUBE_JDBC_PASSWORD=sonar jenkins: image: jenkins/jenkins:lts user: root privileged: true restart: always ports: - "18080:8080" networks: - prodnetwork volumes: - /usr/bin/docker:/usr/bin/docker - /var/run/docker.sock:/var/run/docker.sock - /etc/docker/daemon.json:/etc/docker/daemon.json - /usr/lib64/libltdl.so.7:/usr/lib/x86_64-linux-gnu/libltdl.so.7 - /etc/localtime:/etc/localtime:ro - $HOME/.ssh:/root/.ssh - /data/docker/ci/jenkins/lib:/var/lib/jenkins/ - /data/docker/ci/jenkins/home:/var/jenkins_home depends_on: - sonar environment: - TZ=Asia/Shanghai - NEXUS_PORT=8081 - SONAR_PORT=9000 - SONAR_DB_PORT=5432 - JAVA_OPTS=-Xms512m -Xmx10240m deploy: resources: limits: cpus: "2.00" memory: 10G reservations: memory: 200M cap_add: - ALL1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.41.42.43.44.45.46.47.48.49.50.51.52.53.54.55.56.57.58.59.60.61.62.63.64.65.66.67.68.69.70.71.72.73.74.75.76.77.

因并不是每个项目都需要自己的Maven私服,所以这里去除了Maven私服Nexus的部署,如果需要,直接在jenkins-compose.yml文件中添加即可:

复制
nexus: image: sonatype/nexus3 restart: always ports: - "18081:8081" networks: - prodnetwork volumes: - /data/docker/ci/nexus:/nexus-data1.2.3.4.5.6.7.8.9.

在Jenkins的depends_on:添加。

复制
depends_on: - nexus - sonar1.2.3.
2、创建宿主机挂载目录并赋权
复制
mkdir -p /data/docker/ci/nexus /data/docker/ci/jenkins/lib /data/docker/ci/jenkins/home /data/docker/ci/sonarqube /data/docker/ci/postgresql /data/docker/ci/postgresql/data chmod -R 777 /data/docker/ci/nexus /data/docker/ci/jenkins/lib /data/docker/ci/jenkins/home /data/docker/ci/sonarqube /data/docker/ci/postgresql /data/docker/ci/postgresql/data1.2.3.
3、在 jenkins-compose.yml 文件所在目录下执行安装启动命令启动命令
复制
docker-compose -f jenkins-compose.yml up -d1.
停止命令
复制
docker-compose -f jenkins-compose.yml down1.
重新创建某一个容器命令
复制
docker-compose -f jenkins-compose.yml up --force-recreate --no-deps 服务名称1.
查看容器运行情况
复制
[root@root server]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES b28f1878ee08 jenkins/jenkins:lts "/sbin/tini -- /usr/…" 20 hours ago Up 19 hours 50000/tcp, 0.0.0.0:18080->8080/tcp docker-jenkins-1 cff7c0d88150 sonarqube:10.1.0-community "/opt/sonarqube/dock…" 20 hours ago Up 20 hours 0.0.0.0:19000->9000/tcp, 0.0.0.0:19092->9092/tcp docker-sonar-1 90dacc85efb1 postgres:12.2 "docker-entrypoint.s…" 20 hours ago Up 20 hours 0.0.0.0:5433->5432/tcp docker-sonardb-11.2.3.4.5.
查看某一容器的运行日志 docker logs -f 容器id
复制
[root@root server]# docker logs -f b28f1878ee081.
重启某一容器 docker restart 容器id
复制
[root@root server]# docker restart b28f1878ee081.
4、通过界面访问Jenkins,通过提示的路径找到初始密码并输入,然后进行下一步

复制
[root@ZvRiIw4706 docker]# cd /data/docker/ci/jenkins/home/secrets [root@ZvRiIw4706 secrets]# ls filepath-filters.d initialAdminPassword jenkins.model.Jenkins.crumbSalt master.key org.jenkinsci.main.modules.instance_identity.InstanceIdentity.KEY slave-to-master-security-kill-switch whitelisted-callables.d [root@ZvRiIw4706 secrets]# cat initialAdminPassword1.2.3.4.
5、选择安装推荐插件即可

6、插件安装中

7、部分插件安装失败,根据后台日志可知,部分插件因为jenkins版本太低,所以不能安装,这里先进行下一步,在系统中升级jenkins版本之后,再继续安装插件。(jenkins/jenkins:lts镜像里面集成的不是最新的jenkins,但在下载插件时,是下载的最新的插件,导致不兼容,所以无法下载)

报错日志:

复制
2023-08-09 07:44:36.664+0000 [id=72] INFO h.m.UpdateCenter$UpdateCenterConfiguration#download: Downloading github-branch-source 2023-08-09 07:44:36.685+0000 [id=72] SEVERE h.model.UpdateCenter$DownloadJob#run: Failed to install github-branch-source java.io.IOException: Failed to load: GitHub Branch Source Plugin (1696.v3a_7603564d04) - Failed to load: GitHub plugin (1.34.5) - Jenkins (2.346.1) or higher required at hudson.PluginWrapper.resolvePluginDependencies(PluginWrapper.java:1016) at hudson.PluginManager.dynamicLoad(PluginManager.java:917) Caused: java.io.IOException: Failed to install github-branch-source plugin at hudson.PluginManager.dynamicLoad(PluginManager.java:930) at hudson.model.UpdateCenter$InstallationJob._run(UpdateCenter.java:2179) Caused: java.io.IOException: Failed to dynamically deploy this plugin at hudson.model.UpdateCenter$InstallationJob._run(UpdateCenter.java:2183) at hudson.model.UpdateCenter$DownloadJob.run(UpdateCenter.java:1846) at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:515) at java.base/java.util.concurrent.FutureTask.run(FutureTask.java:264) at hudson.remoting.AtmostOneThreadExecutor$Worker.run(AtmostOneThreadExecutor.java:121) at java.base/java.lang.Thread.run(Thread.java:829)1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.

二、配置

1、登录到Jenkins之后,首先进入系统管理然后升级Jenkins版本

2、然后安装所需插件,系统管理 > 插件管理Blue Ocean :Jenkins Pipeline设计的一个聚合工具,图形化Pipeline的流程,使流水线更加直观。SonarQube Scanner for Jenkins:代码质量扫描工具,Jenkins扫描代码后将结果发送到SonarQube Server。NodeJS Plugin :打包NodeJs项目时,需要的插件,用于运行NodeJs环境。Maven Integration plugin:Maven工程打包插件。Publish Over SSH:将打包后的文件,发送到远程服务器。3、系统管理 > 系统配置Maven参数配置,此处根据自己服务器的配置情况配置。

复制
-Xms256m -Xmx512m -XX:MaxPermSize=128m -XX:ReservedCodeCacheSize=64m1.
SonarQube servers配置,此处配置我们使用docker-compose部署的SonarQube,Server authentication token必填,这个在后续步骤会说明如何从SonarQube获取生成token。

Publish over SSH配置,这里配置我们需要部署到的服务器,可以部署多个。点击下侧的“高级”,填写服务器密码和端口。

4、系统管理 > 全局工具配置,这里主要安装一些所需插件需要的软件环境,jenkins/jenkins:lts镜像默认装有openjdk和git,如果没有特殊要求,我们可以不安装,我们在这里安装SonarQube Scanner、Maven、NodeJS。SonarQube Scanner安装

Maven安装,最好自己下载后上传到服务器,因为使用服务器下载安装很慢。

Maven全局配置,配置Maven的配置文件

修改Maven全局配置中配置文件里面的jar包存储路径,否则不同任务构建都会重新下载jar包。

NodeJS安装,选择自己所需要的版本,同时如果有其他工具包可以在下方填写,比如我们使用的是pnpm,使用的镜像源是https://registry.npm.taobao.org ,可以在下方填写:
复制
pnpm -registry=https://registry.npm.taobao.org1.

阅读剩余
THE END