首页 » 软件开发 » 端到端Java DevOps自动化项目-第1部分(容器运行访问设置命令)

端到端Java DevOps自动化项目-第1部分(容器运行访问设置命令)

乖囧猫 2024-07-25 04:09:47 0

扫一扫用手机浏览

文章目录 [+]

译自 Part-1 End-to-End Java DevOps Automation Project,作者 Naveen Kumar。

我们将从设置基础设施、配置服务器和设置基本工具开始。
接下来,我们将创建一个 Kubernetes 集群和一个用于源代码的私有仓库。
在继续的过程中,我们将推送源代码、编写 Jenkins 流水线并实施强大的监控系统来跟踪应用程序的性能。

我们将把这个项目分成四个部分:

端到端Java DevOps自动化项目-第1部分(容器运行访问设置命令) 软件开发
(图片来自网络侵删)

在第一部分中,我们将通过设置必要的基础设施和工具为我们的 CI/CD 流水线奠定基础。
这包括:

设置基础设施和工具: 我们将设置服务器、配置它们并安装必要的工具,为我们的 CI/CD 流水线创建坚实的基础。
创建 Kubernetes 集群: 学习如何创建和配置 Kubernetes 集群来管理我们的容器化应用程序。
设置 Jenkins、Nexus 和 SonarQube 服务器: 我们将安装和配置 Jenkins 用于自动化,Nexus 用于工件管理,SonarQube 用于代码质量分析。
第2部分:源代码管理

第二部分侧重于管理我们的源代码,包括:

创建私有 Git 仓库: 设置一个 Git 仓库来安全地存储我们的源代码,确保没有未经授权的访问。
推送源代码: 将源代码推送到仓库并验证其可见性和可访问性。
第3部分:CI/CD 流水线配置

在第三部分中,我们将配置我们的 CI/CD 流水线,其中包括:

构建 Jenkins 流水线: 使用 Jenkins,我们将编写一个流水线,其中包括源代码编译、运行单元测试和使用 SonarQube 进行代码质量检查等阶段。
安全扫描: 使用 Trivy 等工具对源代码和依赖项实施漏洞扫描。
工件管理: 打包应用程序、生成工件并将它们发布到 Nexus 仓库以进行版本控制。
容器化: 构建 Docker 镜像,适当地标记它们并将它们推送到 Docker Hub。
Kubernetes 部署: 将应用程序部署到安全的 Kubernetes 集群,使用 kube-audit 等工具确保集群的安全性。
第 4 部分:监控和安全

最后部分涉及设置全面的监控和安全检查,包括:

监控和通知: 使用 Grafana 和 Prometheus 设置监控,包括使用 node exporter 进行系统级监控和使用 blackbox exporter 进行应用程序级监控。
我们还将配置电子邮件通知以告知流水线成功或失败。

通过遵循这四个部分,我们将构建一个强大且安全的 Jenkins 流水线,能够高效地部署 Java 应用程序。

到本文结束时,您将拥有一个功能齐全的 Jenkins 流水线,能够将 Java 应用程序从代码提交部署到生产环境,并包含全面的监控和安全实践。
无论您是开发人员还是 DevOps 工程师,本指南都将为您提供实施强大的 CI/CD 流水线和简化部署流程的知识。

加入我,踏上掌握使用 Jenkins 自动化 Java 应用程序部署的艺术之旅。
让我们开始吧!

1. 设置基础设施和工具:

对于这个项目,我们将使用默认 VPC。
在企业环境中,我们通常在私有 VPC 中设置所有内容以增强安全性。
第一步是创建一个安全组,我们将将其附加到我们创建的每个实例。

以下是名为 devops-automation-primary-sg 的安全组的 入站规则 的详细信息。

我们将创建 7 个 EC2 实例,使用以下配置运行 Ubuntu Server 20.04:

实例类型: t3.xlarge安全组: primary-SG卷: 1 个卷 (gp3) — 30 GiB

这些实例将相应地命名:

masterslave-1slave-2jenkinssonarqubenexusmonitoring

注意: 您也可以选择使用 Ubuntu Server 20.04 的 t3.medium 实例。
我在使用 t3.medium 时遇到了错误,因此我选择了 t3.xlarge,这会产生更高的成本。
您也可以通过根据 YUM 兼容性替换命令来尝试使用 Linux 服务器。
如果您遇到错误,解决它们将增强您的信心。

2. 创建 Kubernetes 集群:

我建议使用 MobaXterm 或 MTPuTTY 通过 SSH 登录服务器。

在主节点和工作节点上运行的命令

sudo su -sudo apt-get updatesudo apt install docker.io -ysudo chmod 666 /var/run/docker.socksudo apt-get install -y apt-transport-https ca-certificates curl gnupgsudo mkdir -p -m 755 /etc/apt/keyringscurl -fsSL https://pkgs.k8s.io/core:/stable:/v1.28/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpgecho 'deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.28/deb/ /' | sudo tee /etc/apt/sources.list.d/kubernetes.listsudo apt updatesudo apt install -y kubeadm=1.28.1-1.1 kubelet=1.28.1-1.1 kubectl=1.28.1-1.1

仅在主节点上运行的命令

sudo su -# Run the output of the following command on the worker node to join it to the clustersudo kubeadm init --pod-network-cidr=10.244.0.0/16mkdir -p $HOME/.kubesudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/configsudo chown $(id -u):$(id -g) $HOME/.kube/configkubectl apply -f https://docs.projectcalico.org/manifests/calico.yamlkubectl apply -f https://raw.githubusercontent.com/kubernetes/ingress-nginx/controller-v0.49.0/deploy/static/provider/baremetal/deploy.yaml

如果您忘记加入工作节点,您可以使用以下命令检索令牌并在工作节点上运行它:

kubeadm token create --print-join-command

现在我们的 k8 集群已准备就绪,您可以执行 kubectl 命令

主节点上的 K8s 集群扫描

要扫描 Kubernetes 集群,请在主节点上运行以下命令。
请注意,由于我们尚未设置 RBAC 等所有内容,因此它将显示许多错误。
输出可供基础设施团队使用。

wget https://github.com/Shopify/kubeaudit/releases/download/v0.22.1/kubeaudit_0.22.1_linux_amd64.tar.gztar -xvzf kubeaudit_0.22.1_linux_amd64.tar.gzsudo mv kubeaudit /usr/local/bin/kubeaudit all3. 设置 Jenkins

安装 Jenkins 脚本

将以下脚本保存在一个文件中,例如 install_jenkins.sh:

#!/bin/bash# Install OpenJDK 17 JRE Headless (pre-requisite)sudo apt install openjdk-17-jre-headless -y# Download Jenkins GPG key (official code link - https://www.jenkins.io/doc/book/installing/linux/#debianubuntu)sudo wget -O /usr/share/keyrings/jenkins-keyring.asc https://pkg.jenkins.io/debian-stable/jenkins.io-2023.key# Add Jenkins repository to package manager sourcesecho deb [signed-by=/usr/share/keyrings/jenkins-keyring.asc] https://pkg.jenkins.io/debian-stable binary/ | sudo tee /etc/apt/sources.list.d/jenkins.list > /dev/null# Update package manager repositoriessudo apt-get update# Install Jenkinssudo apt-get install jenkins -y

使脚本可执行并运行它:

chmod +x install_jenkins.sh./install_jenkins.sh

此脚本将自动执行 OpenJDK 17 JRE Headless 和 Jenkins 的安装过程。

安装 Docker 脚本

将以下脚本保存在一个文件中,例如 install_docker.sh:

#!/bin/bash# Update package manager repositoriessudo apt-get update# Install necessary dependenciessudo apt-get install -y ca-certificates curl# Create directory for Docker GPG keysudo install -m 0755 -d /etc/apt/keyrings# Download Docker's GPG keysudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc# Ensure proper permissions for the keysudo chmod a+r /etc/apt/keyrings/docker.asc# Add Docker repository to Apt sourcesecho "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null# Update package manager repositoriessudo apt-get update# Install Docker packagessudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

使脚本可执行并运行它:

chmod +x install_docker.sh./install_docker.sh

授予其他用户运行 Docker 命令的权限:

sudo chmod 666 /var/run/docker.sock

运行这些命令后,Jenkins 将在您的主机上的 http://IP:8080. 可访问。

4. 设置 Nexus

步骤 1:安装 Docker

首先,我们需要安装 Docker。
将以下脚本保存在名为 install_docker.sh 的文件中:

#!/bin/bash# Update package manager repositoriessudo apt-get update# Install necessary dependenciessudo apt-get install -y ca-certificates curl# Create directory for Docker GPG keysudo install -m 0755 -d /etc/apt/keyrings# Download Docker's GPG keysudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc# Ensure proper permissions for the keysudo chmod a+r /etc/apt/keyrings/docker.asc# Add Docker repository to Apt sourcesecho "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \$(. /etc/os-release && echo "$VERSION_CODENAME") stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null# Update package manager repositories againsudo apt-get update# Install Docker packagessudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

使脚本可执行并运行它:

chmod +x install_docker.sh./install_docker.sh

授予其他用户运行 Docker 命令的权限:

sudo chmod 666 /var/run/docker.sock

步骤 2:创建 Nexus Docker 容器

要创建一个运行 Nexus 3 并将其暴露在端口 8081 上的 Docker 容器,请使用以下命令:

docker run -d --name nexus -p 8081:8081 sonatype/nexus3:latest

此命令执行以下操作:

-d: 分离容器并在后台运行。
--name nexus: 将容器命名为“nexus”。
-p 8081:8081: 将主机上的端口 8081 映射到容器上的端口 8081,允许通过端口 8081 访问 Nexus。
sonatype/nexus3:latest: 使用 Sonatype 存储库中的最新版本的 Nexus 3。

运行此命令后,您可以在主机上的 http://<your_IP>:8081 访问 Nexus。

步骤 3:检索 Nexus 初始密码

要访问存储在容器中的 Nexus 初始管理员密码,请按照以下步骤操作:

获取容器 ID: 列出所有正在运行的容器以查找 Nexus 容器的 ID。

docker ps访问容器的 Bash Shell: 执行以下命令以访问容器的 bash shell:

docker exec -it <container_ID> /bin/bash

将 <container_ID> 替换为 Nexus 容器的实际 ID。

导航到 Nexus 目录: 在容器的 bash shell 中,导航到 Nexus 存储其配置的目录:

cd sonatype-work/nexus3查看管理员密码: 显示 admin.password 文件的内容以查看管理员密码:

cat admin.password退出容器 Shell: 检索到密码后,退出容器的 bash shell:

exit

此过程允许您访问存储在容器中的 Nexus 管理员密码。
确保将此密码保密,因为它授予您对 Nexus 实例的管理访问权限。

注意:在 Nexus 中设置密码时 - 允许匿名访问

用例示例:

示例场景

假设您有一个开源项目的文档服务器。
您希望让每个人都能访问项目的文档,而无需用户创建帐户。
以下是如何配置它:

访问:启用匿名访问。
用户名:设置为“anonymous”。
领域:设置为“本地授权领域”以定义匿名用户操作的上下文。

此设置确保任何人都可以访问文档,而无需进行身份验证,从而使信息广泛可用且易于访问。

通过仔细考虑用例并适当地配置设置,您可以利用匿名访问来提高可访问性,同时保持对敏感资源的安全性和控制。

5. 设置 SonarQube

步骤 1:安装 Docker

首先,我们需要安装 Docker。
将以下脚本保存在名为 install_docker.sh 的文件中:

#!/bin/bash# Update package manager repositoriessudo apt-get update# Install necessary dependenciessudo apt-get install -y ca-certificates curl# Create directory for Docker GPG keysudo install -m 0755 -d /etc/apt/keyrings# Download Docker's GPG keysudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc# Ensure proper permissions for the keysudo chmod a+r /etc/apt/keyrings/docker.asc# Add Docker repository to Apt sourcesecho "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \$(. /etc/os-release && echo \"$VERSION_CODENAME\") stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null# Update package manager repositories againsudo apt-get update# Install Docker packagessudo apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin

使脚本可执行并运行它:

chmod +x install_docker.sh./install_docker.sh

授予其他用户运行 Docker 命令的权限:

sudo chmod 666 /var/run/docker.sock

步骤 2:创建 SonarQube Docker 容器

要在 Docker 容器中运行 SonarQube,请使用以下命令:

docker run -d --name sonar -p 9000:9000 sonarqube:lts-community

此命令执行以下操作:

-d: 分离容器并在后台运行。
--name sonar: 将容器命名为“sonar”。
-p 9000:9000: 将主机上的端口 9000 映射到容器上的端口 9000,允许通过端口 9000 访问 SonarQube。
sonarqube:lts-community: 使用 Docker Hub 中的 SonarQube 的长期支持 (LTS) 社区版。

运行此命令后,您可以在主机上的 http://<your_VM_IP>:9000 访问 SonarQube。

步骤 3:访问 SonarQube

要访问 SonarQube,请打开 Web 浏览器并导航到 http://<your_VM_IP>:9000。

这将启动 SonarQube 服务器,您应该能够使用提供的 URL 访问它。
如果您在远程服务器或其他端口上运行 Docker,请替换 <your_VM_IP>。
使用适当的主机名或 IP 地址,并相应地调整端口。

注意:这是第一部分:基础设施设置的结尾,第二部分将涵盖源代码管理。

标签:

相关文章

语言中的借用,文化交融的桥梁

自古以来,人类社会的交流与发展离不开语言的传播。在漫长的历史长河中,各民族、各地区之间的文化相互碰撞、交融,产生了许多独特的语言现...

软件开发 2025-01-01 阅读1 评论0

机顶盒协议,守护数字生活的新卫士

随着科技的飞速发展,数字家庭逐渐走进千家万户。在这个时代,机顶盒成为了连接我们与丰富多彩的数字世界的重要桥梁。而机顶盒协议,作为保...

软件开发 2025-01-01 阅读1 评论0

语言基础在现代社会的重要性及方法步骤

语言是人类沟通的桥梁,是社会发展的基础。语言基础作为语言学习的基石,对于个人、社会乃至国家的发展具有重要意义。本文将从语言基础在现...

软件开发 2025-01-01 阅读2 评论0

粤语电影,传承文化,点亮时代之光

粤语电影,作为中国电影产业的一朵奇葩,以其独特的地域特色、丰富的文化内涵和鲜明的艺术风格,赢得了广大观众的喜爱。本文将从粤语电影的...

软件开发 2025-01-01 阅读3 评论0

苹果游戏语言,塑造未来娱乐体验的基石

随着科技的飞速发展,游戏产业逐渐成为全球娱乐市场的重要支柱。在我国,游戏产业更是蓬勃发展,吸引了无数玩家和投资者的目光。而在这其中...

软件开发 2025-01-01 阅读1 评论0