Kubernetes 上安装 Jenkins

  1. 安装 Helm
bash 复制代码
curl https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | bash
  1. 添加 Jenkins Helm 仓库
    首先添加 Jenkins Helm 仓库
bash 复制代码
helm repo add jenkins https://charts.jenkins.io
helm repo update
  1. 安装 Jenkins
    使用 Helm 安装 Jenkins 的最新版本:
bash 复制代码
helm install jenkins jenkins/jenkins

这将会使用 Helm Chart 安装 Jenkins,并且会自动创建一个 jenkins 的部署、服务和相关资源。

  1. 查看 Jenkins 的服务
    你可以使用以下命令查看 Jenkins 的服务和端口:
bash 复制代码
kubectl get svc
  1. 获取 Jenkins 的 初始管理员密码

Jenkins Helm Chart 在安装时会创建一个 Secret,其中包含 Jenkins 的初始管理员密码。你可以通过以下命令获取密码:

bash 复制代码
kubectl exec --stdin --tty <jenkins-pod-name> -- cat /var/jenkins_home/secrets/initialAdminPassword

将 替换为 Jenkins Pod 的名称。你可以使用 kubectl get pods 查看 Jenkins Pod 的名称。

  1. 访问 Jenkins
    根据服务类型不同,你可以通过以下方式访问 Jenkins:

如果是 NodePort 类型:访问 http://:,其中 是 Kubernetes 节点的 IP 地址, 是服务的 NodePort 端口号。

如果是 LoadBalancer 类型:访问 http://,其中 是 LoadBalancer 分配的外部 IP 地址。

如果使用 kubectl port-forward:可以将 Jenkins 的服务端口映射到本地端口。执行以下命令:

bash 复制代码
kubectl port-forward svc/jenkins 8080:8080

然后在浏览器中访问 http://localhost:8080

  1. 配置 Jenkins

    访问 Jenkins 后,使用刚刚获取的初始管理员密码进行登录。然后按照 Jenkins 的引导完成初始配置,安装所需的插件和设置管理员用户。

  2. 自定义 Jenkins 配置(可选)

    你可以根据需要自定义 Jenkins 的配置。修改 Helm 的值文件或 Helm Chart 的配置,可以通过以下命令安装 Jenkins 并指定自定义配置:

bash 复制代码
helm install jenkins jenkins/jenkins -f values.yaml

jenkins 开启远程访问

  1. 修改 Jenkins 服务为 NodePort 类型
    你可以通过修改 Jenkins 服务的类型为 NodePort 来使其可从集群外部访问。以下是修改服务类型的步骤:

编辑 Jenkins 服务

bash 复制代码
kubectl edit svc jenkins

在编辑器中,将 type: ClusterIP 修改为 type: NodePort,并保存。最终的 YAML 配置示例如下:

bash 复制代码
apiVersion: v1
kind: Service
metadata:
  name: jenkins
  namespace: default
spec:
  type: NodePort
  ports:
  - port: 8080
    targetPort: 8080
    nodePort: 30000  # 你可以选择一个在 30000-32767 范围内的端口号
  selector:
    app: jenkins

确认更改

检查 Jenkins 服务是否更新成功:

bash 复制代码
kubectl get svc jenkins

你应该能看到 TYPE 列变为 NodePort,并且 PORT(S) 列包含 8080:30000/TCP(如果你设置了 nodePort 为 30000)。

访问 Jenkins

通过以下 URL 访问 Jenkins:

bash 复制代码
http://<node-ip>:30000
相关推荐
等什么君!11 小时前
docker -数据卷技术
运维·docker·容器
花酒锄作田11 小时前
Debian 13基于kubeadm和containerd部署单节点kubernetes
kubernetes·containerd·cilium
上天_去_做颗惺星 EVE_BLUE11 小时前
Docker高效使用指南:从基础到实战模板
开发语言·ubuntu·docker·容器·mac·虚拟环境
好好沉淀13 小时前
Docker开发笔记(详解)
运维·docker·容器
Ankie Wan14 小时前
cgroup(Control Group)是 Linux 内核提供的一种机制,用来“控制、限制、隔离、统计”进程对系统资源的使用。
linux·容器·cgroup·lxc
lcx_defender16 小时前
【Docker】Docker部署运行nacos
运维·docker·容器
啦啦啦小石头16 小时前
docker添加用户权限不使用sudo
运维·docker·容器
春日见17 小时前
Autoware使用教程
大数据·人工智能·深度学习·elasticsearch·搜索引擎·docker·容器
Dontla18 小时前
Kubernetes流量管理双雄:Ingress与Gateway API解析(Nginx与Ingress与Gateway API的关系)
nginx·kubernetes·gateway
lcx_defender18 小时前
【Docker】Docker部署运行Kibana
运维·docker·容器